Some pathnames are used both by SCons and cpp which can be a bit tricky.

Should revisit and make the distinction more explicit.

Put the Data and Sys directories under Resources in the OS X app bundle.

Construct config.h (now lower-case to avoid confusion with other Config.h
instances in the tree) in the root. One tiny step towards a read-only
and cross-buildable source tree.

Some minor bits of non-Linux Unix portability.


git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@5921 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
Soren Jorvang 2010-07-20 02:45:31 +00:00
parent c9855f2c22
commit 6813a75ab2
15 changed files with 50 additions and 60 deletions

View File

@ -17,4 +17,4 @@ libs = [
exeGUI = env['binary_dir'] + 'MemcardManager' exeGUI = env['binary_dir'] + 'MemcardManager'
env.Program(exeGUI, files, LIBS = env['LIBS'] + libs) env.Program('#' + exeGUI, files, LIBS = env['LIBS'] + libs)

View File

@ -35,6 +35,7 @@ cppDefines = [
] ]
include_paths = [ include_paths = [
'#',
'#Source/Core/Common/Src', '#Source/Core/Common/Src',
'#Source/Core/DiscIO/Src', '#Source/Core/DiscIO/Src',
'#Source/PluginSpecs', '#Source/PluginSpecs',
@ -132,25 +133,15 @@ if not sys.platform == 'win32' and not sys.platform == 'darwin':
) )
env = Environment( env = Environment(
CPPPATH = include_paths,
RPATH = [],
LIBS = [],
LIBPATH = [],
BUILDERS = builders, BUILDERS = builders,
CPPPATH = include_paths,
ENV = os.environ,
LIBPATH = [],
LIBS = [],
RPATH = [],
variables = vars, variables = vars,
) )
if sys.platform == 'win32':
env['tools'] = ['mingw']
env['ENV'] = os.environ
else:
env['CXXFLAGS'] = ['-fvisibility-inlines-hidden']
env['ENV'] = {
'PATH' : os.environ['PATH'],
'HOME' : os.environ['HOME'],
'PKG_CONFIG_PATH' : os.environ.get('PKG_CONFIG_PATH')
}
# Save the given command line options # Save the given command line options
vars.Save('args.cache', env) vars.Save('args.cache', env)
@ -200,6 +191,7 @@ if env['lint']:
compileFlags += [ ('-W' + warning) for warning in warnings ] compileFlags += [ ('-W' + warning) for warning in warnings ]
env['CCFLAGS'] = compileFlags env['CCFLAGS'] = compileFlags
env['CXXFLAGS'] = ['-fvisibility-inlines-hidden']
env['CPPDEFINES'] = cppDefines env['CPPDEFINES'] = cppDefines
# Configuration tests section # Configuration tests section
@ -231,14 +223,14 @@ if sys.platform == 'linux2' and env['install'] == 'global':
env['plugin_dir'] = env['prefix'] + 'lib/dolphin-emu/' env['plugin_dir'] = env['prefix'] + 'lib/dolphin-emu/'
env['data_dir'] = env['prefix'] + "share/dolphin-emu/" env['data_dir'] = env['prefix'] + "share/dolphin-emu/"
else: else:
env['prefix'] = os.path.join('#Binary', env['prefix'] = os.path.join('Binary',
platform.system() + '-' + platform.machine() + extra + os.sep) platform.system() + '-' + platform.machine() + extra + os.sep)
env['binary_dir'] = env['prefix'] env['binary_dir'] = env['prefix']
env['plugin_dir'] = env['prefix'] + 'plugins/' env['plugin_dir'] = env['prefix'] + 'plugins/'
env['data_dir'] = env['prefix'] env['data_dir'] = env['prefix']
if sys.platform == 'darwin': if sys.platform == 'darwin':
env['plugin_dir'] = env['prefix'] + 'Dolphin.app/Contents/PlugIns/' env['plugin_dir'] = env['prefix'] + 'Dolphin.app/Contents/PlugIns/'
env['data_dir'] = env['prefix'] + 'Dolphin.app/Contents/' env['data_dir'] = env['prefix'] + 'Dolphin.app/Contents/Resources'
shared = {} shared = {}
shared['glew'] = shared['lzo'] = shared['sdl'] = \ shared['glew'] = shared['lzo'] = shared['sdl'] = \
@ -290,9 +282,11 @@ if sys.platform == 'darwin':
env['LINKFLAGS'] += ['-FExternals/Cg'] env['LINKFLAGS'] += ['-FExternals/Cg']
shared['zlib'] = 1 shared['zlib'] = 1
if not sys.platform == 'win32' and not sys.platform == 'darwin': elif sys.platform == 'win32':
conf = env.Configure(custom_tests = tests, env['tools'] = ['mingw']
config_h="Source/Core/Common/Src/Config.h")
else:
conf = env.Configure(custom_tests = tests, config_h="#config.h")
if not conf.CheckPKGConfig('0.15.0'): if not conf.CheckPKGConfig('0.15.0'):
print "Can't find pkg-config, some tests will fail" print "Can't find pkg-config, some tests will fail"
@ -437,8 +431,8 @@ Progress(['-\r', '\\\r', '|\r', '/\r'], interval=5)
# package will later install it to the prefix as it was defined before this. # package will later install it to the prefix as it was defined before this.
if env.has_key('destdir'): if env.has_key('destdir'):
env['prefix'] = env['destdir'] + env['prefix'] env['prefix'] = env['destdir'] + env['prefix']
env['plugin_dir'] = env['destdir'] + env['plugin_dir']
env['binary_dir'] = env['destdir'] + env['binary_dir'] env['binary_dir'] = env['destdir'] + env['binary_dir']
env['plugin_dir'] = env['destdir'] + env['plugin_dir']
env['data_dir'] = env['destdir'] + env['data_dir'] env['data_dir'] = env['destdir'] + env['data_dir']
# Die on unknown variables # Die on unknown variables
@ -461,11 +455,11 @@ for subdir in dirs:
# Data install # Data install
if sys.platform == 'darwin': if sys.platform == 'darwin':
env.Install(env['data_dir'], 'Data/Sys') env.Install('#' + env['data_dir'], 'Data/Sys')
env.Install(env['data_dir'], 'Data/User') env.Install('#' + env['data_dir'], 'Data/User')
else: else:
env.InstallAs(env['data_dir'] + 'sys', 'Data/Sys') env.InstallAs('#' + env['data_dir'] + 'sys', 'Data/Sys')
env.InstallAs(env['data_dir'] + 'user', 'Data/User') env.InstallAs('#' + env['data_dir'] + 'user', 'Data/User')
env.Alias('install', env['prefix']) env.Alias('install', env['prefix'])

