X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=SConstruct;h=da35a8d2a58ae310c7829edf65794a4ac3784668;hb=e898f807e2bdd260a0967051829fe307e2e4a0bd;hp=87c1bebe7661de6994fbb8d2c7efe03bdc25c3d1;hpb=15c5e1939d77dfea97da38df7526bcb84a53460b;p=senf.git diff --git a/SConstruct b/SConstruct index 87c1beb..da35a8d 100644 --- a/SConstruct +++ b/SConstruct @@ -1,41 +1,94 @@ # -*- python -*- -import sys, glob, os.path, datetime +import sys, glob, os.path, datetime, pwd, time sys.path.append('senfscons') import SENFSCons ########################################################################### -svninfo = dict( - [ map(lambda y:y.strip(),x.split(":",1)) - for x in os.popen("svn info").read().split("\n") - if ':' in x ] ) -svninfo['commited'] = not(os.popen("svn status -q").read()) - +# Load utilities and setup libraries SENFSCons.UseBoost() SENFSCons.UseSTLPort() env = SENFSCons.MakeEnvironment() +env.Help(""" +Additional top-level build targets: + +all_tests Build and run unit tests for all modules +all_docs Build documentation for all modules +all Build everything +install_all Install SENF into $PREFIX +deb Build debian source and binary package +debsrc Build debian source package +debbin Build debian binary package +""") + +if os.environ.get('debian_build'): + rev = os.popen("dpkg-parsechangelog | awk '/^Version:/{print $2}'").read().strip() +else: + rev = 'r' + os.popen("svnversion").read().strip().lower() + +# Configure build env.Append( CPPPATH = [ '#' ], - LIBS = [ 'iberty' ], + LIBS = [ 'iberty', '$BOOSTREGEXLIB' ], DOXY_XREF_TYPES = [ 'bug', 'fixme', 'todo', 'idea' ], DOXY_HTML_XSL = '#/doclib/html-munge.xsl', ENV = { 'TODAY' : str(datetime.date.today()), - 'REVISION' : svninfo['Revision'] + (not(svninfo['commited']) and " + local changes" or ""), + 'REVISION' : rev, + 'LOGNAME' : os.environ['LOGNAME'] # needed by the debian build scripts }, ) Export('env') +# Build modules (that is, instruct to build ... the build happens later) SConscript(glob.glob("*/SConscript")) SENFSCons.StandardTargets(env) SENFSCons.GlobalTargets(env) SENFSCons.Doxygen(env) -SENFSCons.DoxyXRef(env, + +SENFSCons.DoxyXRef(env, HTML_HEADER = '#/doclib/doxy-header-overview.html', HTML_FOOTER = '#/doclib/doxy-footer.html') +def updateRevision(target, source, env): + rev = env['ENV']['REVISION'][1:] + if ':' in rev: + print + print "Working copy not clean. Run 'svn update'" + print + return 1 + if 'm' in rev and not ARGUMENTS.get('force_deb'): + print + print "Working copy contains local changes. Commit first" + print + return 1 + if 's' in rev: + rev = rev[:-1] + if 'm' in rev: + rev = rev[:-1] + changelog = file('debian/changelog.template').read() % { + 'rev': rev, + 'user': pwd.getpwuid(os.getuid()).pw_gecos.split(',')[0].strip(), + 'date': time.strftime("%a, %d %b %Y %H:%M:%S +0000", time.gmtime()) } + file('debian/changelog','w').write(changelog) + +if not os.environ.get('debian_build'): + env.AlwaysBuild( + env.Alias('deb', [], [ updateRevision, + "dpkg-buildpackage -us -uc -rfakeroot -I.svn" ])) + + env.AlwaysBuild( + env.Alias('debsrc', [], [ updateRevision, + "dpkg-buildpackage -us -uc -rfakeroot -S -I.svn" ])) + + env.AlwaysBuild( + env.Alias('debbin', [], [ updateRevision, + "dpkg-buildpackage -us -uc -rfakeroot -nc" ])) + +# Create Doxyfile.local if not cleaning and the file does not exist +# otherwise doxygen will barf on this non-existent file if not env.GetOption('clean') and not os.path.exists("Doxyfile.local"): Execute(Touch("Doxyfile.local"))