diff options
author | Michel Selten <michel@mselten.demon.nl> | 2004-02-21 18:13:15 +0300 |
---|---|---|
committer | Michel Selten <michel@mselten.demon.nl> | 2004-02-21 18:13:15 +0300 |
commit | 9e238d385d34bdbc09d2643fd2a1575886e024b3 (patch) | |
tree | 21238f7650ee8a1a52444036c99d93786f7fb274 /SConstruct | |
parent | 05bff7f93823d484ca237340a5b6af546a7e99c3 (diff) |
SCons updates
* Almost all library settings are now available in the config.opts user option
file.
* All platform variables had to be updated to make this possible. Things are
much clearer now, but I only was able to test the changes on Linux. I've
tried to update all other platform variables, but things are most likely to
be broken. Please contact me how to resolve the issues.
Note: Before running scons, remove your existing config.opts file to get all
new options.
Diffstat (limited to 'SConstruct')
-rw-r--r-- | SConstruct | 493 |
1 files changed, 372 insertions, 121 deletions
diff --git a/SConstruct b/SConstruct index bcc11452313..40180d82193 100644 --- a/SConstruct +++ b/SConstruct @@ -30,33 +30,59 @@ if sys.platform == 'linux2': defines = [] warn_flags = ['-Wall', '-W'] window_system = 'X11' - platform_libs = ['m', 'z', 'GL', 'GLU', 'png', 'jpeg', 'util'] + platform_libs = ['m', 'util'] platform_libpath = [] platform_linkflags = [] extra_includes = [] - # SDL specific stuff. + # z library information + z_lib = ['z'] + z_libpath = ['/usr/lib'] + z_include = ['/usr/include'] + # png library information + png_lib = ['png'] + png_libpath = ['/usr/lib'] + png_include = ['/usr/include'] + # jpeg library information + jpeg_lib = ['jpeg'] + jpeg_libpath = ['/usr/lib'] + jpeg_include = ['/usr/include'] + # OpenGL library information + opengl_lib = ['GL', 'GLU'] + opengl_libpath = ['/usr/lib', '/usr/X11R6/lib'] + opengl_include = ['/usr/include'] + # SDL library information sdl_cenv.ParseConfig ('sdl-config --cflags') sdl_lenv.ParseConfig ('sdl-config --libs') - sdl_cdict = sdl_cenv.Dictionary() - sdl_ldict = sdl_lenv.Dictionary() - sdl_cflags = string.join(sdl_cdict['CCFLAGS']) - sdl_include = sdl_cdict['CPPPATH'][0] - link_env.Append (LIBS=sdl_ldict['LIBS']) - link_env.Append (LIBPATH=sdl_ldict['LIBPATH']) - solid_include = '#extern/solid/include' - ode_include = '#extern/ode/dist/include/ode' - # Python variables. - python_include = sysconfig.get_python_inc () - python_libpath = sysconfig.get_python_lib (0, 1) + '/config' - python_lib = 'python%d.%d' % sys.version_info[0:2] - # International stuff - if (use_international == 'true'): - defines += ['INTERNATIONAL', 'FTGL_STATIC_LIBRARY', 'WITH_FREETYPE2'] - platform_libpath += ['#../lib/linux-glibc2.2.5-i386/ftgl/lib', - '#../lib/linux-glibc2.2.5-i386/freetype/lib'] - platform_libs += ['ftgl', 'freetype'] - extra_includes += ['#../lib/linux-glibc2.2.5-i386/ftgl/include', - '#../lib/linux-glibc2.2.5-i386/freetype/include'] + sdl_cflags = sdl_cenv.Dictionary()['CCFLAGS'] + sdl_include = sdl_cenv.Dictionary()['CPPPATH'] + sdl_libpath = sdl_lenv.Dictionary()['LIBPATH'] + sdl_lib = sdl_lenv.Dictionary()['LIBS'] + # SOLID library information + solid_lib = [] # TODO + solid_libpath = [] # TODO + solid_include = ['#extern/solid/include'] + qhull_lib = [] # TODO + qhull_libpath = [] # TODO + qhull_include = ['#extern/qhull/include'] + # ODE library information + ode_lib = [] # TODO + ode_libpath = [] # TODO + ode_include = ['#extern/ode/dist/include/ode'] + # Python library information + python_lib = ['python%d.%d' % sys.version_info[0:2]] + python_libpath = [sysconfig.get_python_lib (0, 1) + '/config'] + python_include = [sysconfig.get_python_inc ()] + # International support information + ftgl_lib = ['ftgl'] + ftgl_libpath = ['#../lib/linux-glibc2.2.5-i386/ftgl/lib'] + ftgl_include = ['#../lib/linux-glibc2.2.5-i386/ftgl/include'] + freetype_lib = ['freetype'] + freetype_libpath = ['#../lib/linux-glibc2.2.5-i386/freetype/lib'] + freetype_include = ['#../lib/linux-glibc2.2.5-i386/freetype/include'] + gettext_lib = [] + gettext_libpath = [] + gettext_include = [] + i18n_defines = ['INTERNATIONAL', 'FTGL_STATIC_LIBRARY', 'WITH_FREETYPE2'] elif sys.platform == 'darwin': use_international = 'false' @@ -79,6 +105,22 @@ elif sys.platform == 'darwin': release_flags = [] debug_flags = ['-g'] window_system = 'CARBON' + # z library information + z_lib = ['z'] + z_libpath = [] + z_include = [] + # png library information + png_lib = ['png'] + png_libpath = [] + png_include = [] + # jpeg library information + jpeg_lib = ['jpeg'] + jpeg_libpath = [] + jpeg_include = [] + # OpenGL library information + opengl_lib = ['GL', 'GLU'] + opengl_libpath = [] + opengl_include = [] # SDL specific stuff. sdl_cenv.ParseConfig ('sdl-config --cflags') sdl_lenv.ParseConfig ('sdl-config --libs') @@ -91,17 +133,36 @@ elif sys.platform == 'darwin': sdl_ldict['LIBPATH'] = [darwin_precomp + '/sdl/lib'] sdl_cdict['CPPPATH'] = [darwin_precomp + '/sdl/include'] - sdl_include = sdl_cdict['CPPPATH'][0] - link_env.Append (LIBS=sdl_ldict['LIBS']) - link_env.Append (LIBPATH=sdl_ldict['LIBPATH']) - platform_libs = ['z', 'GL', 'GLU', 'png', 'jpeg', 'stdc++'] + platform_libs = ['stdc++'] extra_includes = ['/sw/include'] platform_libpath = ['/System/Library/Frameworks/OpenGL.framework/Libraries'] platform_linkflags = [] + # SOLID library information + solid_lib = [] # TODO + solid_libpath = [] # TODO + solid_include = ['#extern/solid/include'] + qhull_lib = [] # TODO + qhull_libpath = [] # TODO + qhull_include = ['#extern/qhull/include'] + # ODE library information + ode_lib = [] # TODO + ode_libpath = [] # TODO + ode_include = ['#extern/ode/dist/include/ode'] # Python variables. - python_lib = 'python%d.%d' % sys.version_info[0:2] - python_libpath = sysconfig.get_python_lib (0, 1) + '/config' - python_include = sysconfig.get_python_inc () + python_lib = ['python%d.%d' % sys.version_info[0:2]] + python_libpath = [sysconfig.get_python_lib (0, 1) + '/config'] + python_include = [sysconfig.get_python_inc ()] + # International stuff + ftgl_lib = ['ftgl'] + ftgl_libpath = [darwin_precomp + '/ftgl/lib'] + ftgl_include = [darwin_precomp + '/ftgl/include'] + freetype_lib = ['freetype'] + freetype_libpath = [darwin_precomp + '/freetype/lib'] + freetype_include = [darwin_precomp + '/freetype/include'] + gettext_lib = [] + gettext_libpath = [] + gettext_include = [] + i18n_defines = [] elif sys.platform == 'cygwin': use_international = 'false' @@ -119,26 +180,37 @@ elif sys.platform == 'cygwin': warn_flags = ['-Wall', '-Wno-char-subscripts'] platform_libs = ['png', 'jpeg', 'netapi32', 'opengl32', 'glu32', 'winmm', - 'mingw32', 'z'] + 'mingw32'] platform_libpath = ['/usr/lib/w32api', '/lib/w32api'] platform_linkflags = ['-mwindows', '-mno-cygwin', '-mconsole'] window_system = 'WIN32' extra_includes = ['/usr/include'] + # z library information + z_lib = ['z'] + z_libpath = ['/usr/lib'] + z_include = ['/usr/include'] # SDL specific stuff. sdl_cenv.ParseConfig ('sdl-config --cflags') sdl_lenv.ParseConfig ('sdl-config --libs') sdl_cdict = sdl_cenv.Dictionary() sdl_ldict = sdl_lenv.Dictionary() sdl_cflags = '-DWIN32' - sdl_include = sdl_cdict['CPPPATH'][0] - link_env.Append (LIBS=sdl_ldict['LIBS']) - link_env.Append (LIBPATH=sdl_ldict['LIBPATH']) # We need to force the Cygwin environment to use the g++ linker. link_env.Replace (CC='g++') # Python variables. python_include = sysconfig.get_python_inc () python_libpath = sysconfig.get_python_lib (0, 1) + '/config' python_lib = 'python%d.%d' % sys.version_info[0:2] + # International stuff + ftgl_lib = ['ftgl'] + ftgl_libpath = ['#../lib/windows/ftgl/lib'] + ftgl_include = ['#../lib/windows/ftgl/include'] + freetype_lib = ['freetype'] + freetype_libpath = ['#../lib/windows/freetype/lib'] + freetype_include = ['#../lib/windows/freetype/include'] + gettext_lib = [] + gettext_libpath = [] + gettext_include = [] elif sys.platform == 'win32': use_international = 'true' @@ -152,31 +224,19 @@ elif sys.platform == 'win32': debug_flags = ['/Zi'] extra_flags = ['/EHsc', '/J', '/W3', '/Gd', '/MT'] cxxflags = [] - defines = ['WIN32', '_CONSOLE', 'FTGL_STATIC_LIBRARY'] - defines += ['INTERNATIONAL', 'WITH_QUICKTIME'] - defines += ['_LIB', 'WITH_FREETYPE2', 'USE_OPENAL'] + defines = ['WIN32', '_CONSOLE'] + defines += ['WITH_QUICKTIME'] + defines += ['_LIB', 'USE_OPENAL'] warn_flags = [] - platform_libs = ['SDL', 'freetype2ST', 'ftgl_static_ST', 'gnu_gettext', - 'qtmlClient', 'odelib', 'openal_static', 'soundsystem', - 'ws2_32', 'dxguid', 'opengl32', 'libjpeg', 'glu32', - 'vfw32', 'winmm', 'libpng_st', 'libz_st', 'solid', - 'qhull', 'iconv', 'kernel32', 'user32', 'gdi32', + platform_libs = [ 'qtmlClient', 'odelib', 'openal_static', 'soundsystem', + 'ws2_32', 'dxguid', 'vfw32', 'winmm', + 'iconv', 'kernel32', 'user32', 'gdi32', 'winspool', 'comdlg32', 'advapi32', 'shell32', 'ole32', 'oleaut32', 'uuid', 'odbc32', 'odbccp32', 'libcmt', 'libc'] - platform_libpath = ['#../lib/windows/ftgl/lib', - '#../lib/windows/freetype/lib', - '#../lib/windows/gettext/lib', - '#../lib/windows/iconv/lib', - '#../lib/windows/jpeg/lib', + platform_libpath = ['#../lib/windows/iconv/lib', '#../lib/windows/QTDevWin/Libraries', - '#../lib/windows/ode/lib', - '#../lib/windows/openal/lib', - '#../lib/windows/png/lib', - '#../lib/windows/zlib/lib', - '#../lib/windows/solid/lib', - '#../lib/windows/qhull/lib', - '#../lib/windows/sdl/lib'] + '#../lib/windows/openal/lib'] platform_linkflags = [ '/SUBSYSTEM:CONSOLE', '/MACHINE:IX86', @@ -191,27 +251,60 @@ elif sys.platform == 'win32': '/NODEFAULTLIB:"libcmtd.lib"', ] window_system = 'WIN32' - extra_includes = ['#../lib/windows/zlib/include', - '#../lib/windows/jpeg/include', - '#../lib/windows/png/include'] - if use_international == 'true': - extra_includes += ['#../lib/windows/ftgl/include', - '#../lib/windows/freetype/include', - '#../lib/windows/gettext/include'] + extra_includes = [] if use_quicktime == 'true': extra_includes += ['#../lib/windows/QTDevWin/CIncludes'] if use_openal == 'true': extra_includes += ['#../lib/windows/openal/include'] - sdl_include = '#../lib/windows/sdl/include' - sdl_cflags = '' + # z library information + z_lib = ['libz_st'] + z_libpath = ['#../lib/windows/zlib/lib'] + z_include = ['#../lib/windows/zlib/include'] + # png library information + png_lib = ['libpng_st'] + png_libpath = ['#../lib/windows/png/lib'] + png_include = ['#../lib/windows/png/include'] + # jpeg library information + jpeg_lib = ['libjpeg'] + jpeg_libpath = ['#../lib/windows/jpeg/lib'] + jpeg_include = ['#../lib/windows/jpeg/include'] + # OpenGL library information + opengl_lib = ['opengl32', 'glu32'] + opengl_libpath = [] + opengl_include = ['/usr/include'] + # SDL library information + sdl_include = ['#../lib/windows/sdl/include'] + sdl_libpath = ['#../lib/windows/sdl/lib'] + sdl_lib = ['SDL'] + sdl_cflags = [] link_env.RES(['source/icons/winblender.rc']) window_system = 'WIN32' - solid_include = '#../lib/windows/solid/include' - ode_include = '#../lib/windows/ode/include' + # SOLID library information + solid_lib = ['solid'] + solid_libpath = ['#../lib/windows/solid/lib'] + solid_include = ['#../lib/windows/solid/include'] + qhull_lib = ['qhull'] + qhull_libpath = ['#../lib/windows/qhull/lib'] + qhull_include = ['#extern/qhull/include'] + # ODE library information + ode_lib = [] # TODO + ode_libpath = ['#../lib/windows/ode/lib'] + ode_include = ['#../lib/windows/ode/include'] # Python lib name python_include = '#../lib/windows/python/include/python2.2' python_libpath = '#../lib/windows/python/lib' python_lib = 'python22' + # International stuff + ftgl_lib = ['ftgl_static_ST'] + ftgl_libpath = ['#../lib/windows/ftgl/lib'] + ftgl_include = ['#../lib/windows/ftgl/include'] + freetype_lib = ['freetype2ST'] + freetype_libpath = ['#../lib/windows/freetype/lib'] + freetype_include = ['#../lib/windows/freetype/include'] + gettext_lib = ['gnu_gettext'] + gettext_libpath = ['#../lib/windows/gettext/lib'] + gettext_include = ['#../lib/windows/gettext/include'] + i18n_defines = ['INTERNATIONAL', 'FTGL_STATIC_LIBRARY', 'WITH_FREETYPE2'] elif string.find (sys.platform, 'sunos') != -1: use_international = 'true' @@ -230,34 +323,59 @@ elif string.find (sys.platform, 'sunos') != -1: env['ENV']['CXX']='g++' warn_flags = ['-Wall', '-W'] window_system = 'X11' - platform_libs = ['m', 'z', 'GL', 'GLU', 'png', 'jpeg', 'util'] + platform_libs = ['m', 'util'] platform_libpath = [] platform_linkflags = [] extra_includes = [] - # SDL specific stuff. + # z library information + z_lib = ['z'] + z_libpath = [] + z_include = [] + # png library information + png_lib = ['png'] + png_libpath = [] + png_include = [] + # jpeg library information + jpeg_lib = ['jpeg'] + jpeg_libpath = [] + jpeg_include = [] + # OpenGL library information + opengl_lib = ['GL', 'GLU'] + opengl_libpath = [] + opengl_include = [] + # SDL library information sdl_cenv.ParseConfig ('sdl-config --cflags') sdl_lenv.ParseConfig ('sdl-config --libs') - sdl_cdict = sdl_cenv.Dictionary() - sdl_ldict = sdl_lenv.Dictionary() - sdl_cflags = string.join(sdl_cdict['CCFLAGS']) - sdl_include = sdl_cdict['CPPPATH'][0] - link_env.Append (LIBS=sdl_ldict['LIBS']) - link_env.Append (LIBPATH=sdl_ldict['LIBPATH']) - solid_include = '#extern/solid/include' - ode_include = '#extern/ode/dist/include/ode' + sdl_cflags = sdl_cenv.Dictionary()['CCFLAGS'] + sdl_include = sdl_cenv.Dictionary()['CPPPATH'] + sdl_libpath = sdl_lenv.Dictionary()['LIBPATH'] + sdl_lib = sdl_lenv.Dictionary()['LIBS'] + # SOLID library information + solid_lib = [] # TODO + solid_libpath = [] # TODO + solid_include = ['#extern/solid/include'] + qhull_lib = [] # TODO + qhull_libpath = [] # TODO + qhull_include = ['#extern/qhull/include'] + # ODE library information + ode_lib = [] # TODO + ode_libpath = [] # TODO + ode_include = ['#extern/ode/dist/include/ode'] # Python variables. - python_include = sysconfig.get_python_inc () - python_libpath = sysconfig.get_python_lib (0, 1) + '/config' - python_lib = 'python%d.%d' % sys.version_info[0:2] - # International stuff - if (use_international == 'true'): - defines += ['INTERNATIONAL', 'FTGL_STATIC_LIBRARY', 'WITH_FREETYPE2'] - platform_libpath += ['#../lib/solaris-2.8-sparc/ftgl', - '#../lib/solaris-2.8-sparc/freetype/lib'] - platform_libs += ['ftgl', 'freetype'] - extra_includes += ['#../lib/solaris-2.8-sparc/ftgl/include', - '#../lib/solaris-2.8-sparc/freetype/include'] - + python_lib = ['python%d.%d' % sys.version_info[0:2]] + python_libpath = [sysconfig.get_python_lib (0, 1) + '/config'] + python_include = [sysconfig.get_python_inc ()] + # International support information + ftgl_lib = ['ftgl'] + ftgl_libpath = ['#../lib/solaris-2.8-sparc/ftgl/lib'] + ftgl_include = ['#../lib/solaris-2.8-sparc/ftgl/include'] + freetype_lib = ['freetype'] + freetype_libpath = ['#../lib/solaris-2.8-sparc/freetype/lib'] + freetype_include = ['#../lib/solaris-2.8-sparc/freetype/include'] + gettext_lib = [] + gettext_libpath = [] + gettext_include = [] + i18n_defines = ['INTERNATIONAL', 'FTGL_STATIC_LIBRARY', 'WITH_FREETYPE2'] elif string.find (sys.platform, 'irix') != -1: use_international = 'false' @@ -277,28 +395,62 @@ elif string.find (sys.platform, 'irix') != -1: debug_flags = ['-O2', '-g'] defines = [] warn_flags = ['-fullwarn', '-woff', '1001,1110,1201,1209,1355,1424,1681,3201'] - sdl_cflags = '' - sdl_include = irix_precomp + '/sdl/include/SDL' - link_env.Append (LIBS=['libSDL.a']) - link_env.Append (LIBPATH=['/usr/lib32/mips3', irix_precomp + '/sdl/lib']) - python_libpath = irix_precomp + '/python/lib/python2.2/config' - python_include = irix_precomp + '/python/include/python2.2' - python_lib = 'python2.2' - - platform_libs = ['SDL', 'movieGL', 'GLU', 'GL', 'Xmu', 'Xext', 'X11', + platform_libs = ['movieGL', 'Xmu', 'Xext', 'X11', 'c', 'm', 'dmedia', 'cl', 'audio', - 'Cio', 'png', 'jpeg', 'z', 'pthread'] - platform_libpath = [irix_precomp + '/png/lib', - irix_precomp + '/jpeg/lib', - '/usr/lib32', '/lib/freeware/lib32'] + 'Cio', 'pthread'] + platform_libpath = ['/usr/lib32', + '/lib/freeware/lib32', + '/usr/lib32/mips3'] platform_linkflags = ['-mips3', '-n32'] - extra_includes = [irix_precomp + '/jpeg/include', - irix_precomp + '/png/include', - '/usr/freeware/include', + extra_includes = ['/usr/freeware/include', '/usr/include'] - solid_include = irix_precomp + '/solid/include' - ode_include = irix_precomp + '/ode/include' - + # z library information + z_lib = ['z'] + z_libpath = [] + z_include = [] + # png library information + png_lib = ['png'] + png_libpath = [irix_precomp + '/png/lib'] + png_include = [irix_precomp + '/png/include'] + # jpeg library information + jpeg_lib = ['jpeg'] + jpeg_libpath = [irix_precomp + '/jpeg/lib'] + jpeg_include = [irix_precomp + '/jpeg/include'] + # OpenGL library information + opengl_lib = ['GL', 'GLU'] + opengl_libpath = [] + opengl_include = [] + # SDL library information + sdl_cflags = [] + sdl_include = [irix_precomp + '/sdl/include/SDL'] + sdl_libpath = [irix_precomp + '/sdl/lib'] + sdl_lib = ['SDL', 'libSDL.a'] + # SOLID library information + solid_lib = [] # TODO + solid_libpath = [] # TODO + solid_include = [irix_precomp + '/solid/include'] + qhull_lib = [] # TODO + qhull_libpath = [] # TODO + qhull_include = ['#extern/qhull/include'] + # ODE library information + ode_lib = [] # TODO + ode_libpath = [] # TODO + ode_include = [irix_precomp + '/ode/include'] + # Python library information + python_libpath = [irix_precomp + '/python/lib/python2.2/config'] + python_include = [irix_precomp + '/python/include/python2.2'] + python_lib = ['python2.2'] + # International support information + ftgl_lib = ['ftgl'] + ftgl_libpath = [irix_precomp + '/ftgl/lib'] + ftgl_include = [irix_precomp + '/ftgl/include'] + freetype_lib = ['freetype'] + freetype_libpath = [irix_precomp + '/freetype/lib'] + freetype_include = [irix_precomp + '/freetype/include'] + gettext_lib = [] + gettext_libpath = [] + gettext_include = [] + i18n_defines = ['INTERNATIONAL', 'FTGL_STATIC_LIBRARY', 'WITH_FREETYPE2'] elif string.find (sys.platform, 'hp-ux') != -1: window_system = 'X11' @@ -334,11 +486,55 @@ else: config.write ("USE_OPENAL = '%s'\n"%(use_openal)) config.write ("USE_FMOD = '%s'\n"%(use_fmod)) config.write ("USE_QUICKTIME = '%s'\n"%(use_quicktime)) + config.write ("\n# External library information.\n") + config.write ("PYTHON_INCLUDE = %s\n"%(python_include)) + config.write ("PYTHON_LIBPATH = %s\n"%(python_libpath)) + config.write ("PYTHON_LIBRARY = %s\n"%(python_lib)) + config.write ("SDL_CFLAGS = %s\n"%(sdl_cflags)) + config.write ("SDL_INCLUDE = %s\n"%(sdl_include)) + config.write ("SDL_LIBPATH = %s\n"%(sdl_libpath)) + config.write ("SDL_LIBRARY = %s\n"%(sdl_lib)) + config.write ("Z_INCLUDE = %s\n"%(z_include)) + config.write ("Z_LIBPATH = %s\n"%(z_libpath)) + config.write ("Z_LIBRARY = %s\n"%(z_lib)) + config.write ("PNG_INCLUDE = %s\n"%(png_include)) + config.write ("PNG_LIBPATH = %s\n"%(png_libpath)) + config.write ("PNG_LIBRARY = %s\n"%(png_lib)) + config.write ("JPEG_INCLUDE = %s\n"%(jpeg_include)) + config.write ("JPEG_LIBPATH = %s\n"%(jpeg_libpath)) + config.write ("JPEG_LIBRARY = %s\n"%(jpeg_lib)) + config.write ("OPENGL_INCLUDE = %s\n"%(opengl_include)) + config.write ("OPENGL_LIBPATH = %s\n"%(opengl_libpath)) + config.write ("OPENGL_LIBRARY = %s\n"%(opengl_lib)) + config.write ("\n# The following information is only necessary when you've enabled support for\n") + config.write ("# the game engine.\n") + config.write ("SOLID_INCLUDE = %s\n"%(solid_include)) + config.write ("SOLID_LIBPATH = %s\n"%(solid_libpath)) + config.write ("SOLID_LIBRARY = %s\n"%(solid_lib)) + config.write ("QHULL_INCLUDE = %s\n"%(qhull_include)) + config.write ("QHULL_LIBPATH = %s\n"%(qhull_libpath)) + config.write ("QHULL_LIBRARY = %s\n"%(qhull_lib)) + config.write ("ODE_INCLUDE = %s\n"%(ode_include)) + config.write ("ODE_LIBPATH = %s\n"%(ode_libpath)) + config.write ("ODE_LIBRARY = %s\n"%(ode_lib)) + config.write ("\n# The following information is only necessary when building with\n") + config.write ("# internationalization support.\n"); + config.write ("I18N_DEFINES = %s\n"%(i18n_defines)) + config.write ("FTGL_INCLUDE = %s\n"%(ftgl_include)) + config.write ("FTGL_LIBPATH = %s\n"%(ftgl_libpath)) + config.write ("FTGL_LIBRARY = %s\n"%(ftgl_lib)) + config.write ("FREETYPE_INCLUDE = %s\n"%(freetype_include)) + config.write ("FREETYPE_LIBPATH = %s\n"%(freetype_libpath)) + config.write ("FREETYPE_LIBRARY = %s\n"%(freetype_lib)) + config.write ("GETTEXT_INCLUDE = %s\n"%(gettext_include)) + config.write ("GETTEXT_LIBPATH = %s\n"%(gettext_libpath)) + config.write ("GETTEXT_LIBRARY = %s\n"%(gettext_lib)) config.close () #----------------------------------------------------------------------------- # Read the options from the config file and update the various necessary flags #----------------------------------------------------------------------------- +list_opts = [] user_options_env = Environment () user_options = Options (config_file) user_options.AddOptions ( @@ -366,6 +562,44 @@ user_options.AddOptions ( (EnumOption ('BUILD_BINARY', 'release', 'Select a release or debug binary.', allowed_values = ('release', 'debug'))), + ('PYTHON_INCLUDE', 'Include directory for Python header files.'), + ('PYTHON_LIBPATH', 'Library path where the Python lib is located.'), + ('PYTHON_LIBRARY', 'Python library name.'), + ('SDL_CFLAGS', 'Necessary CFLAGS when using sdl functionality.'), + ('SDL_INCLUDE', 'Include directory for SDL header files.'), + ('SDL_LIBPATH', 'Library path where the SDL library is located.'), + ('SDL_LIBRARY', 'SDL library name.'), + ('Z_INCLUDE', 'Include directory for zlib header files.'), + ('Z_LIBPATH', 'Library path where the zlib library is located.'), + ('Z_LIBRARY', 'Z library name.'), + ('PNG_INCLUDE', 'Include directory for png header files.'), + ('PNG_LIBPATH', 'Library path where the png library is located.'), + ('PNG_LIBRARY', 'png library name.'), + ('JPEG_INCLUDE', 'Include directory for jpeg header files.'), + ('JPEG_LIBPATH', 'Library path where the jpeg library is located.'), + ('JPEG_LIBRARY', 'jpeg library name.'), + ('OPENGL_INCLUDE', 'Include directory for OpenGL header files.'), + ('OPENGL_LIBPATH', 'Library path where the OpenGL libraries are located.'), + ('OPENGL_LIBRARY', 'OpenGL library names.'), + ('SOLID_INCLUDE', 'Include directory for SOLID header files.'), + ('SOLID_LIBPATH', 'Library path where the SOLID library is located.'), + ('SOLID_LIBRARY', 'SOLID library name.'), + ('QHULL_INCLUDE', 'Include directory for QHULL header files.'), + ('QHULL_LIBPATH', 'Library path where the QHULL library is located.'), + ('QHULL_LIBRARY', 'QHULL library name.'), + ('ODE_INCLUDE', 'Include directory for ODE header files.'), + ('ODE_LIBPATH', 'Library path where the ODE library is located.'), + ('ODE_LIBRARY', 'ODE library name.'), + ('I18N_DEFINES', 'Preprocessor defines needed for internationalization support.'), + ('FTGL_INCLUDE', 'Include directory for ftgl header files.'), + ('FTGL_LIBPATH', 'Library path where the ftgl library is located.'), + ('FTGL_LIBRARY', 'ftgl library name.'), + ('FREETYPE_INCLUDE', 'Include directory for freetype2 header files.'), + ('FREETYPE_LIBPATH', 'Library path where the freetype2 library is located.'), + ('FREETYPE_LIBRARY', 'Freetype2 library name.'), + ('GETTEXT_INCLUDE', 'Include directory for gettext header files.'), + ('GETTEXT_LIBPATH', 'Library path where the gettext library is located.'), + ('GETTEXT_LIBRARY', 'gettext library name.') ) user_options.Update (user_options_env) user_options_dict = user_options_env.Dictionary() @@ -391,26 +625,21 @@ else: #defines += ['_DEBUG'] specifying this makes msvc want to link to python22_d.lib?? platform_linkflags += ['/DEBUG','/PDB:blender.pdb'] +if user_options_dict['USE_INTERNATIONAL']: + defines += user_options_dict['I18N_DEFINES'] #----------------------------------------------------------------------------- # Settings to be exported to other SConscript files #----------------------------------------------------------------------------- -#cflags = extra_flags + release_flags + warn_flags -Export ('python_include') Export ('cflags') Export ('defines') Export ('cxxflags') Export ('window_system') -Export ('sdl_cflags') -Export ('sdl_include') -Export ('solid_include') -Export ('ode_include') Export ('extra_includes') Export ('platform_libs') Export ('platform_libpath') Export ('platform_linkflags') -Export ('root_build_dir') Export ('user_options_dict') BuildDir (root_build_dir+'/intern', 'intern', duplicate=0) @@ -457,11 +686,15 @@ link_env.Append (LIBS=libraries) link_env.Append (LIBPATH=libpath) link_env.Append (CPPDEFINES=defines) -if use_international == 'true': +if user_options_dict['USE_INTERNATIONAL'] == 1: link_env.Append (LIBS=['blender_FTF']) -if use_quicktime == 'true': + link_env.Append (LIBS=user_options_dict['FTGL_LIBRARY']) + link_env.Append (LIBPATH=user_options_dict['FTGL_LIBPATH']) + link_env.Append (LIBS=user_options_dict['FREETYPE_LIBRARY']) + link_env.Append (LIBPATH=user_options_dict['FREETYPE_LIBPATH']) +if user_options_dict['USE_QUICKTIME'] == 1: link_env.Append (LIBS=['blender_quicktime']) -if use_gameengine == 'true': +if user_options_dict['BUILD_GAMEENGINE'] == 1: link_env.Append (LIBS=['blender_expressions', 'KX_blenderhook', 'KX_converter', @@ -475,19 +708,37 @@ if use_gameengine == 'true': 'RAS_rasterizer', 'RAS_OpenGLRasterizer', 'SG_SceneGraph']) - if use_sumo == 'true': + if user_options_dict['USE_PHYSICS'] == 'solid': link_env.Append (LIBS=['PHY_Sumo']) - if use_ode == 'true': + link_env.Append (LIBS=user_options_dict['SOLID_LIBRARY']) + link_env.Append (LIBPATH=user_options_dict['SOLID_LIBPATH']) + link_env.Append (LIBS=user_options_dict['QHULL_LIBRARY']) + link_env.Append (LIBPATH=user_options_dict['QHULL_LIBPATH']) + else: link_env.Append (LIBS=['PHY_Ode']) - -link_env.Append (LIBS=python_lib) -link_env.Append (LIBPATH=python_libpath) + link_env.Append (LIBS=user_options_dict['ODE_LIBRARY']) + link_env.Append (LIBPATH=user_options_dict['ODE_LIBPATH']) + +link_env.Append (LIBS=user_options_dict['PYTHON_LIBRARY']) +link_env.Append (LIBPATH=user_options_dict['PYTHON_LIBPATH']) +link_env.Append (LIBS=user_options_dict['SDL_LIBRARY']) +link_env.Append (LIBPATH=user_options_dict['SDL_LIBPATH']) +link_env.Append (LIBS=user_options_dict['PNG_LIBRARY']) +link_env.Append (LIBPATH=user_options_dict['PNG_LIBPATH']) +link_env.Append (LIBS=user_options_dict['JPEG_LIBRARY']) +link_env.Append (LIBPATH=user_options_dict['JPEG_LIBPATH']) +link_env.Append (LIBS=user_options_dict['OPENGL_LIBRARY']) +link_env.Append (LIBPATH=user_options_dict['OPENGL_LIBPATH']) +link_env.Append (LIBS=user_options_dict['GETTEXT_LIBRARY']) +link_env.Append (LIBPATH=user_options_dict['GETTEXT_LIBPATH']) +link_env.Append (LIBS=user_options_dict['Z_LIBRARY']) +link_env.Append (LIBPATH=user_options_dict['Z_LIBPATH']) link_env.Append (LIBS=platform_libs) link_env.Append (LIBPATH=platform_libpath) if sys.platform == 'darwin': link_env.Append (LINKFLAGS=' -framework Carbon') link_env.Append (LINKFLAGS=' -framework AGL') - if use_quicktime == 'true': + if user_options_dict['USE_QUICKTIME'] == 1: link_env.Append (LINKFLAGS=' -framework QuickTime') else: link_env.Append (LINKFLAGS=platform_linkflags) |