View File

@ -112,7 +112,7 @@ extern const char *netplay_dolphin_ver;
#endif // end DEBUG/FAST #endif // end DEBUG/FAST
#else #else
#include "Config.h" // SCons autoconfiguration defines #include "config.h" // SCons autoconfiguration defines
#endif #endif
#if defined __linux__ && HAVE_BLUEZ #if defined __linux__ && HAVE_BLUEZ

View File

@ -18,9 +18,8 @@
#ifndef _COMMON_PATHS_H_ #ifndef _COMMON_PATHS_H_
#define _COMMON_PATHS_H_ #define _COMMON_PATHS_H_
#ifdef __linux__ // Make sure we pick up USER_DIR if set in config.h
#include "Config.h" #include "Common.h"
#endif
// Library suffix/prefix // Library suffix/prefix
#ifdef _WIN32 #ifdef _WIN32
@ -29,7 +28,7 @@
#elif defined __APPLE__ #elif defined __APPLE__
#define PLUGIN_PREFIX "lib" #define PLUGIN_PREFIX "lib"
#define PLUGIN_SUFFIX ".dylib" #define PLUGIN_SUFFIX ".dylib"
#elif defined __linux__ #else
#define PLUGIN_PREFIX "lib" #define PLUGIN_PREFIX "lib"
#define PLUGIN_SUFFIX ".so" #define PLUGIN_SUFFIX ".so"
#endif #endif
@ -43,7 +42,7 @@
#define PLUGINS_DIR "Plugins" #define PLUGINS_DIR "Plugins"
#elif defined __APPLE__ #elif defined __APPLE__
#define PLUGINS_DIR "Contents/PlugIns" #define PLUGINS_DIR "Contents/PlugIns"
#elif defined __linux__ #else
#ifdef LIBS_DIR #ifdef LIBS_DIR
#define PLUGINS_DIR LIBS_DIR "dolphin-emu" #define PLUGINS_DIR LIBS_DIR "dolphin-emu"
#else #else
@ -60,9 +59,9 @@
// On OS X, USERDATA_DIR exists within the .app, but *always* reference // On OS X, USERDATA_DIR exists within the .app, but *always* reference
// the copy in Application Support instead! (Copied on first run) // the copy in Application Support instead! (Copied on first run)
// You can use the File::GetUserPath() util for this // You can use the File::GetUserPath() util for this
#define USERDATA_DIR "Contents/User" #define USERDATA_DIR "Contents/Resources/User"
#define DOLPHIN_DATA_DIR "Library/Application Support/Dolphin" #define DOLPHIN_DATA_DIR "Library/Application Support/Dolphin"
#elif defined __linux__ #else
#define USERDATA_DIR "user" #define USERDATA_DIR "user"
#ifdef USER_DIR #ifdef USER_DIR
#define DOLPHIN_DATA_DIR USER_DIR #define DOLPHIN_DATA_DIR USER_DIR
@ -75,8 +74,8 @@
#ifdef _WIN32 #ifdef _WIN32
#define SYSDATA_DIR "Sys" #define SYSDATA_DIR "Sys"
#elif defined __APPLE__ #elif defined __APPLE__
#define SYSDATA_DIR "Contents/Sys" #define SYSDATA_DIR "Contents/Resources/Sys"
#elif defined __linux__ #else
#ifdef DATA_DIR #ifdef DATA_DIR
#define SYSDATA_DIR DATA_DIR "sys" #define SYSDATA_DIR DATA_DIR "sys"
#define SHARED_USER_DIR DATA_DIR USERDATA_DIR DIR_SEP #define SHARED_USER_DIR DATA_DIR USERDATA_DIR DIR_SEP

