summaryrefslogtreecommitdiffstats
path: root/gconf/gconf-merge-schema
diff options
context:
space:
mode:
authorpiernov <piernov@piernov.org>2012-02-22 17:22:19 +0100
committerpiernov <piernov@piernov.org>2012-02-22 17:22:19 +0100
commit5060cac4ab81a2d1f5edc22aa5ebfe4ba37db8d2 (patch)
tree902cea516d10d11bda3b83aabbc3fe3b38072225 /gconf/gconf-merge-schema
parent8cf3930268811e83157b7af6b896dbbe6b5f00c3 (diff)
downloadnutyx-extra-5060cac4ab81a2d1f5edc22aa5ebfe4ba37db8d2.tar.gz
nutyx-extra-5060cac4ab81a2d1f5edc22aa5ebfe4ba37db8d2.tar.bz2
nutyx-extra-5060cac4ab81a2d1f5edc22aa5ebfe4ba37db8d2.tar.xz
nutyx-extra-5060cac4ab81a2d1f5edc22aa5ebfe4ba37db8d2.zip
gconf dans extra
Diffstat (limited to 'gconf/gconf-merge-schema')
-rw-r--r--gconf/gconf-merge-schema34
1 files changed, 34 insertions, 0 deletions
diff --git a/gconf/gconf-merge-schema b/gconf/gconf-merge-schema
new file mode 100644
index 000000000..992c162e6
--- /dev/null
+++ b/gconf/gconf-merge-schema
@@ -0,0 +1,34 @@
+#!/bin/bash
+if [ ! "$1" -a ! "$2" ]; then
+ echo "Usage: $0 output.schemas [--domain gettextdomain] file1.schemas [file2.schemas [...]]"
+ exit 1
+fi
+
+OUTFILE="$1"
+DOMAIN=""
+shift
+
+if [ "$1" = "--domain" ]; then
+ shift
+ DOMAIN=$1
+ shift
+fi
+
+echo '<?xml version="1.0"?>' > "$OUTFILE"
+echo '<gconfschemafile><schemalist>' >> "$OUTFILE"
+
+while [ "$1" ]; do
+ if [ -f "$1" ]; then
+ sed -e '/<?xml/d' \
+ -e 's|<gconfschemafile>||g' \
+ -e 's|</gconfschemafile>||g' \
+ -e 's|<schemalist>||g' \
+ -e 's|</schemalist>||g' "$1" >> "$OUTFILE"
+ fi
+ shift
+done
+
+echo '</schemalist></gconfschemafile>' >> "$OUTFILE"
+if [ "$DOMAIN" != "" ]; then
+ sed -ri "s/^([[:space:]]*)(<locale name=\"C\">)/\1<gettext_domain>$DOMAIN<\/gettext_domain>\n\1\2/; /^[[:space:]]*<locale name=\"[^C]/,/^[[:space:]]*<\/locale>[[:space:]]*\$/ d; /^$/d; s/<\/schema>$/&\n/" "$OUTFILE"
+fi