env['MSGFMT'] = conf.CheckCommand('msgfmt')
env['MSGMERGE'] = conf.CheckCommand('msgmerge')
env['XGETTEXT'] = conf.CheckCommand('xgettext')
+env['MSGUNIQ'] = conf.CheckCommand('msguniq')
# if under windows, check the nsis compiler
if platform_name == 'win32':
#
print 'Updating po/*.po files...'
- import glob
- # files to translate
- transfiles = glob.glob(os.path.join(env.subst('$TOP_SRCDIR'), 'po', '*.po'))
- # possibly *only* handle these languages
- languages = None
- if env.has_key('languages'):
- languages = env.make_list(env['lanauges'])
# whether or not update po files
- if not env['XGETTEXT'] or not env['MSGMERGE']:
+ if not env['XGETTEXT'] or not env['MSGMERGE'] or not env['MSGUNIQ']:
print 'xgettext or msgmerge does not exist. Can not merge po files'
Exit(1)
- # create a builder that generate
- env['XGETTEXT_OPTIONS'] = '--language=C++ --join-existing --keyword=_ --keyword=N_ --keyword=qt_'
- env['MSGMERGE_OPTIONS'] = '--update'
- env['COPYRIGHT_HOLDER'] = 'LyX Developers'
- env['MSGID_BUGS_ADDRESS'] = 'lyx-devel@lists.lyx.org'
- env['BUILDERS']['xgettext'] = Builder(action='''$XGETTEXT --default-domain=lyx \
- --output=$TARGET \
+ # build language_l10n.pot, ui_l10n.pot, layouts_l10n.pot, qt4_l10n.pot
+ # and combine them to lyx.po
+ env['LYX_POT'] = 'python $TOP_SRCDIR/po/lyx_pot.py'
+ lyx_po = env.Command('$BUILDDIR/po/lyx.po',
+ env.Command('$BUILDDIR/po/all.po',
+ [env.Command('$BUILDDIR/po/language_l10n.pot', '$TOP_SRCDIR/lib/languages',
+ '$LYX_POT -b $TOP_SRCDIR -t languages -o $TARGET $SOURCES'),
+ env.Command('$BUILDDIR/po/qt4_l10n.pot',
+ ['$TOP_SRCDIR/src/frontends/qt4/ui/%s' % x for x in src_frontends_qt4_ui_files],
+ '$LYX_POT -b $TOP_SRCDIR -t qt4 -o $TARGET $SOURCES'),
+ env.Command('$BUILDDIR/po/layouts_l10n.pot',
+ ['$TOP_SRCDIR/lib/layouts/%s' % x for x in lib_layouts_files],
+ '$LYX_POT -b $TOP_SRCDIR -t layouts -o $TARGET $SOURCES'),
+ env.Command('$BUILDDIR/po/ui_l10n.pot',
+ ['$TOP_SRCDIR/lib/ui/%s' % x for x in lib_ui_files],
+ '$LYX_POT -b $TOP_SRCDIR -t ui -o $TARGET $SOURCES'),
+ ], utils.env_cat),
+ '$MSGUNIQ -o $TARGET $SOURCE'
+ )
+ # create a builder that generate real po files
+ env['BUILDERS']['xgettext'] = Builder(action=['''$XGETTEXT \
+ --default-domain=${SOURCE.filebase} \
--directory=$TOP_SRCDIR \
- --add-comments=TRANSLATORS: $XGETTEXT_OPTIONS \
+ --add-comments=TRANSLATORS: \
+ --language=C++ --join-existing --keyword=_ --keyword=N_ --keyword=qt_ \
--files-from=$TOP_SRCDIR/po/POTFILES.in \
- --copyright-holder='$COPYRIGHT_HOLDER' \
- --msgid-bugs-address='$MSGID_BUGS_ADDRESS' ''')
- env['BUILDERS']['msgmerge'] = Builder(action='$MSGMERGE $MSGMERGE_OPTIONS $SOURCE $TARGET')
+ --copyright-holder='LyX Developers' \
+ --msgid-bugs-address='lyx-devel@lists.lyx.org' ''',
+ Copy('$TARGET', '$SOURCE')]
+ )
+ env['BUILDERS']['msgmerge'] = Builder(action=[
+ '$MSGMERGE -o $TARGET $SOURCE ${TARGET.base}.po',
+ Copy('${TARGET.base}.po', '$TARGET')]
+ )
# ==> lyx.pot
- env.xgettext('$BUILDDIR/common/lyx.pot', '$TOP_SRCDIR/po/POTFILES.in')
+ lyx_pot = env.xgettext('$BUILDDIR/po/lyx.pot', lyx_po)
+ #
+ import glob
+ # files to translate
+ transfiles = glob.glob(os.path.join(env.Dir('$TOP_SRCDIR/po').abspath, '*.po'))
+ # possibly *only* handle these languages
+ languages = None
+ if env.has_key('languages'):
+ languages = env.make_list(env['lanauges'])
# for each po file, generate pot
- for f in transfiles:
+ for po_file in transfiles:
# get filename
- fname = os.path.split(f)[1]
+ fname = os.path.split(po_file)[1]
# country code
country = fname.split('.')[0]
#
if not languages or country in languages:
# merge po files
- env.msgmerge(f, '$BUILDDIR/common/lyx.pot')
- # build language_l10n.pot
- env['BUILDERS']['language_l10n'] = Builder(action=utils.env_language_l10n)
- tar = env.language_l10n('$BUILDDIR/common/language_l10n.pot', '$TOP_SRCDIR/lib/languages')
- Alias('update_po', tar)
+ # FIXME: Depends on POTFILES.in and its content
+ Alias('update_po', env.msgmerge(po_file + '_new', lyx_pot))
if build_po: