diff options
Diffstat (limited to 'linden/indra/SConstruct')
-rw-r--r-- | linden/indra/SConstruct | 51 |
1 files changed, 20 insertions, 31 deletions
diff --git a/linden/indra/SConstruct b/linden/indra/SConstruct index 9298f7a..f1a6c89 100644 --- a/linden/indra/SConstruct +++ b/linden/indra/SConstruct | |||
@@ -25,10 +25,11 @@ | |||
25 | ################################################# | 25 | ################################################# |
26 | 26 | ||
27 | 27 | ||
28 | import os | ||
29 | import sys | ||
30 | import glob | 28 | import glob |
29 | import os | ||
30 | import random | ||
31 | import re | 31 | import re |
32 | import sys | ||
32 | 33 | ||
33 | platform = sys.platform | 34 | platform = sys.platform |
34 | if platform == 'linux2': | 35 | if platform == 'linux2': |
@@ -91,8 +92,8 @@ opts.AddOptions( | |||
91 | BoolOption('COLORGCC', 'Enabled colorgcc', True), | 92 | BoolOption('COLORGCC', 'Enabled colorgcc', True), |
92 | EnumOption('GRID', 'Client package\'s default grid', 'default', | 93 | EnumOption('GRID', 'Client package\'s default grid', 'default', |
93 | allowed_values=('default', 'aditi', 'agni', 'dmz', 'durga', 'ganga', 'shakti', 'siva', 'soma', 'uma', 'vaak')), | 94 | allowed_values=('default', 'aditi', 'agni', 'dmz', 'durga', 'ganga', 'shakti', 'siva', 'soma', 'uma', 'vaak')), |
94 | EnumOption('CHANNEL', 'Client package\'s default channel', 'default', | 95 | EnumOption('CHANNEL', 'Client package\'s default channel', 'Release', |
95 | allowed_values=('default', 'Release', 'Release Candidate', 'WindLight')), | 96 | allowed_values=('Release', 'Release Candidate', 'WindLight')), |
96 | BoolOption('ELFIO', 'Enabled enhanced backtraces with libELFIO symbol extraction support', True), | 97 | BoolOption('ELFIO', 'Enabled enhanced backtraces with libELFIO symbol extraction support', True), |
97 | BoolOption('STANDALONE', 'Build using system packages (implies OPENSOURCE)', False), | 98 | BoolOption('STANDALONE', 'Build using system packages (implies OPENSOURCE)', False), |
98 | BoolOption('OPENSOURCE', 'Build using only non-proprietary dependencies', True) # OPENSOURCE: do not edit this line | 99 | BoolOption('OPENSOURCE', 'Build using only non-proprietary dependencies', True) # OPENSOURCE: do not edit this line |
@@ -211,20 +212,7 @@ for build_target in targets: | |||
211 | """ + | 212 | """ + |
212 | '../libraries/' + system_str + '/include' ) | 213 | '../libraries/' + system_str + '/include' ) |
213 | 214 | ||
214 | if platform == 'linux' and build_target == 'client': | 215 | client_external_libs = [] |
215 | if standalone: | ||
216 | if arch == 'x86_64' and os.path.exists('/usr/lib64'): | ||
217 | client_external_libs = [File('/usr/lib64/libresolv.a')] | ||
218 | else: | ||
219 | client_external_libs = [File('/usr/lib/libresolv.a')] | ||
220 | else: | ||
221 | # Custom libresolv build which avoids a billion flavors of | ||
222 | # brokenness prevalent in common libresolvs out there. | ||
223 | client_external_libs = ['resolv'] | ||
224 | include_dirs += ['../libraries/' + system_str + '/include/llresolv8'] | ||
225 | else: | ||
226 | client_external_libs = ['resolv'] | ||
227 | |||
228 | system_link_flags = '' | 216 | system_link_flags = '' |
229 | 217 | ||
230 | if platform != 'linux' and build_target == 'client' and enable_mozlib: | 218 | if platform != 'linux' and build_target == 'client' and enable_mozlib: |
@@ -255,7 +243,7 @@ for build_target in targets: | |||
255 | ############## | 243 | ############## |
256 | 244 | ||
257 | # Generic GCC flags | 245 | # Generic GCC flags |
258 | cflags = '-g -pipe -Wall -Wno-reorder -Wno-trigraphs -Wno-sign-compare -Werror ' | 246 | cflags = '-g -pipe -Wall -Wno-reorder -Wno-trigraphs -Wno-sign-compare -Werror -fexceptions ' |
259 | cxxflags = '' | 247 | cxxflags = '' |
260 | cppflags = '-D_FORTIFY_SOURCE=2 ' | 248 | cppflags = '-D_FORTIFY_SOURCE=2 ' |
261 | if standalone: | 249 | if standalone: |
@@ -276,7 +264,7 @@ for build_target in targets: | |||
276 | cppflags += server_cppflags + ' ' | 264 | cppflags += server_cppflags + ' ' |
277 | else: | 265 | else: |
278 | # Viewer flags | 266 | # Viewer flags |
279 | cflags += '-pthread -D_REENTRANT -fno-math-errno -fexceptions -fsigned-char -fno-strict-aliasing ' | 267 | cflags += '-pthread -D_REENTRANT -fno-math-errno -fsigned-char -fno-strict-aliasing ' |
280 | cppflags += '-DLL_MESA_HEADLESS=0 -DLL_MESA=0 ' | 268 | cppflags += '-DLL_MESA_HEADLESS=0 -DLL_MESA=0 ' |
281 | try: | 269 | try: |
282 | client_cppflags = os.environ['CLIENT_CPPFLAGS'] | 270 | client_cppflags = os.environ['CLIENT_CPPFLAGS'] |
@@ -327,7 +315,7 @@ for build_target in targets: | |||
327 | cppflags += '-DLL_GSTREAMER_ENABLED=0 ' | 315 | cppflags += '-DLL_GSTREAMER_ENABLED=0 ' |
328 | else: | 316 | else: |
329 | # Mac-only flags | 317 | # Mac-only flags |
330 | cflags += '-x c++ -arch ppc -pipe -Wno-trigraphs -fpascal-strings -faltivec -fasm-blocks -g -fmessage-length=0 -mtune=G4 -Wno-deprecated-declarations -Wno-invalid-offsetof -mmacosx-version-min=10.3 -Wmost -Wno-sign-compare -Wno-switch -fconstant-cfstrings -ffor-scope -Wno-reorder ' | 318 | cflags += '-x c++ -arch ppc -pipe -Wno-trigraphs -fpascal-strings -faltivec -fasm-blocks -g -fmessage-length=0 -mtune=G4 -Wno-deprecated-declarations -Wno-invalid-offsetof -mmacosx-version-min=10.3 -Wmost -Wno-sign-compare -Wno-switch -fconstant-cfstrings -ffor-scope -Wno-reorder -fexceptions ' |
331 | cppflags += '-x c++ -DLL_DARWIN=1 -fpch-preprocess -F./newview/build/Deployment -fconstant-cfstrings -isysroot /Developer/SDKs/MacOSX10.3.9.sdk ' | 319 | cppflags += '-x c++ -DLL_DARWIN=1 -fpch-preprocess -F./newview/build/Deployment -fconstant-cfstrings -isysroot /Developer/SDKs/MacOSX10.3.9.sdk ' |
332 | 320 | ||
333 | if standalone: | 321 | if standalone: |
@@ -447,9 +435,13 @@ for build_target in targets: | |||
447 | ### Distributed build hosts ### | 435 | ### Distributed build hosts ### |
448 | 436 | ||
449 | if enable_distcc: | 437 | if enable_distcc: |
450 | hosts = 'localhost/2 station9.lindenlab.com,lzo station7.lindenlab.com,lzo station6.lindenlab.com,lzo station11.lindenlab.com,lzo station5.lindenlab.com,lzo station15.lindenlab.com,lzo station10.lindenlab.com,lzo station13.lindenlab.com,lzo station12.lindenlab.com,lzo' | 438 | hosts = [ 'localhost/2', ] |
451 | if arch == 'x86_64' or arch == 'x86_64cross': | 439 | if arch == 'i686': |
452 | hosts = 'localhost' | 440 | dead = [] |
441 | stations = [s for s in xrange(36) if s not in dead] | ||
442 | random.shuffle(stations) | ||
443 | hosts += ['station%d.lindenlab.com/2,lzo' % s for s in stations] | ||
444 | hosts = ' '.join(hosts) | ||
453 | print "Distributing to hosts: " + hosts | 445 | print "Distributing to hosts: " + hosts |
454 | env['ENV']['DISTCC_HOSTS'] = hosts | 446 | env['ENV']['DISTCC_HOSTS'] = hosts |
455 | env['ENV']['USER'] = os.environ['USER'] | 447 | env['ENV']['USER'] = os.environ['USER'] |
@@ -624,7 +616,6 @@ for build_target in targets: | |||
624 | pkgconfig('--libs-only-l', ['gtk+-2.0']).split()] | 616 | pkgconfig('--libs-only-l', ['gtk+-2.0']).split()] |
625 | else: | 617 | else: |
626 | external_libs = net_external_libs + [ 'db-4.2', 'gtk-x11-2.0' ] | 618 | external_libs = net_external_libs + [ 'db-4.2', 'gtk-x11-2.0' ] |
627 | external_libs.remove('cares') | ||
628 | internal_libs = [ 'llvfs', 'llmath', 'llcommon' ] | 619 | internal_libs = [ 'llvfs', 'llmath', 'llcommon' ] |
629 | create_executable(output_crashlogger_bin + '-globalsyms', | 620 | create_executable(output_crashlogger_bin + '-globalsyms', |
630 | 'linux_crash_logger', | 621 | 'linux_crash_logger', |
@@ -649,8 +640,8 @@ for build_target in targets: | |||
649 | external_libs += [ d[2:] for d in | 640 | external_libs += [ d[2:] for d in |
650 | pkgconfig('--libs-only-l').split() ] | 641 | pkgconfig('--libs-only-l').split() ] |
651 | else: | 642 | else: |
652 | external_libs += [ 'freetype', 'SDL', 'ogg', 'vorbisenc', | 643 | external_libs += [ 'freetype', 'SDL', 'vorbisenc', |
653 | 'vorbisfile', 'vorbis', 'db-4.2' ] | 644 | 'vorbisfile', 'vorbis', 'ogg', 'db-4.2' ] |
654 | 645 | ||
655 | external_libs += [ 'jpeg', 'openjpeg', 'png12', 'GL', 'GLU' ] | 646 | external_libs += [ 'jpeg', 'openjpeg', 'png12', 'GL', 'GLU' ] |
656 | 647 | ||
@@ -660,8 +651,6 @@ for build_target in targets: | |||
660 | if buildtype == 'debug': | 651 | if buildtype == 'debug': |
661 | external_libs += ['tcmalloc', 'stacktrace'] | 652 | external_libs += ['tcmalloc', 'stacktrace'] |
662 | 653 | ||
663 | external_libs.remove('cares') | ||
664 | |||
665 | internal_libs = [ 'lscript', 'llwindow', 'llrender', 'llprimitive', | 654 | internal_libs = [ 'lscript', 'llwindow', 'llrender', 'llprimitive', |
666 | 'llmedia', 'llinventory', | 655 | 'llmedia', 'llinventory', |
667 | 'llimage', 'llimagej2coj', | 656 | 'llimage', 'llimagej2coj', |
@@ -684,7 +673,7 @@ for build_target in targets: | |||
684 | product_name = 'SecondLife_' + arch + '_' + "_".join(version_viewer.split(".")) | 673 | product_name = 'SecondLife_' + arch + '_' + "_".join(version_viewer.split(".")) |
685 | if grid not in ['default', 'agni']: | 674 | if grid not in ['default', 'agni']: |
686 | product_name += "_" + grid.upper() | 675 | product_name += "_" + grid.upper() |
687 | if channel not in ['default', 'Release']: | 676 | if channel not in ['Release']: |
688 | product_name += "_" + "".join((channel.upper()).split()) | 677 | product_name += "_" + "".join((channel.upper()).split()) |
689 | package_name = product_name + '.tar.bz2' | 678 | package_name = product_name + '.tar.bz2' |
690 | complete_channel = 'Second Life ' + channel | 679 | complete_channel = 'Second Life ' + channel |
@@ -701,7 +690,7 @@ for build_target in targets: | |||
701 | elif build_target == 'server': | 690 | elif build_target == 'server': |
702 | create_static_module('lldatabase') | 691 | create_static_module('lldatabase') |
703 | create_static_module('llscene') | 692 | create_static_module('llscene') |
704 | create_static_module('llhavok', '-fno-exceptions -fno-rtti') | 693 | create_static_module('llhavok', '-fno-rtti') |
705 | create_static_module_from_dir('llkdu', 'llkdustatic') | 694 | create_static_module_from_dir('llkdu', 'llkdustatic') |
706 | 695 | ||
707 | 696 | ||