View File

@ -422,11 +422,6 @@ bool RunCode(const ARCode &arcode)
switch (addr.type) switch (addr.type)
{ {
case 0x08:
LogInfo("Bad Normal Code type: 0x08");
return false;
break;
case 0x00: case 0x00:
if (false == NormalCode(addr, data)) if (false == NormalCode(addr, data))
return false; return false;

View File

@ -58,15 +58,15 @@ elif sys.platform == 'darwin' and not env['HAVE_WX']:
elif sys.platform == 'darwin' and env['HAVE_WX']: elif sys.platform == 'darwin' and env['HAVE_WX']:
exeGUI = env['binary_dir'] + 'Dolphin.app/Contents/MacOS/Dolphin' exeGUI = env['binary_dir'] + 'Dolphin.app/Contents/MacOS/Dolphin'
env.Install(env['binary_dir'] + 'Dolphin.app/Contents/' + env.Install('#' + env['binary_dir'] + 'Dolphin.app/Contents/' +
'Library/Frameworks/Cg.framework', 'Library/Frameworks/Cg.framework',
'#Externals/Cg/Cg.framework/Cg') '#Externals/Cg/Cg.framework/Cg')
env.Install(env['binary_dir'] + 'Dolphin.app/Contents/Resources/', env.Install('#' + env['binary_dir'] + 'Dolphin.app/Contents/Resources/',
'#Source/Core/DolphinWX/resources/Dolphin.icns') '#Source/Core/DolphinWX/resources/Dolphin.icns')
env.Plist( env.Plist(
env['binary_dir'] + 'Dolphin.app/Contents/Info.plist', '#' + env['binary_dir'] + 'Dolphin.app/Contents/Info.plist',
Value(dict( Value(dict(
CFBundleExecutable = 'Dolphin', CFBundleExecutable = 'Dolphin',
CFBundleIconFile = 'Dolphin.icns', CFBundleIconFile = 'Dolphin.icns',
@ -86,6 +86,6 @@ else:
if env['HAVE_WX']: if env['HAVE_WX']:
env.StaticLibrary(env['local_libs'] + 'memcard', memcardfiles) env.StaticLibrary(env['local_libs'] + 'memcard', memcardfiles)
env.Program(exeGUI, files, LIBS = env['LIBS'] + wxlibs + libs) env.Program('#' + exeGUI, files, LIBS = env['LIBS'] + wxlibs + libs)
else: else:
env.Program(exeNoGUI, files, LIBS = env['LIBS'] + libs) env.Program('#' + exeNoGUI, files, LIBS = env['LIBS'] + libs)

View File

@ -18,12 +18,14 @@
#ifndef XINPUTBASE_H #ifndef XINPUTBASE_H
#define XINPUTBASE_H #define XINPUTBASE_H
#include "Common.h"
#include <X11/X.h> #include <X11/X.h>
#include <X11/keysym.h> #include <X11/keysym.h>
#include "Config.h"
#if defined(HAVE_WX) && HAVE_WX #if defined(HAVE_WX) && HAVE_WX
#include <wx/wx.h> #include <wx/wx.h>
#endif #endif
namespace InputCommon namespace InputCommon
{ {
#if defined(HAVE_WX) && HAVE_WX #if defined(HAVE_WX) && HAVE_WX

View File

@ -11,4 +11,4 @@ libs = [
'common', 'common',
] ]
env.Program(env['binary_dir'] + 'dsptool', files, LIBS = libs) env.Program('#' + env['binary_dir'] + 'dsptool', files, LIBS = libs)

View File

@ -29,4 +29,4 @@ if env['HAVE_WX']:
libs = [ 'common', 'audiocommon' ] libs = [ 'common', 'audiocommon' ]
env.SharedLibrary(env['plugin_dir'] + name, files, LIBS = env['LIBS'] + libs) env.SharedLibrary('#' + env['plugin_dir'] + name, files, LIBS = env['LIBS'] + libs)

View File

@ -26,4 +26,4 @@ libs = [ 'dspcore', 'audiocommon', 'common' ]
if env['HAVE_WX']: if env['HAVE_WX']:
libs += [ 'debugger_ui_util' ] libs += [ 'debugger_ui_util' ]
env.SharedLibrary(env['plugin_dir'] + name, files, LIBS = env['LIBS'] + libs) env.SharedLibrary('#' + env['plugin_dir'] + name, files, LIBS = env['LIBS'] + libs)

View File

@ -38,4 +38,4 @@ elif sys.platform == 'win32':
elif not sys.platform == 'darwin' and env['HAVE_OPENCL']: elif not sys.platform == 'darwin' and env['HAVE_OPENCL']:
libs += [ 'OpenCL' ] libs += [ 'OpenCL' ]
env.SharedLibrary(env['plugin_dir'] + name, files, LIBS = env['LIBS'] + libs) env.SharedLibrary('#' + env['plugin_dir'] + name, files, LIBS = env['LIBS'] + libs)

View File

@ -40,4 +40,4 @@ if sys.platform == 'darwin' and not env['HAVE_WX']:
elif sys.platform == 'win32': elif sys.platform == 'win32':
files += [ 'Win32.cpp' ] files += [ 'Win32.cpp' ]
env.SharedLibrary(env['plugin_dir'] + name, files, LIBS = env['LIBS'] + libs) env.SharedLibrary('#' + env['plugin_dir'] + name, files, LIBS = env['LIBS'] + libs)

View File

@ -33,4 +33,4 @@ if env['HAVE_WIIUSE']:
libs += [ 'wiiuse' ] libs += [ 'wiiuse' ]
files += [ 'wiimote_real.cpp' ] files += [ 'wiimote_real.cpp' ]
env.SharedLibrary(env['plugin_dir'] + name, files, LIBS = env['LIBS'] + libs) env.SharedLibrary('#' + env['plugin_dir'] + name, files, LIBS = env['LIBS'] + libs)

View File

@ -31,4 +31,4 @@ if env['HAVE_WIIUSE']:
files += [ 'WiimoteReal/WiimoteReal.cpp' ] files += [ 'WiimoteReal/WiimoteReal.cpp' ]
libs += [ 'wiiuse' ] libs += [ 'wiiuse' ]
env.SharedLibrary(env['plugin_dir'] + name, files, LIBS = env['LIBS'] + libs) env.SharedLibrary('#' + env['plugin_dir'] + name, files, LIBS = env['LIBS'] + libs)

View File

@ -12,4 +12,4 @@ libs = [
'dspcore', 'common', 'dspcore', 'common',
] ]
env.Program(env['binary_dir'] + 'tester', files, LIBS = libs) env.Program('#' + env['binary_dir'] + 'tester', files, LIBS = libs)