New way to run configuration scripts

This commit is contained in:
Pierre Pronchery 2010-12-31 16:09:48 +00:00
parent 4c70a7d2f8
commit db45466325
2 changed files with 80 additions and 55 deletions

View File

@ -10,19 +10,19 @@ INSTALL = install
all: $(TARGETS)
Editor.pot: POTFILES
./gettext.sh "Editor.pot"
./gettext.sh -P "$(PREFIX)" -- "Editor.pot"
de.mo: Editor.pot de.po
./gettext.sh "de.mo"
./gettext.sh -P "$(PREFIX)" -- "de.mo"
es.mo: Editor.pot es.po
./gettext.sh "es.mo"
./gettext.sh -P "$(PREFIX)" -- "es.mo"
fr.mo: Editor.pot fr.po
./gettext.sh "fr.mo"
./gettext.sh -P "$(PREFIX)" -- "fr.mo"
it.mo: Editor.pot it.po
./gettext.sh "it.mo"
./gettext.sh -P "$(PREFIX)" -- "it.mo"
clean:
$(RM) -- $(Editor.pot_OBJS) $(de.mo_OBJS) $(es.mo_OBJS) $(fr.mo_OBJS) $(it.mo_OBJS)
@ -31,15 +31,15 @@ distclean: clean
$(RM) -- $(TARGETS)
install: all
./gettext.sh -p "$(DESTDIR)$(PREFIX)" install "de.mo"
./gettext.sh -p "$(DESTDIR)$(PREFIX)" install "es.mo"
./gettext.sh -p "$(DESTDIR)$(PREFIX)" install "fr.mo"
./gettext.sh -p "$(DESTDIR)$(PREFIX)" install "it.mo"
./gettext.sh -P "$(DESTDIR)$(PREFIX)" -i -- "de.mo"
./gettext.sh -P "$(DESTDIR)$(PREFIX)" -i -- "es.mo"
./gettext.sh -P "$(DESTDIR)$(PREFIX)" -i -- "fr.mo"
./gettext.sh -P "$(DESTDIR)$(PREFIX)" -i -- "it.mo"
uninstall:
./gettext.sh -p "$(DESTDIR)$(PREFIX)" uninstall "de.mo"
./gettext.sh -p "$(DESTDIR)$(PREFIX)" uninstall "es.mo"
./gettext.sh -p "$(DESTDIR)$(PREFIX)" uninstall "fr.mo"
./gettext.sh -p "$(DESTDIR)$(PREFIX)" uninstall "it.mo"
./gettext.sh -P "$(DESTDIR)$(PREFIX)" -u -- "de.mo"
./gettext.sh -P "$(DESTDIR)$(PREFIX)" -u -- "es.mo"
./gettext.sh -P "$(DESTDIR)$(PREFIX)" -u -- "fr.mo"
./gettext.sh -P "$(DESTDIR)$(PREFIX)" -u -- "it.mo"
.PHONY: all clean distclean install uninstall

View File

@ -18,16 +18,6 @@ XGETTEXT="xgettext --force-po"
#functions
#usage
_usage()
{
echo "Usage: ./gettext.sh <target>" 1>&2
echo " ./gettext.sh -p <prefix> install <target>" 1>&2
echo " ./gettext.sh -p <prefix> uninstall <target>" 1>&2
return 1
}
#debug
_debug()
{
@ -36,6 +26,14 @@ _debug()
}
#usage
_usage()
{
echo "Usage: gettext.sh [-i|-u][-P prefix] <target>" 1>&2
return 1
}
#gettext_mo
_gettext_mo()
{
@ -63,38 +61,65 @@ _gettext_pot()
#main
if [ $# -eq 4 -a "$1" = "-p" ]; then
PREFIX="$2"
LOCALEDIR="$PREFIX/share/locale"
lang="${4%%.mo}"
if [ "$3" = "install" ]; then
$DEBUG $MKDIR "$LOCALEDIR/$lang/LC_MESSAGES" || exit 2
$DEBUG $INSTALL "$4" \
"$LOCALEDIR/$lang/LC_MESSAGES/$PACKAGE.mo" \
|| exit 2
exit 0
elif [ "$3" = "uninstall" ]; then
$DEBUG $RM "$LOCALEDIR/$lang/LC_MESSAGES/$PACKAGE.mo" \
|| exit 2
exit 0
else
echo "gettext.sh: $3: Unknown operation" 1>&2
fi
fi
if [ $# -ne 1 ]; then
args=`getopt iuP: $*`
if [ $? -ne 0 ]; then
_usage
exit $?
fi
case "$1" in
*.mo)
_gettext_mo "$PACKAGE" "${1%%.mo}" || exit 2
;;
*.pot)
_gettext_pot "${1%%.pot}" || exit 2
;;
*)
exit 2
;;
esac
exit 0
set -- $args
install=0
uninstall=0
while [ $# -gt 0 ]; do
case "$1" in
-i)
install=1
;;
-u)
uninstall=1
;;
-P)
PREFIX="$2"
shift
;;
--)
shift
break
;;
esac
shift
done
LOCALEDIR="$PREFIX/share/locale"
while [ $# -gt 0 ]; do
target="$1"
lang="${target%%.mo}"
shift
#uninstall
if [ "$uninstall" -eq 1 ]; then
$DEBUG $RM "$LOCALEDIR/$lang/LC_MESSAGES/$PACKAGE.mo" \
|| exit 2
continue
fi
#create
case "$target" in
*.mo)
_gettext_mo "$PACKAGE" "$lang" || exit 2
;;
*.pot)
_gettext_pot "${target%%.pot}" || exit 2
;;
*)
exit 2
;;
esac
#install
if [ "$install" -eq 1 ]; then
$DEBUG $MKDIR "$LOCALEDIR/$lang/LC_MESSAGES" || exit 2
$DEBUG $INSTALL "$target" \
"$LOCALEDIR/$lang/LC_MESSAGES/$PACKAGE.mo" \
|| exit 2
fi
done