summaryrefslogtreecommitdiff
path: root/scripts/calcurse-upgrade.sh
diff options
context:
space:
mode:
authorLukas Fleischer <calcurse@cryptocrack.de>2012-05-23 17:12:52 +0200
committerLukas Fleischer <calcurse@cryptocrack.de>2012-05-23 17:25:41 +0200
commit7fa1f0e2aa70a610d6de76e2194857b2ddc36b18 (patch)
tree452f195d3b14941550306dfc7118a858a72e8ccd /scripts/calcurse-upgrade.sh
parentde114ce437d5f34db52a3acd7e17672ea6d76336 (diff)
downloadcalcurse-7fa1f0e2aa70a610d6de76e2194857b2ddc36b18.zip
Add localization to calcurse-upgrade
* Use gettext in "scripts/calcurse-upgrade". * Add "scripts/calcurse-upgrade" to "po/POTFILES.in". * Rename "scripts/calcurse-upgrade" to "scripts/calcurse-upgrade.sh" to make sure xgettext(1) detects the correct input file format. Signed-off-by: Lukas Fleischer <calcurse@cryptocrack.de>
Diffstat (limited to 'scripts/calcurse-upgrade.sh')
-rw-r--r--scripts/calcurse-upgrade.sh96
1 files changed, 96 insertions, 0 deletions
diff --git a/scripts/calcurse-upgrade.sh b/scripts/calcurse-upgrade.sh
new file mode 100644
index 0000000..ffe110a
--- /dev/null
+++ b/scripts/calcurse-upgrade.sh
@@ -0,0 +1,96 @@
+#!/bin/sh
+
+export TEXTDOMAIN='calcurse'
+
+set -e
+
+if [ "$1" = "--config" ]; then
+ CONFFILE=$2
+else
+ CONFFILE=$HOME/.calcurse/conf
+fi
+
+if [ ! -e "$CONFFILE" ]; then
+ echo "$(gettext "Configuration file not found:") $CONFFILE" >&2
+ exit 1
+fi
+
+if grep -q -e '^auto_save=' -e '^auto_gc=' -e '^periodic_save=' \
+ -e '^confirm_quit=' -e '^confirm_delete=' -e '^skip_system_dialogs=' \
+ -e '^skip_progress_bar=' -e '^calendar_default_view=' \
+ -e '^week_begins_on_monday=' -e '^color-theme=' -e '^layout=' \
+ -e '^side-bar_width=' -e '^notify-bar_show=' -e '^notify-bar_date=' \
+ -e '^notify-bar_clock=' -e '^notify-bar_warning=' -e '^notify-bar_command=' \
+ -e '^notify-all=' -e '^output_datefmt=' -e '^input_datefmt=' \
+ -e '^notify-daemon_enable=' -e '^notify-daemon_log=' "$CONFFILE"; then
+
+ echo "$(gettext "Pre-3.0.0 configuration file format detected...")"
+
+ tmpfile="${TMPDIR:-/tmp}/calcurse-upgrade.$!"
+ [ -e "$tmpfile" ] && exit 1
+
+ echo -n "$(gettext "Upgrade configuration directives...")"
+
+ sed -e 's/^auto_save=/general.autosave=/' \
+ -e 's/^auto_gc=/general.autogc=/' \
+ -e 's/^periodic_save=/general.periodicsave=/' \
+ -e 's/^confirm_quit=/general.confirmquit=/' \
+ -e 's/^confirm_delete=/general.confirmdelete=/' \
+ -e 's/^skip_system_dialogs=/general.systemdialogs=/' \
+ -e 's/^skip_progress_bar=/general.progressbar=/' \
+ -e 's/^calendar_default_view=/appearance.calendarview=/' \
+ -e 's/^week_begins_on_monday=/general.firstdayofweek=/' \
+ -e 's/^color-theme=/appearance.theme=/' \
+ -e 's/^layout=/appearance.layout=/' \
+ -e 's/^side-bar_width=/appearance.sidebarwidth=/' \
+ -e 's/^notify-bar_show=/appearance.notifybar=/' \
+ -e 's/^notify-bar_date=/format.notifydate=/' \
+ -e 's/^notify-bar_clock=/format.notifytime=/' \
+ -e 's/^notify-bar_warning=/notification.warning=/' \
+ -e 's/^notify-bar_command=/notification.command=/' \
+ -e 's/^notify-all=/notification.notifyall=/' \
+ -e 's/^output_datefmt=/format.outputdate=/' \
+ -e 's/^input_datefmt=/format.inputdate=/' \
+ -e 's/^notify-daemon_enable=/daemon.enable=/' \
+ -e 's/^notify-daemon_log=/daemon.log=/' "$CONFFILE" > "$tmpfile"
+ mv "$tmpfile" "$CONFFILE"
+
+ if grep -q -e '^[^#=][^#=]*$' -e '^[^#=][^#=]*#.*$' "$CONFFILE"; then
+ sed -e '/^general.autosave=/{N;s/\n//}' \
+ -e '/^general.autogc=/{N;s/\n//}' \
+ -e '/^general.periodicsave=/{N;s/\n//}' \
+ -e '/^general.confirmquit=/{N;s/\n//}' \
+ -e '/^general.confirmdelete=/{N;s/\n//}' \
+ -e '/^general.systemdialogs=/{N;s/\n//}' \
+ -e '/^general.progressbar=/{N;s/\n//}' \
+ -e '/^appearance.calendarview=/{N;s/\n//}' \
+ -e '/^general.firstdayofweek=/{N;s/\n//}' \
+ -e '/^appearance.theme=/{N;s/\n//}' \
+ -e '/^appearance.layout=/{N;s/\n//}' \
+ -e '/^appearance.sidebarwidth=/{N;s/\n//}' \
+ -e '/^appearance.notifybar=/{N;s/\n//}' \
+ -e '/^format.notifydate=/{N;s/\n//}' \
+ -e '/^format.notifytime=/{N;s/\n//}' \
+ -e '/^notification.warning=/{N;s/\n//}' \
+ -e '/^notification.command=/{N;s/\n//}' \
+ -e '/^notification.notifyall=/{N;s/\n//}' \
+ -e '/^format.outputdate=/{N;s/\n//}' \
+ -e '/^format.inputdate=/{N;s/\n//}' \
+ -e '/^daemon.enable=/{N;s/\n//}' \
+ -e '/^daemon.log=/{N;s/\n//}' "$CONFFILE" > "$tmpfile"
+ mv "$tmpfile" "$CONFFILE"
+ fi
+
+ awk '
+ BEGIN { FS=OFS="=" }
+ $1 == "general.systemdialogs" || $1 == "general.progressbar" \
+ { $2 = ($2 == "yes") ? "no" : "yes" }
+ $1 == "general.firstdayofweek" { $2 = ($2 == "yes") ? "monday" : "sunday" }
+ { print }
+ ' < "$CONFFILE" > "$tmpfile"
+ mv "$tmpfile" "$CONFFILE"
+
+ echo -n ' '
+ echo "$(gettext 'done')"
+fi
+