diff --git a/SConstruct b/SConstruct index c49b8434c..29c5a82c7 100644 --- a/SConstruct +++ b/SConstruct @@ -1,110 +1,158 @@ # This file is part of Mapnik (c++ mapping toolkit) -# Copyright (C) 2005 Artem Pavlenko +# Copyright (C) 2005 Artem Pavlenko, Jean-Francois Doyon # # Mapnik is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License # as published by the Free Software Foundation; either version 2 # of the License, or any later version. -# +# # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. -# +# # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -# +# # $Id$ -import os +import os, sys -#edit 'settings.py' to match your system settings -opts = Options('settings.py') +opts = Options() -opts.Add('PREFIX', 'Set the install "prefix"', '/opt/mapnik') -opts.Add(PathOption('BOOST_ROOT','boost source root directory','/opt/boost')) -opts.Add(PathOption('AGG_ROOT','agg source root directory','/opt/agg23')) -opts.Add(PathOption('FREETYPE2_ROOT','freetype2 root directory','/opt/freetype2')) -opts.Add(PathOption('PYTHON_ROOT','python root directory','/opt/python')) -opts.Add('PYTHON_VERSION','python version','2.4') -opts.Add(ListOption('DATASOURCES','list of available datasources','all',['postgis','shape','raster'])) -opts.Add(ListOption('EXTENSIONS','list of available extensions','none',['python'])) -opts.Add('POSTGRESQL_ROOT','path to postgresql prefix','/usr/local') - -platform = ARGUMENTS.get("OS",Platform()) - -build_dir = 'build' -build_prefix = build_dir+'/'+str(platform) - -#cxx = 'g++' +opts.Add('PREFIX', 'The install path "prefix"', '/usr/local') +opts.Add(PathOption('BOOST_INCLUDES', 'Search path for boost include files', '/usr/include')) +opts.Add(PathOption('BOOST_LIBS', 'Search path for boost library files', '/usr/lib')) +opts.Add(PathOption('FREETYPE_INCLUDES', 'Search path for FreeType include files', '/usr/include')) +opts.Add(PathOption('FREETYPE_LIBS', 'Search path for FreeType library files', '/usr/lib')) +opts.Add(PathOption('PNG_INCLUDES', 'Search path for libpng include files', '/usr/include')) +opts.Add(PathOption('PNG_LIBS', 'Search path for libpng include files', '/usr/lib')) +opts.Add(PathOption('JPEG_INCLUDES', 'Search path for libjpeg include files', '/usr/include')) +opts.Add(PathOption('JPEG_LIBS', 'Search path for libjpeg library files', '/usr/lib')) +opts.Add(PathOption('TIFF_INCLUDES', 'Search path for libtiff include files', '/usr/include')) +opts.Add(PathOption('TIFF_LIBS', 'Search path for libtiff library files', '/usr/lib')) +opts.Add(PathOption('PGSQL_INCLUDES', 'Search path for PostgreSQL include files', '/usr/include')) +opts.Add(PathOption('PGSQL_LIBS', 'Search path for PostgreSQL library files', '/usr/lib')) +opts.Add(PathOption('PYTHON','Python executable','/usr/local/bin/python2.4')) +opts.Add(ListOption('INPUT_PLUGINS','Input drivers to include','all',['postgis','shape','raster'])) +opts.Add(ListOption('BINDINGS','Language bindings to build','all',['python'])) env = Environment(ENV=os.environ, options=opts) -cxx_debug='-Wall -Wno-non-virtual-dtor -Wno-ctor-dtor-privacy -ftemplate-depth-100 -O0 -fno-inline -g -pthread -DDEBUG' -cxx_release='-Wall -Wno-non-virtual-dtor -Wno-ctor-dtor-privacy -ftemplate-depth-100 -O3 -finline-functions -Wno-inline -pthread -DNDEBUG ' - -#release_env = env.Copy(CXXFLAGS = cxx_release) -#debug_env = env.Copy(CXXFLAGS = cxx_debug) - -if ARGUMENTS.get('debug',0): - env.Append(CXXFLAGS = cxx_debug) - build_prefix+='/debug' -else: - env.Append(CXXFLAGS = cxx_release) - build_prefix+='/release' - Help(opts.GenerateHelpText(env)) conf = Configure(env) -if not conf.CheckLibWithHeader('ltdl','ltdl.h','C'): - print 'Could not find libltdl/headers , exiting!' - Exit(1) +# Libraries and headers dependency checks -if not conf.CheckLib('z'): - print 'Could not find libz , exiting!' - Exit(1) +env['CPPPATH'] = ['#agg/include', '#include'] -if not conf.CheckLibWithHeader('png','png.h','C'): - print 'Could not find png lib and/or headers, exiting!' - Exit(1) +for path in [env['BOOST_INCLUDES'], env['FREETYPE_INCLUDES'], env['PNG_INCLUDES'], env['JPEG_INCLUDES'], env['TIFF_INCLUDES'], env['PGSQL_INCLUDES']]: + if path not in env['CPPPATH']: env['CPPPATH'].append(path) -if not conf.CheckLib('jpeg'): - print 'Could not find jpeg lib, exiting!' - Exit(1) - -if not conf.CheckLibWithHeader('tiff','tiff.h','C'): - print 'Could not find tiff lib and/or headers, exiting!' - Exit(1) - -env = conf.Finish() +env['LIBPATH'] = ['#agg', '#src'] + +for path in [env['BOOST_LIBS'], env['FREETYPE_LIBS'], env['PNG_LIBS'], env['JPEG_LIBS'], env['TIFF_LIBS'], env['PGSQL_LIBS']]: + if path not in env['LIBPATH']: env['LIBPATH'].append(path) + +C_LIBSHEADERS = [ + ['ltdl', 'ltdl.h', True], + ['png', 'png.h', True], + ['tiff', 'tiff.h', True], + ['z', 'zlib.h', True], + ['jpeg', ['stdio.h','jpeglib.h'], True], + ['pq', 'libpq-fe.h', False] +] + +BOOST_LIBSHEADERS = [ + ['thread', 'boost/thread/mutex.hpp', True], + ['filesystem', 'boost/filesystem/operations.hpp', True], + ['wserialization', ['boost/archive/text_oarchive.hpp', + 'boost/archive/text_iarchive.hpp', + 'boost/archive/xml_oarchive.hpp', + 'boost/archive/xml_iarchive.hpp'], True + ], + ['regex', 'boost/regex.hpp', True], + ['program_options', 'boost/program_options.hpp', False] +] + +for libinfo in C_LIBSHEADERS: + if not conf.CheckLibWithHeader(libinfo[0], libinfo[1], 'C') and libinfo[2]: + print 'Could not find header or shared library for %s, exiting!' % libinfo[0] + Exit(1) + +for libinfo in BOOST_LIBSHEADERS: + if not conf.CheckLibWithHeader('boost_%s' % libinfo[0], libinfo[1], 'C++'): + if not conf.CheckLibWithHeader('boost_%s-%s-mt' % (libinfo[0], env['CC']), libinfo[1], 'C++') and libinfo[2]: + print 'Could not find header or shared library for boost %s, exiting!' % libinfo[0] + Exit(1) + +# Check out the Python situation + +if 'python' in env['BINDINGS']: + if not os.access(env['PYTHON'], os.X_OK): + print 'Cannot run python, make sure that you have the permissions to execute it.' + Exit(1) + + env['PYTHON_PREFIX'] = os.popen("%s -c 'import sys; print sys.prefix'" % env['PYTHON']).read().strip() + env['PYTHON_VERSION'] = os.popen("%s -c 'import sys; print sys.version'" % env['PYTHON']).read()[0:3] + + print 'Bindings Python version... %s' % env['PYTHON_VERSION'] + + majver, minver = env['PYTHON_VERSION'].split('.') + + if int(majver) > 1: + if int(minver) < 3: + print "Python version 2.2 or greater required" + Exit(1) + else: + print "Python version 2.2 or greater required" + Exit(1) + + print 'Python %s prefix... %s' % (env['PYTHON_VERSION'], env['PYTHON_PREFIX']) + +env = conf.Finish() + +# Setup the c++ args for our own codebase + +if ARGUMENTS.get('DEBUG',0): + env.Append(CXXFLAGS = '-Wall -ftemplate-depth-100 -O0 -fno-inline -g -pthread -DDEBUG') +else: + env.Append(CXXFLAGS = '-Wall -ftemplate-depth-100 -O3 -finline-functions -Wno-inline -pthread -DNDEBUG') + +# Build the input plug-ins + +inputplugins = [ driver.strip() for driver in Split(env['INPUT_PLUGINS'])] Export('env') -#build agg lib -env.SConscript('agg/SConscript') -#build boost libs (filesystem, regex, python etc) -env.SConscript('boost/SConscript') -#main lib + +# Build agg first, doesn't need anything special + +SConscript('agg/SConscript') + +# Build shapeindex and remove it's dependency from the LIBS + +if 'boost_program_options' in env['LIBS'] or 'boost_program_options-gcc-mt' in env['LIBS']: + SConscript('utils/shapeindex/SConscript') + +if 'postgis' in inputplugins and 'pq' in env['LIBS']: + SConscript('plugins/input/postgis/SConscript') + env['LIBS'].remove('pq') + +if 'shape' in inputplugins: + SConscript('plugins/input/shape/SConscript') + +if 'raster' in inputplugins: + SConscript('plugins/input/raster/SConscript') + +# Build the core library + SConscript('src/SConscript') -import string - -#python bindings - -if 'python' in [string.strip(m) for m in Split(env['EXTENSIONS'])]: - SConscript('python/SConscript') - -#shapeindex -SConscript('util/shapeindex/SConscript') - -#datasources -def build_datasource(name): - env.BuildDir('build/datasources/' + name,'src/datasources/'+name,duplicate=0) - SConscript('datasources/' + name + '/SConscript') - -[build_datasource(name) for name in Split(env['DATASOURCES'])] - - +# Build python bindings +bindings = [ binding.strip() for binding in Split(env['BINDINGS'])] +if 'python' in bindings: + SConscript('bindings/python/SConscript')