X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=build_common%2FSConscript;h=c5651f6c4f4b42d0301bb08dc4979acdf74976c2;hb=129440510176a0badf06174f1787c63a6c74b4d6;hp=02cbed3a5ae0656e3d5e81f43d98469f34efebc2;hpb=2685312e2d73ec95cd59641aa8eef809ce938e5e;p=platform%2Fupstream%2Fiotivity.git diff --git a/build_common/SConscript b/build_common/SConscript index 02cbed3..c5651f6 100644 --- a/build_common/SConscript +++ b/build_common/SConscript @@ -40,7 +40,11 @@ if target_os not in host_target_map[host]: print "\nError: Unknown target os: %s (Allow values: %s)\n" % (target_os, host_target_map[host]) Exit(1) -default_arch = platform.machine() +if target_os == 'android': + default_arch = 'x86' +else: + default_arch = platform.machine() + if default_arch not in os_arch_map[target_os]: default_arch = os_arch_map[target_os][0].lower() @@ -50,11 +54,14 @@ target_arch = ARGUMENTS.get('TARGET_ARCH', default_arch) # target arch # set to 'no', 'false' or 0 for only compilation require_upload = ARGUMENTS.get('UPLOAD', False) +# Get the device name. This name can be used as network display name wherever possible +device_name = ARGUMENTS.get('DEVICE_NAME', "OIC-DEVICE") + if ARGUMENTS.get('TEST'): logging_default = False else: release_mode = False - if ARGUMENTS.get('RELEASE', True) in ['y', 'yes', 'true', 't', '1', 'on', 'all']: + if ARGUMENTS.get('RELEASE', True) in ['y', 'yes', 'true', 't', '1', 'on', 'all', True]: release_mode = True logging_default = (release_mode == False) @@ -70,17 +77,49 @@ help_vars.Add(BoolVariable('VERBOSE', 'Show compilation', False)) help_vars.Add(BoolVariable('RELEASE', 'Build for release?', True)) # set to 'no', 'false' or 0 for debug help_vars.Add(EnumVariable('TARGET_OS', 'Target platform', host, host_target_map[host])) + +help_vars.Add(BoolVariable('WITH_RA', 'Build with Remote Access module', False)) +help_vars.Add(BoolVariable('WITH_TCP', 'Build with TCP adapter', False)) +help_vars.Add(EnumVariable('WITH_RD', 'Build including Resource Directory', '0', allowed_values=('0', '1'))) +help_vars.Add(BoolVariable('WITH_CLOUD', 'Build including Cloud client sample', False)) + +help_vars.Add(BoolVariable('SIMULATOR', 'Build with simulator module', False)) + +help_vars.Add(BoolVariable('WITH_RA_IBB', 'Build with Remote Access module(workssys)', False)) + + if target_os in targets_disallow_multitransport: - help_vars.Add(ListVariable('TARGET_TRANSPORT', 'Target transport', 'IP', ['BT', 'BLE', 'IP'])) + help_vars.Add(ListVariable('TARGET_TRANSPORT', 'Target transport', 'IP', ['BT', 'BLE', 'IP', 'NFC'])) else: - help_vars.Add(ListVariable('TARGET_TRANSPORT', 'Target transport', 'ALL', ['ALL', 'BT', 'BLE', 'IP'])) + help_vars.Add(ListVariable('TARGET_TRANSPORT', 'Target transport', 'ALL', ['ALL', 'BT', 'BLE', 'IP', 'NFC'])) help_vars.Add(EnumVariable('TARGET_ARCH', 'Target architecture', default_arch, os_arch_map[target_os])) help_vars.Add(EnumVariable('SECURED', 'Build with DTLS', '0', allowed_values=('0', '1'))) +help_vars.Add(EnumVariable('DTLS_WITH_X509', 'DTLS with X.509 support', '0', allowed_values=('0', '1'))) help_vars.Add(EnumVariable('TEST', 'Run unit tests', '0', allowed_values=('0', '1'))) help_vars.Add(BoolVariable('LOGGING', 'Enable stack logging', logging_default)) help_vars.Add(BoolVariable('UPLOAD', 'Upload binary ? (For Arduino)', require_upload)) +help_vars.Add(EnumVariable('ROUTING', 'Enable routing', 'EP', allowed_values=('GW', 'EP'))) help_vars.Add(EnumVariable('BUILD_SAMPLE', 'Build with sample', 'ON', allowed_values=('ON', 'OFF'))) +help_vars.AddVariables(('DEVICE_NAME', 'Network display name for device (For Arduino)', device_name, None, None),) +help_vars.Add(PathVariable('ANDROID_NDK', 'Android NDK path', None, PathVariable.PathAccept)) +help_vars.Add(PathVariable('ANDROID_HOME', 'Android SDK path', None, PathVariable.PathAccept)) +help_vars.Add(PathVariable('ANDROID_GRADLE', 'Gradle binary file', None, PathVariable.PathIsFile)) +#ES_TARGET_ENROLLEE is for specifying what is our target enrollee (Arduino or rest of platforms which support Multicast) +help_vars.Add(EnumVariable('ES_TARGET_ENROLLEE', 'Target Enrollee', 'arduino', allowed_values=('arduino', 'tizen', 'linux'))) +#ES_ROLE is for specifying the role (Enrollee or Mediator) for which scons is being executed +help_vars.Add(EnumVariable('ES_ROLE', 'Target build mode', 'mediator', allowed_values=('mediator', 'enrollee'))) +#ES_SOFT_MODE is for specifying MODE (Mode 1 : Enrollee with Soft AP or Mode 2 : Mediator with Soft AP) +help_vars.Add(EnumVariable('ES_SOFTAP_MODE', 'Target build mode', 'ENROLLEE_SOFTAP', allowed_values=('ENROLLEE_SOFTAP', 'MEDIATOR_SOFTAP'))) + +AddOption('--prefix', + dest='prefix', + type='string', + nargs=1, + action='store', + metavar='DIR', + help='installation prefix') + ###################################################################### # Platform(build target) specific options: SDK/NDK & toolchain ###################################################################### @@ -95,11 +134,14 @@ if target_os in targets_support_cc: if target_os in ['android', 'arduino']: # Android/Arduino always uses GNU compiler regardless of the host env = Environment(variables = help_vars, - tools = ['gnulink', 'gcc', 'g++', 'ar', 'as'] + tools = ['gnulink', 'gcc', 'g++', 'ar', 'as', 'textfile'] ) else: - env = Environment(variables = help_vars, TARGET_ARCH = target_arch, TARGET_OS = target_os) - + env = Environment(variables = help_vars, tools = ['default', 'textfile'], + TARGET_ARCH = target_arch, TARGET_OS = target_os, + PREFIX = GetOption('prefix'), + LIB_INSTALL_DIR = ARGUMENTS.get('LIB_INSTALL_DIR') #for 64bit build + ) Help(help_vars.GenerateHelpText(env)) tc_set_msg = ''' @@ -123,12 +165,11 @@ if target_os in targets_support_cc: prefix = env.get('TC_PREFIX') tc_path = env.get('TC_PATH') if prefix: - env.Replace(CC = prefix + 'gcc') - env.Replace(CXX = prefix + 'g++') - env.Replace(AR = prefix + 'ar') - env.Replace(AS = prefix + 'as') - env.Replace(LINK = prefix + 'ld') - env.Replace(RANLIB = prefix + 'ranlib') + env.Replace(CC = prefix + env.get('CC', 'gcc')) + env.Replace(CXX = prefix + env.get('CXX', 'g++')) + env.Replace(AR = prefix + env.get('AR', 'ar')) + env.Replace(AS = prefix + env.get('AS', 'as')) + env.Replace(RANLIB = prefix + env.get('RANLIB', 'ranlib')) if tc_path: env.PrependENVPath('PATH', tc_path) @@ -139,6 +180,14 @@ if target_os in targets_support_cc: if prefix or tc_path: print tc_set_msg +# If cross-compiling, honor environment settings for toolchain to avoid picking up native tools +if os.environ.get('PKG_CONFIG') != None: + env["ENV"]["PKG_CONFIG"] = os.environ.get("PKG_CONFIG") +if os.environ.get('PKG_CONFIG_PATH') != None: + env["ENV"]["PKG_CONFIG_PATH"] = os.environ.get("PKG_CONFIG_PATH") +if os.environ.get('PKG_CONFIG_SYSROOT_DIR') != None: + env["ENV"]["PKG_CONFIG_SYSROOT_DIR"] = os.environ.get("PKG_CONFIG_SYSROOT_DIR") + # Ensure scons be able to change its working directory env.SConscriptChdir(1) @@ -180,6 +229,38 @@ def __install(ienv, targets, name): Alias(name, i_n) env.AppendUnique(TS = [name]) +def __installlib(ienv, targets, name): + user_prefix = env.get('PREFIX') + if user_prefix: + user_lib = env.get('LIB_INSTALL_DIR') + if user_lib: + i_n = ienv.Install(user_lib, targets) + else: + i_n = ienv.Install(user_prefix + '/lib', targets) + ienv.Alias("install", i_n) + +def __installbin(ienv, targets, name): + user_prefix = env.get('PREFIX') + if user_prefix: + i_n = ienv.Install(user_prefix + '/bin', targets) + ienv.Alias("install", i_n) + +def __installheader(ienv, targets, dir, name): + user_prefix = env.get('PREFIX') + if user_prefix: + i_n = ienv.Install(user_prefix + '/include/' + dir ,targets) + ienv.Alias("install", i_n) + +def __installpcfile(ienv, targets, name): + user_prefix = env.get('PREFIX') + if user_prefix: + user_lib = env.get('LIB_INSTALL_DIR') + if user_lib: + i_n = ienv.Install(user_lib + '/pkgconfig', targets) + else: + i_n = ienv.Install(user_prefix + '/lib/pkgconfig', targets) + ienv.Alias("install", i_n) + def __append_target(ienv, name, targets = None): if targets: env.Alias(name, targets) @@ -203,12 +284,48 @@ env.AddMethod(__print_targets, 'PrintTargets') env.AddMethod(__src_to_obj, 'SrcToObj') env.AddMethod(__append_target, 'AppendTarget') env.AddMethod(__install, 'InstallTarget') +env.AddMethod(__installlib, 'UserInstallTargetLib') +env.AddMethod(__installbin, 'UserInstallTargetBin') +env.AddMethod(__installheader, 'UserInstallTargetHeader') +env.AddMethod(__installpcfile, 'UserInstallTargetPCFile') env.SetDir(env.GetLaunchDir()) env['ROOT_DIR']=env.GetLaunchDir()+'/..' Export('env') ###################################################################### +# Scons to generate the iotivity.pc file from iotivity.pc.in file +###################################################################### +pc_file = env.get('SRC_DIR') + '/iotivity.pc.in' + +if env.get('ROUTING') == 'GW': + routing_define = 'ROUTING_GATEWAY' +elif env.get('ROUTING') == 'EP': + routing_define = 'ROUTING_EP' + +user_prefix = env.get('PREFIX') +user_lib = env.get('LIB_INSTALL_DIR') +if not user_lib: + user_lib = '$${prefix}/lib' + +if user_prefix: + pc_vars = {'\@PREFIX\@': user_prefix, + '\@EXEC_PREFIX\@':user_prefix, + '\@VERSION\@': '1.0.1', + '\@LIB_INSTALL_DIR\@': user_lib, + '\@ROUTING_DEFINE\@': routing_define + } +else: + pc_vars = {'\@PREFIX\@': env.get('BUILD_DIR'), + '\@EXEC_PREFIX\@': env.get('BUILD_DIR'), + '\@VERSION\@': '1.0.1', + '\@LIB_INSTALL_DIR\@': user_lib, + '\@ROUTING_DEFINE\@': routing_define + } + +env.Substfile(pc_file, SUBST_DICT = pc_vars) + +###################################################################### # Link scons to Yocto cross-toolchain ONLY when target_os is yocto ###################################################################### if target_os == "yocto": @@ -265,7 +382,7 @@ if target_os == "yocto": env.AppendUnique(CPPDEFINES = ['TB_LOG']) env.AppendUnique(CPPDEFINES = ['WITH_POSIX', '__linux__', '_GNU_SOURCE']) env.AppendUnique(CFLAGS = ['-std=gnu99']) - env.AppendUnique(CCFLAGS = ['-Wall', '-fPIC']) + env.AppendUnique(CCFLAGS = ['-Wall', '-Wextra', '-fPIC']) env.AppendUnique(LINKFLAGS = ['-ldl', '-lpthread']) env.AppendUnique(LIBS = ['uuid']) Export('env')