# 3. compiler commands and flags like CCFLAGS.
# MSGFMT used to process po files
# 4. Variables that will be used to replace variables in some_file.in
-# src/support/package.C.in:
+# src/support/Package.C.in:
# TOP_SRCDIR, LOCALEDIR, LYX_DIR, PROGRAM_SUFFIX
# lib/lyx2lyx/lyx2lyx_version.py.in
# PACKAGE_VERSION
program_suffix = env['version_suffix']
else:
program_suffix = ''
-# used by package.C.in
+# used by Package.C.in
env['PROGRAM_SUFFIX'] = program_suffix
# whether or not add suffix to file and directory names
add_suffix = packaging_method != 'windows'
-# LYX_DIR are different (used in package.C.in)
+# LYX_DIR are different (used in Package.C.in)
if add_suffix:
env['LYX_DIR'] = Dir(os.path.join(prefix, share_dir + program_suffix)).abspath
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':
print "Processing files in src/support..."
frontend_env.Depends('$BUILDDIR/common/support/package.C', '$BUILDDIR/common/config.h')
- env.substFile('$BUILDDIR/common/support/package.C', '$TOP_SRCDIR/src/support/package.C.in')
+ env.substFile('$BUILDDIR/common/support/package.C', '$TOP_SRCDIR/src/support/Package.C.in')
support = frontend_env.StaticLibrary(
target = '$LOCALLIBPATH/support',
#
# moc qt4_moc_files, the moced files are included in the original files
#
- qt4_moced_files = [frontend_env.Moc4(x.replace('.C', '_moc.cpp'), x.replace('.C', '.h')) for x in qt4_moc_files]
+ qt4_moced_files = [frontend_env.Moc4(x.replace('.cpp', '_moc.cpp'), x.replace('.cpp', '.h')) for x in qt4_moc_files]
qt4 = frontend_env.StaticLibrary(
target = '$LOCALLIBPATH/qt4',
print "Processing files in src/tex2lyx..."
#
- for file in ['FloatList.C', 'Floating.C', 'counters.C', 'lyxlayout.h', 'lyxlayout.C',
- 'lyxtextclass.h', 'lyxtextclass.C', 'lyxlex.C', 'lyxlex_pimpl.C']:
+ for file in ['FloatList.cpp', 'Floating.cpp', 'Counters.cpp', 'LyXLayout.h', 'LyXLayout.cpp',
+ 'LyXTextClass.h', 'LyXTextClass.cpp', 'Lexer.cpp', 'Lexer.h']:
frontend_env.Command('$BUILDDIR/common/tex2lyx/'+file, '$TOP_SRCDIR/src/'+file,
[Copy('$TARGET', '$SOURCE')])
env.substFile('$BUILDDIR/common/version.C', '$TOP_SRCDIR/src/version.C.in')
if env.has_key('USE_ASPELL') and env['USE_ASPELL']:
- src_post_files.append('aspell.C')
+ src_post_files.append('ASpell.cpp')
elif env.has_key('USE_PSPELL') and env['USE_PSPELL']:
- src_post_files.append('pspell.C')
+ src_post_files.append('PSpell.cpp')
elif env.has_key('USE_ISPELL') and env['USE_ISPELL']:
- src_post_files.append('ispell.C')
+ src_post_files.append('ISpell.cpp')
# msvc requires at least one source file with main()
- # so I exclude main.C from lyxbase
+ # so I exclude main.cpp from lyxbase
lyxbase_pre = env.StaticLibrary(
target = '$LOCALLIBPATH/lyxbase_pre',
source = ['$BUILDDIR/common/%s' % x for x in src_pre_files]
#
lyx = frontend_env.Program(
target = '$BUILDDIR/lyx',
- source = ['$BUILDDIR/common/main.C'] + \
+ source = ['$BUILDDIR/common/main.cpp'] + \
utils.createResFromIcon(frontend_env, 'lyx_32x32.ico', '$LOCALLIBPATH/lyx.rc'),
LIBS = [
'lyxbase_pre',
#
print 'Updating po/*.po files...'
+ # whether or not update po files
+ if not env['XGETTEXT'] or not env['MSGMERGE'] or not env['MSGUNIQ']:
+ print 'xgettext or msgmerge does not exist. Cannot merge po files'
+ Exit(1)
+ # 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/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/languages_l10n.pot', '$TOP_SRCDIR/lib/languages',
+ '$LYX_POT -b $TOP_SRCDIR -t languages -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',
+ '''$XGETTEXT --default-domain=${TARGET.base} \
+ --directory=$TOP_SRCDIR --add-comments=TRANSLATORS: \
+ --language=C++ --join-existing --keyword=_ --keyword=N_ --keyword=qt_ \
+ --files-from=$TOP_SRCDIR/po/POTFILES.in \
+ --copyright-holder="LyX Developers" \
+ --msgid-bugs-address="lyx-devel@lists.lyx.org" ''']
+ )
+ # copy lyx.po to lyx.pot
+ lyx_pot = env.Command('$BUILDDIR/po/lyx.pot', lyx_po,
+ Copy('$TARGET', '$SOURCE'))
+ #
import glob
# files to translate
- transfiles = glob.glob(os.path.join(env.subst('$TOP_SRCDIR'), 'po', '*.po'))
+ 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'])
- # whether or not update po files
- if not env['XGETTEXT'] or not env['MSGMERGE']:
- 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 \
- --directory=$TOP_SRCDIR \
- --add-comments=TRANSLATORS: $XGETTEXT_OPTIONS \
- --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')
- # ==> lyx.pot
- env.xgettext('$BUILDDIR/common/lyx.pot', '$TOP_SRCDIR/po/POTFILES.in')
+ languages = env.make_list(env['languages'])
+ # merge. if I use lan.po as $TARGET, it will be removed
+ # before it is merged. In this builder,
+ # $BUILDDIR/po/lang.po is merged from po/lang.po and $BUILDDIR/po/lyx.pot
+ # and is copied to po/lang.po
+ env['BUILDERS']['msgmerge'] = Builder(action=[
+ '$MSGMERGE $TOP_SRCDIR/po/${TARGET.filebase}.po $SOURCE -o $TARGET',
+ Copy('$TOP_SRCDIR/po/${TARGET.filebase}.po', '$TARGET')]
+ )
+ # get dependency files from POTFILES.in
+ dep_files = ['$TOP_SRCDIR/%s' % x.strip() for x in open(env.File('$TOP_SRCDIR/po/POTFILES.in').abspath).readlines()]
+ dep_files.append('$TOP_SRCDIR/po/POTFILES.in')
# 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)
- tar1 = env.language_l10n('$BUILDDIR/common/language_l10n.pot', '$TOP_SRCDIR/lib/languages')
- env['BUILDERS']['qt4_l10n'] = Builder(action=utils.env_qt4_l10n)
- tar2 = env.qt4_l10n('$BUILDDIR/common/qt4_l10n.pot',
- ['$TOP_SRCDIR/src/frontends/qt4/ui/%s' % x for x in src_frontends_qt4_ui_files])
- env['BUILDERS']['layouts_l10n'] = Builder(action=utils.env_layouts_l10n)
- tar3 = env.layouts_l10n('$BUILDDIR/common/layouts_l10n.pot',
- ['$TOP_SRCDIR/lib/layouts/%s' % x for x in lib_layouts_files])
- Alias('update_po', [tar1, tar2, tar3])
+ # merge po files, the generated lan.po_new file is copied to lan.po file.
+ po = env.msgmerge('$BUILDDIR/po/%s.po' % country, lyx_pot)
+ env.Depends(po, dep_files)
+ Alias('update_po', po)
if build_po:
dirs = []
for (dir,files) in [
('.', lib_files),
- ('images', lib_images_files),
- ('images/math', lib_images_math_files),
- ('kbd', lib_kbd_files),
- ('layouts', lib_layouts_files),
- ('scripts', lib_scripts_files),
- ('templates', lib_templates_files),
- ('tex', lib_tex_files),
- ('ui', lib_ui_files),
('bind', lib_bind_files),
('bind/de', lib_bind_de_files),
('bind/fi', lib_bind_fi_files),
('examples/ru', lib_examples_ru_files),
('examples/sl', lib_examples_sl_files),
('examples/ro', lib_examples_ro_files),
- ('lyx2lyx', lib_lyx2lyx_files)]:
+ ('fonts', lib_fonts_files),
+ ('images', lib_images_files),
+ ('images/math', lib_images_math_files),
+ ('kbd', lib_kbd_files),
+ ('layouts', lib_layouts_files),
+ ('lyx2lyx', lib_lyx2lyx_files),
+ ('scripts', lib_scripts_files),
+ ('templates', lib_templates_files),
+ ('tex', lib_tex_files),
+ ('ui', lib_ui_files)]:
dirs.append(env.Install(os.path.join(share_dest_dir, dir),
[env.subst('$TOP_SRCDIR/lib/%s/%s' % (dir, file)) for file in files]))
Alias('install', dirs)
if platform_name != 'win32':
print 'installer target is only available for windows platform'
Exit(1)
+ if mode != 'release':
+ print 'installer has to be built in release mode (use option mode=release)'
+ Exit(1)
if env.has_key('NSIS') and env['NSIS'] is not None:
# create a builder to strip and install
env['BUILDERS']['installer'] = Builder(generator=utils.env_nsis)