From 44df3a0541b53d7a23a99079d0f653a4aa7bcf95 Mon Sep 17 00:00:00 2001 From: Bo Peng Date: Tue, 26 Sep 2006 19:33:31 +0000 Subject: [PATCH] Scons: get version info from configure.ac, add fonts and postinstall script for cygwin git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/branches/BRANCH_1_4_X@15157 a592a061-630c-0410-9148-cb99ea01b6c8 --- development/scons/SConstruct | 23 ++++++++++++++--- development/scons/scons_manifest.py | 12 +++++++++ development/scons/scons_utils.py | 39 +++++++++++++++++++++++++++++ 3 files changed, 70 insertions(+), 4 deletions(-) diff --git a/development/scons/SConstruct b/development/scons/SConstruct index 1aea17d581..8aac113a97 100644 --- a/development/scons/SConstruct +++ b/development/scons/SConstruct @@ -53,12 +53,18 @@ else: # some global settings # -package_version = '1.4.3svn' -package_cygwin_version = '1.4.3svn-1' +# get version number from configure.ac so that JMarc does +# not have to change SConstruct during lyx release +package_version = utils.getVerFromConfigure(top_src_dir) +package_cygwin_version = '%s-1' % package_version boost_version = '1_32' -devel_version = True -default_build_mode = 'debug' +if 'svn' in package_version: + devel_version = True + default_build_mode = 'debug' +else: + devel_version = False + default_build_mode = 'release' package = 'lyx' package_bugreport = 'lyx-devel@lists.lyx.org' @@ -2088,6 +2094,15 @@ if 'install' in targets: env.Install(Cygwin_Doc, [os.path.join(env.subst('$TOP_SRCDIR'), x) for x in \ ['INSTALL', 'README', 'README.Cygwin', 'RELEASE-NOTES', 'COPYING', 'ANNOUNCE']]) Alias('install', Cygwin_Doc) + # cygwin fonts also need to be installed + env.Install(os.path.join(share_dest_dir, 'font'), + [env.subst('$TOP_SRC_DIR/development/Win32/packaging/bakoma/%s' % file) \ + for file in win32_bakoma_fonts]) + # we also need a post installation script + tmp_script = utils.installCygwinPostinstallScript('/tmp') + postinstall_script = os.path.join(dest_dir, 'etc', 'postinstall', 'lyx.sh') + env.Install(postinstall_script, tmp_script) + Alias('install', postinstall_script) # lyx1.4.x does not have lyx2lyx_version.py.in if os.path.isfile(env.subst('$TOP_SRCDIR/lib/lyx2lyx/lyx2lyx_version.py.in')): diff --git a/development/scons/scons_manifest.py b/development/scons/scons_manifest.py index fb7c87836c..fce59e10db 100644 --- a/development/scons/scons_manifest.py +++ b/development/scons/scons_manifest.py @@ -2266,3 +2266,15 @@ lib_lyx2lyx_files = Split(''' profiling.py ''') +win32_bakoma_fonts = Split(''' + Readme.txt + Licence.txt + cmex10.ttf + cmr10.ttf + eufm10.ttf + msbm10.ttf + cmmi10.ttf + cmsy10.ttf + msam10.ttf + wasy10.ttf +''') diff --git a/development/scons/scons_utils.py b/development/scons/scons_utils.py index e6c6aded65..5caef41f72 100644 --- a/development/scons/scons_utils.py +++ b/development/scons/scons_utils.py @@ -16,6 +16,24 @@ import os, sys, re, shutil, glob from SCons.Util import WhereIs +def getVerFromConfigure(path): + " get lyx version from the AC_INIT line of configure.ac " + try: + config = open(os.path.join(path, 'configure.ac')) + except: + print "Can not open configure.ac. " + return 'x.x.x' + # find a line like follows + # AC_INIT(LyX,1.4.4svn,[lyx-devel@lists.lyx.org],[lyx]) + pat = re.compile('AC_INIT\([^,]+,([^,]+),') + for line in config.readlines(): + if pat.match(line): + (version,) = pat.match(line).groups() + return version.strip() + return 'x.x.x' + + + def writeToFile(filename, lines, append = False): " utility function: write or append lines to filename " # create directory if needed @@ -581,6 +599,27 @@ SECTIONS return(ld_script) +def installCygwinPostinstallScript(path): + ''' Install lyx.sh ''' + postinstall_script = os.path.join(path, 'lyx.sh') + script = open(postinstall_script, 'w') + script.write('''#!/bin/sh + +# Add /usr/share/lyx/fonts to /etc/fonts/local.conf +# if it is not already there. +if [ -f /etc/fonts/local.conf ]; then + grep -q /usr/share/lyx/fonts /etc/fonts/local.conf + if [ $? -ne 0 ]; then + sed 's/^<\/fontconfig>/\/usr\/share\/lyx\/fonts<\/dir>\n<\/fontconfig>/' /etc/fonts/local.conf > /etc/fonts/local.conf.tmp + mv -f /etc/fonts/local.conf.tmp /etc/fonts/local.conf + fc-cache /usr/share/lyx/fonts + fi +fi + ''') + script.close() + return(postinstall_script) + + try: # these will be used under win32 import win32file