More SConstruct cleanup.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@5962 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
parent
53f5bc682d
commit
d906dcee27
195
SConstruct
195
SConstruct
|
@ -54,22 +54,20 @@ if not sys.platform == 'win32' and not sys.platform == 'darwin':
|
||||||
('CXX', 'The C++ compiler', 'g++'),
|
('CXX', 'The C++ compiler', 'g++'),
|
||||||
)
|
)
|
||||||
|
|
||||||
# Save the given command line options
|
|
||||||
env = Environment(ENV = os.environ, variables = vars)
|
env = Environment(ENV = os.environ, variables = vars)
|
||||||
vars.Save('args.cache', env)
|
Export('env')
|
||||||
|
|
||||||
# Verbose compile
|
# Generate help
|
||||||
if not env['verbose']:
|
Help(vars.GenerateHelpText(env))
|
||||||
env['CCCOMSTR'] = "Compiling $TARGET"
|
|
||||||
env['CXXCOMSTR'] = "Compiling $TARGET"
|
# Die on unknown variables
|
||||||
env['ARCOMSTR'] = "Archiving $TARGET"
|
unknown = vars.UnknownVariables()
|
||||||
env['LINKCOMSTR'] = "Linking $TARGET"
|
if unknown:
|
||||||
env['ASCOMSTR'] = "Assembling $TARGET"
|
print "Unknown variables:", unknown.keys()
|
||||||
env['ASPPCOMSTR'] = "Assembling $TARGET"
|
Exit(1)
|
||||||
env['SHCCCOMSTR'] = "Compiling shared $TARGET"
|
|
||||||
env['SHCXXCOMSTR'] = "Compiling shared $TARGET"
|
# Save the given command line options
|
||||||
env['SHLINKCOMSTR'] = "Linking shared $TARGET"
|
vars.Save('args.cache', env)
|
||||||
env['RANLIBCOMSTR'] = "Indexing $TARGET"
|
|
||||||
|
|
||||||
cppDefines = [
|
cppDefines = [
|
||||||
( '_FILE_OFFSET_BITS', 64),
|
( '_FILE_OFFSET_BITS', 64),
|
||||||
|
@ -85,7 +83,7 @@ ccFlags = [
|
||||||
'-Wwrite-strings',
|
'-Wwrite-strings',
|
||||||
'-fPIC',
|
'-fPIC',
|
||||||
'-fno-exceptions',
|
'-fno-exceptions',
|
||||||
'-fno-strict-aliasing',
|
'-fno-strict-aliasing',
|
||||||
'-fvisibility=hidden',
|
'-fvisibility=hidden',
|
||||||
'-msse2',
|
'-msse2',
|
||||||
]
|
]
|
||||||
|
@ -96,26 +94,46 @@ if env['CCVERSION'] >= '4.3.0': ccFlags += [
|
||||||
]
|
]
|
||||||
|
|
||||||
# Build flavor
|
# Build flavor
|
||||||
flavour = env['flavor']
|
if env['flavor'] == 'debug':
|
||||||
if flavour == 'debug':
|
|
||||||
ccFlags.append('-ggdb')
|
ccFlags.append('-ggdb')
|
||||||
cppDefines.append('_DEBUG') #enables LOGGING
|
cppDefines.append('_DEBUG') #enables LOGGING
|
||||||
# FIXME: this disable wx debugging how do we make it work?
|
# FIXME: this disable wx debugging how do we make it work?
|
||||||
cppDefines.append('NDEBUG')
|
cppDefines.append('NDEBUG')
|
||||||
elif flavour == 'devel':
|
elif env['flavor'] == 'devel':
|
||||||
ccFlags.append('-ggdb')
|
ccFlags.append('-ggdb')
|
||||||
elif flavour == 'fastlog':
|
elif env['flavor'] == 'fastlog':
|
||||||
ccFlags.append('-O3')
|
ccFlags.append('-O3')
|
||||||
cppDefines.append('DEBUGFAST')
|
cppDefines.append('DEBUGFAST')
|
||||||
elif flavour == 'prof':
|
elif env['flavor'] == 'prof':
|
||||||
ccFlags.append('-O3')
|
ccFlags.append('-O3')
|
||||||
ccFlags.append('-ggdb')
|
ccFlags.append('-ggdb')
|
||||||
elif flavour == 'release':
|
elif env['flavor'] == 'release':
|
||||||
ccFlags.append('-O3')
|
ccFlags.append('-O3')
|
||||||
ccFlags.append('-fomit-frame-pointer');
|
ccFlags.append('-fomit-frame-pointer');
|
||||||
|
|
||||||
|
if env['flavor'] == 'debug':
|
||||||
|
extra = '-debug'
|
||||||
|
elif env['flavor'] == 'prof':
|
||||||
|
extra = '-prof'
|
||||||
|
else:
|
||||||
|
extra = ''
|
||||||
|
|
||||||
if env['lint']:
|
if env['lint']:
|
||||||
ccFlags.append('-Werror')
|
ccFlags.append('-Werror')
|
||||||
|
|
||||||
|
# Verbose compile
|
||||||
|
if not env['verbose']:
|
||||||
|
env['CCCOMSTR'] = "Compiling $TARGET"
|
||||||
|
env['CXXCOMSTR'] = "Compiling $TARGET"
|
||||||
|
env['ARCOMSTR'] = "Archiving $TARGET"
|
||||||
|
env['LINKCOMSTR'] = "Linking $TARGET"
|
||||||
|
env['ASCOMSTR'] = "Assembling $TARGET"
|
||||||
|
env['ASPPCOMSTR'] = "Assembling $TARGET"
|
||||||
|
env['SHCCCOMSTR'] = "Compiling shared $TARGET"
|
||||||
|
env['SHCXXCOMSTR'] = "Compiling shared $TARGET"
|
||||||
|
env['SHLINKCOMSTR'] = "Linking shared $TARGET"
|
||||||
|
env['RANLIBCOMSTR'] = "Indexing $TARGET"
|
||||||
|
|
||||||
dirs = [
|
dirs = [
|
||||||
'Externals/Bochs_disasm',
|
'Externals/Bochs_disasm',
|
||||||
'Externals/Lua',
|
'Externals/Lua',
|
||||||
|
@ -135,44 +153,23 @@ dirs = [
|
||||||
'Source/DSPTool/Src',
|
'Source/DSPTool/Src',
|
||||||
'Source/Plugins/Plugin_DSP_HLE/Src',
|
'Source/Plugins/Plugin_DSP_HLE/Src',
|
||||||
'Source/Plugins/Plugin_DSP_LLE/Src',
|
'Source/Plugins/Plugin_DSP_LLE/Src',
|
||||||
|
'Source/Plugins/Plugin_VideoOGL/Src',
|
||||||
'Source/Plugins/Plugin_VideoSoftware/Src',
|
'Source/Plugins/Plugin_VideoSoftware/Src',
|
||||||
'Source/Plugins/Plugin_Wiimote/Src',
|
'Source/Plugins/Plugin_Wiimote/Src',
|
||||||
'Source/Plugins/Plugin_WiimoteNew/Src',
|
'Source/Plugins/Plugin_WiimoteNew/Src',
|
||||||
'Source/UnitTests',
|
'Source/UnitTests',
|
||||||
]
|
]
|
||||||
|
|
||||||
if sys.platform == 'darwin' or sys.platform == 'linux2':
|
|
||||||
dirs += ['Source/Plugins/Plugin_VideoOGL/Src']
|
|
||||||
|
|
||||||
# Object files
|
# Object files
|
||||||
env['build_dir'] = os.path.join('Build',
|
env['build_dir'] = 'Build' + os.sep + platform.system() + \
|
||||||
platform.system() + '-' + platform.machine() + '-' + env['flavor'])
|
'-' + platform.machine() + '-' + env['flavor']
|
||||||
|
|
||||||
# Static libs go here
|
# Static libs go here
|
||||||
env['local_libs'] = '#' + env['build_dir'] + os.sep + 'libs' + os.sep
|
env['local_libs'] = '#' + env['build_dir'] + os.sep + 'libs' + os.sep
|
||||||
|
|
||||||
# Install paths
|
# Install path
|
||||||
extra=''
|
env['prefix'] = 'Binary' + os.sep + platform.system() + \
|
||||||
if flavour == 'debug':
|
'-' + platform.machine() + extra + os.sep
|
||||||
extra = '-debug'
|
|
||||||
elif flavour == 'prof':
|
|
||||||
extra = '-prof'
|
|
||||||
|
|
||||||
# Set up the install locations
|
|
||||||
if sys.platform == 'linux2' and env['install'] == 'global':
|
|
||||||
env['prefix'] = os.path.join(env['prefix'] + os.sep)
|
|
||||||
env['binary_dir'] = env['prefix'] + 'bin/'
|
|
||||||
env['plugin_dir'] = env['prefix'] + 'lib/dolphin-emu/'
|
|
||||||
env['data_dir'] = env['prefix'] + "share/dolphin-emu/"
|
|
||||||
else:
|
|
||||||
env['prefix'] = os.path.join('Binary',
|
|
||||||
platform.system() + '-' + platform.machine() + extra + os.sep)
|
|
||||||
env['binary_dir'] = '#' + env['prefix']
|
|
||||||
env['plugin_dir'] = '#' + env['prefix'] + 'plugins/'
|
|
||||||
env['data_dir'] = '#' + env['prefix']
|
|
||||||
if sys.platform == 'darwin':
|
|
||||||
env['plugin_dir'] = '#' + env['prefix'] + 'Dolphin.app/Contents/PlugIns/'
|
|
||||||
env['data_dir'] = '#' + env['prefix'] + 'Dolphin.app/Contents/Resources'
|
|
||||||
|
|
||||||
# Configuration tests section
|
# Configuration tests section
|
||||||
tests = {'CheckWXConfig' : wxconfig.CheckWXConfig,
|
tests = {'CheckWXConfig' : wxconfig.CheckWXConfig,
|
||||||
|
@ -182,6 +179,10 @@ tests = {'CheckWXConfig' : wxconfig.CheckWXConfig,
|
||||||
'CheckPortaudio' : utils.CheckPortaudio,
|
'CheckPortaudio' : utils.CheckPortaudio,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
rev = utils.GenerateRevFile(env['flavor'],
|
||||||
|
"Source/Core/Common/Src/svnrev_template.h",
|
||||||
|
"Source/Core/Common/Src/svnrev.h")
|
||||||
|
|
||||||
shared = {}
|
shared = {}
|
||||||
shared['glew'] = shared['lzo'] = shared['sdl'] = \
|
shared['glew'] = shared['lzo'] = shared['sdl'] = \
|
||||||
shared['soil'] = shared['sfml'] = shared['zlib'] = 0
|
shared['soil'] = shared['sfml'] = shared['zlib'] = 0
|
||||||
|
@ -232,6 +233,16 @@ if sys.platform == 'darwin':
|
||||||
env['FRAMEWORKS'] += ['Cg']
|
env['FRAMEWORKS'] += ['Cg']
|
||||||
env['LINKFLAGS'] += ['-FExternals/Cg']
|
env['LINKFLAGS'] += ['-FExternals/Cg']
|
||||||
shared['zlib'] = 1
|
shared['zlib'] = 1
|
||||||
|
env['data_dir'] = '#' + env['prefix'] + 'Dolphin.app/Contents/Resources'
|
||||||
|
env['plugin_dir'] = '#' + env['prefix'] + 'Dolphin.app/Contents/PlugIns/'
|
||||||
|
env.Install(env['data_dir'], 'Data/Sys')
|
||||||
|
env.Install(env['data_dir'], 'Data/User')
|
||||||
|
if env['bundle']:
|
||||||
|
app = env['prefix'] + 'Dolphin.app'
|
||||||
|
dmg = env['prefix'] + 'Dolphin-r' + rev + '.dmg'
|
||||||
|
env.Command(dmg, app, 'rm -f ' + dmg +
|
||||||
|
' && hdiutil create -srcfolder ' + app + ' -format UDBZ ' + dmg +
|
||||||
|
' && hdiutil internet-enable -yes ' + dmg)
|
||||||
|
|
||||||
elif sys.platform == 'win32':
|
elif sys.platform == 'win32':
|
||||||
env['tools'] = ['mingw']
|
env['tools'] = ['mingw']
|
||||||
|
@ -328,7 +339,7 @@ else:
|
||||||
env['LINKFLAGS']='-fprofile-use'
|
env['LINKFLAGS']='-fprofile-use'
|
||||||
|
|
||||||
# Profiling
|
# Profiling
|
||||||
if (flavour == 'prof'):
|
if (env['flavor'] == 'prof'):
|
||||||
proflibs = [ '/usr/lib/oprofile', '/usr/local/lib/oprofile' ]
|
proflibs = [ '/usr/lib/oprofile', '/usr/local/lib/oprofile' ]
|
||||||
env['LIBPATH'].append(proflibs)
|
env['LIBPATH'].append(proflibs)
|
||||||
env['RPATH'].append(proflibs)
|
env['RPATH'].append(proflibs)
|
||||||
|
@ -337,14 +348,38 @@ else:
|
||||||
else:
|
else:
|
||||||
print "Can't build prof without oprofile, disabling"
|
print "Can't build prof without oprofile, disabling"
|
||||||
|
|
||||||
conf.Define('USER_DIR', "\"" + env['userdir'] + "\"")
|
if env['install'] == 'global':
|
||||||
if (env['install'] == 'global'):
|
env['binary_dir'] = env['prefix'] + '/bin/'
|
||||||
|
env['data_dir'] = env['prefix'] + "/share/dolphin-emu/"
|
||||||
|
env['plugin_dir'] = env['prefix'] + '/lib/dolphin-emu/'
|
||||||
conf.Define('DATA_DIR', "\"" + env['data_dir'] + "\"")
|
conf.Define('DATA_DIR', "\"" + env['data_dir'] + "\"")
|
||||||
conf.Define('LIBS_DIR', "\"" + env['prefix'] + 'lib/' + "\"")
|
conf.Define('LIBS_DIR', "\"" + env['prefix'] + 'lib/' + "\"")
|
||||||
|
else:
|
||||||
|
env['binary_dir'] = '#' + env['prefix']
|
||||||
|
env['data_dir'] = '#' + env['prefix']
|
||||||
|
env['plugin_dir'] = '#' + env['prefix'] + 'plugins/'
|
||||||
|
|
||||||
|
conf.Define('USER_DIR', "\"" + env['userdir'] + "\"")
|
||||||
|
|
||||||
# After all configuration tests are done
|
# After all configuration tests are done
|
||||||
conf.Finish()
|
conf.Finish()
|
||||||
|
|
||||||
|
# Setup destdir for package building
|
||||||
|
# Warning: The program will not run from this location. It is assumed the
|
||||||
|
# package will later install it to the prefix as it was defined before this.
|
||||||
|
if env.has_key('destdir'):
|
||||||
|
env['binary_dir'] = env['destdir'] + env['binary_dir']
|
||||||
|
env['data_dir'] = env['destdir'] + env['data_dir']
|
||||||
|
env['plugin_dir'] = env['destdir'] + env['plugin_dir']
|
||||||
|
env['prefix'] = env['destdir'] + env['prefix']
|
||||||
|
if env['bundle']:
|
||||||
|
env.Tar('dolphin-' + rev + '.tar.bz2', env['prefix'],
|
||||||
|
TARFLAGS='-cj', TARCOMSTR='Creating release tarball')
|
||||||
|
|
||||||
|
# Data install
|
||||||
|
env.InstallAs(env['data_dir'] + 'sys', 'Data/Sys')
|
||||||
|
env.InstallAs(env['data_dir'] + 'user', 'Data/User')
|
||||||
|
|
||||||
# Local (static) libraries must be first in the search path for the build in
|
# Local (static) libraries must be first in the search path for the build in
|
||||||
# order that they can override system libraries, but they must not be found
|
# order that they can override system libraries, but they must not be found
|
||||||
# during autoconfiguration as they will then be detected as system libraries.
|
# during autoconfiguration as they will then be detected as system libraries.
|
||||||
|
@ -370,61 +405,11 @@ if not shared['zlib']:
|
||||||
env['CPPPATH'] += ['#Externals/zlib']
|
env['CPPPATH'] += ['#Externals/zlib']
|
||||||
dirs += ['Externals/zlib']
|
dirs += ['Externals/zlib']
|
||||||
|
|
||||||
rev = utils.GenerateRevFile(env['flavor'],
|
|
||||||
"Source/Core/Common/Src/svnrev_template.h",
|
|
||||||
"Source/Core/Common/Src/svnrev.h")
|
|
||||||
|
|
||||||
# Print a nice progress indication when not compiling
|
|
||||||
Progress(['-\r', '\\\r', '|\r', '/\r'], interval=5)
|
|
||||||
|
|
||||||
# Setup destdir for package building
|
|
||||||
# Warning: The program will not run from this location. It is assumed the
|
|
||||||
# package will later install it to the prefix as it was defined before this.
|
|
||||||
if env.has_key('destdir'):
|
|
||||||
env['prefix'] = env['destdir'] + env['prefix']
|
|
||||||
env['binary_dir'] = env['destdir'] + env['binary_dir']
|
|
||||||
env['plugin_dir'] = env['destdir'] + env['plugin_dir']
|
|
||||||
env['data_dir'] = env['destdir'] + env['data_dir']
|
|
||||||
|
|
||||||
# Die on unknown variables
|
|
||||||
unknown = vars.UnknownVariables()
|
|
||||||
if unknown:
|
|
||||||
print "Unknown variables:", unknown.keys()
|
|
||||||
Exit(1)
|
|
||||||
|
|
||||||
# Generate help
|
|
||||||
Help(vars.GenerateHelpText(env))
|
|
||||||
|
|
||||||
Export('env')
|
|
||||||
|
|
||||||
for subdir in dirs:
|
for subdir in dirs:
|
||||||
SConscript(
|
SConscript(subdir + os.sep + 'SConscript',
|
||||||
subdir + os.sep + 'SConscript',
|
variant_dir = env['build_dir'] + os.sep + subdir, duplicate = 0)
|
||||||
variant_dir = env['build_dir'] + os.sep + subdir,
|
|
||||||
duplicate=0
|
|
||||||
)
|
|
||||||
|
|
||||||
# Data install
|
|
||||||
if sys.platform == 'darwin':
|
|
||||||
env.Install(env['data_dir'], 'Data/Sys')
|
|
||||||
env.Install(env['data_dir'], 'Data/User')
|
|
||||||
else:
|
|
||||||
env.InstallAs(env['data_dir'] + 'sys', 'Data/Sys')
|
|
||||||
env.InstallAs(env['data_dir'] + 'user', 'Data/User')
|
|
||||||
|
|
||||||
env.Alias('install', env['prefix'])
|
env.Alias('install', env['prefix'])
|
||||||
#env.Depends(env['prefix'], env['build_dir'])
|
|
||||||
|
|
||||||
if env['bundle']:
|
# Print a nice progress indication when not compiling
|
||||||
if sys.platform == 'linux2':
|
Progress(['-\r', '\\\r', '|\r', '/\r'], interval = 5)
|
||||||
# Make tar ball (TODO put inside normal dir)
|
|
||||||
tar_env = env.Clone()
|
|
||||||
tarball = tar_env.Tar('dolphin-' + rev + '.tar.bz2', env['prefix'])
|
|
||||||
tar_env.Append(TARFLAGS='-j', TARCOMSTR="Creating release tarball")
|
|
||||||
env.Clean(all, tarball)
|
|
||||||
elif sys.platform == 'darwin':
|
|
||||||
app = env['prefix'] + 'Dolphin.app'
|
|
||||||
dmg = env['prefix'] + 'Dolphin-r' + rev + '.dmg'
|
|
||||||
env.Command(dmg, app, 'rm -f ' + dmg +
|
|
||||||
' && hdiutil create -srcfolder ' + app + ' -format UDBZ ' + dmg +
|
|
||||||
' && hdiutil internet-enable -yes ' + dmg)
|
|
||||||
|
|
|
@ -55,12 +55,12 @@ if sys.platform == 'win32':
|
||||||
files += [ "stdafx.cpp" ]
|
files += [ "stdafx.cpp" ]
|
||||||
elif sys.platform == 'darwin' and not env['HAVE_WX']:
|
elif sys.platform == 'darwin' and not env['HAVE_WX']:
|
||||||
files += [ 'cocoaApp.m' ]
|
files += [ 'cocoaApp.m' ]
|
||||||
exeNoGUI = env['binary_dir'] + 'DolphinNoGUI'
|
exeNoGUI = '#' + env['prefix'] + 'DolphinNoGUI'
|
||||||
elif sys.platform == 'darwin' and env['HAVE_WX']:
|
elif sys.platform == 'darwin' and env['HAVE_WX']:
|
||||||
exeGUI = 'Dolphin'
|
exeGUI = 'Dolphin'
|
||||||
exeGUIdist = env['binary_dir'] + 'Dolphin.app/Contents/MacOS/Dolphin'
|
exeGUIdist = '#' + env['prefix'] + 'Dolphin.app/Contents/MacOS/Dolphin'
|
||||||
|
|
||||||
env.Install(env['binary_dir'] + 'Dolphin.app/Contents/' +
|
env.Install('#' + env['prefix'] + 'Dolphin.app/Contents/' +
|
||||||
'Library/Frameworks/Cg.framework',
|
'Library/Frameworks/Cg.framework',
|
||||||
'#Externals/Cg/Cg.framework/Cg')
|
'#Externals/Cg/Cg.framework/Cg')
|
||||||
|
|
||||||
|
@ -72,8 +72,8 @@ elif sys.platform == 'darwin' and env['HAVE_WX']:
|
||||||
for srcNode in source:
|
for srcNode in source:
|
||||||
writePlist(srcNode.value, str(target[0]))
|
writePlist(srcNode.value, str(target[0]))
|
||||||
env.Append(BUILDERS = {'Plist' : Builder(action = createPlist)})
|
env.Append(BUILDERS = {'Plist' : Builder(action = createPlist)})
|
||||||
env.Plist(env['binary_dir'] + 'Dolphin.app/Contents/Info.plist', Value(
|
env.Plist('#' + env['prefix'] + 'Dolphin.app/Contents/Info.plist',
|
||||||
dict(
|
Value(dict(
|
||||||
CFBundleExecutable = 'Dolphin',
|
CFBundleExecutable = 'Dolphin',
|
||||||
CFBundleIconFile = 'Dolphin.icns',
|
CFBundleIconFile = 'Dolphin.icns',
|
||||||
CFBundleIdentifier = 'com.dolphin-emu.dolphin',
|
CFBundleIdentifier = 'com.dolphin-emu.dolphin',
|
||||||
|
|
Loading…
Reference in New Issue