]> git.lyx.org Git - lyx.git/blobdiff - development/scons/SConstruct
Scons: update_po target, move processing functions to po/lyx_pot.py
[lyx.git] / development / scons / SConstruct
index 8c6e74a83abea2b028ec44d18c5d6e7a256307e7..aa16849ce7f9b617756226793f7e3dc698835c85 100644 (file)
@@ -718,6 +718,7 @@ else:
 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':
@@ -1981,46 +1982,65 @@ if update_po:
     #
     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: