- fixed SCons build on Windows: only build static library (support static/dynamic at the same time requires significant changes)

- renamed SCons glob tool to globtool to avoid clash with python glob module. This prevented running the tests.
- check target now works with SCons 1.x
This commit is contained in:
Baptiste Lepilleur 2009-11-18 21:27:06 +00:00
parent 617270bfaa
commit 64e07e54ed
6 changed files with 57 additions and 31 deletions

View File

@ -137,24 +137,29 @@ elif platform == 'msvc6':
for tool in ['msvc', 'msvs', 'mslink', 'masm', 'mslib']: for tool in ['msvc', 'msvs', 'mslink', 'masm', 'mslib']:
env.Tool( tool ) env.Tool( tool )
env['CXXFLAGS']='-GR -GX /nologo /MT' env['CXXFLAGS']='-GR -GX /nologo /MT'
env['SHARED_LIB_ENABLED'] = False
elif platform == 'msvc70': elif platform == 'msvc70':
env['MSVS_VERSION']='7.0' env['MSVS_VERSION']='7.0'
for tool in ['msvc', 'msvs', 'mslink', 'masm', 'mslib']: for tool in ['msvc', 'msvs', 'mslink', 'masm', 'mslib']:
env.Tool( tool ) env.Tool( tool )
env['CXXFLAGS']='-GR -GX /nologo /MT' env['CXXFLAGS']='-GR -GX /nologo /MT'
env['SHARED_LIB_ENABLED'] = False
elif platform == 'msvc71': elif platform == 'msvc71':
env['MSVS_VERSION']='7.1' env['MSVS_VERSION']='7.1'
for tool in ['msvc', 'msvs', 'mslink', 'masm', 'mslib']: for tool in ['msvc', 'msvs', 'mslink', 'masm', 'mslib']:
env.Tool( tool ) env.Tool( tool )
env['CXXFLAGS']='-GR -GX /nologo /MT' env['CXXFLAGS']='-GR -GX /nologo /MT'
env['SHARED_LIB_ENABLED'] = False
elif platform == 'msvc80': elif platform == 'msvc80':
env['MSVS_VERSION']='8.0' env['MSVS_VERSION']='8.0'
for tool in ['msvc', 'msvs', 'mslink', 'masm', 'mslib']: for tool in ['msvc', 'msvs', 'mslink', 'masm', 'mslib']:
env.Tool( tool ) env.Tool( tool )
env['CXXFLAGS']='-GR -EHsc /nologo /MT' env['CXXFLAGS']='-GR -EHsc /nologo /MT'
env['SHARED_LIB_ENABLED'] = False
elif platform == 'mingw': elif platform == 'mingw':
env.Tool( 'mingw' ) env.Tool( 'mingw' )
env.Append( CPPDEFINES=[ "WIN32", "NDEBUG", "_MT" ] ) env.Append( CPPDEFINES=[ "WIN32", "NDEBUG", "_MT" ] )
env['SHARED_LIB_ENABLED'] = False
elif platform.startswith('linux-gcc'): elif platform.startswith('linux-gcc'):
env.Tool( 'default' ) env.Tool( 'default' )
env.Append( LIBS = ['pthread'], CCFLAGS = "-Wall" ) env.Append( LIBS = ['pthread'], CCFLAGS = "-Wall" )
@ -166,13 +171,16 @@ env.Tool('doxygen')
env.Tool('substinfile') env.Tool('substinfile')
env.Tool('targz') env.Tool('targz')
env.Tool('srcdist') env.Tool('srcdist')
env.Tool('glob') env.Tool('globtool')
env.Append( CPPPATH = ['#include'], env.Append( CPPPATH = ['#include'],
LIBPATH = lib_dir ) LIBPATH = lib_dir )
short_platform = platform short_platform = platform
if short_platform.startswith('msvc'): if short_platform.startswith('msvc'):
short_platform = short_platform[2:] short_platform = short_platform[2:]
# Notes: on Windows you need to rebuild the source for each variant
# Build script does not support that yet so we only build static libraries.
env['SHARED_LIB_ENABLED'] = env.get('SHARED_LIB_ENABLED', True)
env['LIB_PLATFORM'] = short_platform env['LIB_PLATFORM'] = short_platform
env['LIB_LINK_TYPE'] = 'lib' # static env['LIB_LINK_TYPE'] = 'lib' # static
env['LIB_CRUNTIME'] = 'mt' env['LIB_CRUNTIME'] = 'mt'
@ -210,11 +218,12 @@ def buildJSONTests( env, target_sources, target_name ):
def buildLibrary( env, target_sources, target_name ): def buildLibrary( env, target_sources, target_name ):
static_lib = env.StaticLibrary( target=target_name + '_${LIB_NAME_SUFFIX}', static_lib = env.StaticLibrary( target=target_name + '_${LIB_NAME_SUFFIX}',
source=target_sources ) source=target_sources )
shared_lib = env.SharedLibrary( target=target_name + '_${LIB_NAME_SUFFIX}',
source=target_sources )
global lib_dir global lib_dir
env.Install( lib_dir, static_lib ) env.Install( lib_dir, static_lib )
env.Install( lib_dir, shared_lib ) if env['SHARED_LIB_ENABLED']:
shared_lib = env.SharedLibrary( target=target_name + '_${LIB_NAME_SUFFIX}',
source=target_sources )
env.Install( lib_dir, shared_lib )
env['SRCDIST_ADD']( source=[target_sources] ) env['SRCDIST_ADD']( source=[target_sources] )
Export( 'env env_testing buildJSONExample buildLibrary buildJSONTests' ) Export( 'env env_testing buildJSONExample buildLibrary buildJSONTests' )
@ -232,10 +241,10 @@ def runJSONTests_action( target, source = None, env = None ):
jsontest_path = Dir( '#test' ).abspath jsontest_path = Dir( '#test' ).abspath
sys.path.insert( 0, jsontest_path ) sys.path.insert( 0, jsontest_path )
import runjsontests import runjsontests
return runjsontests.runAllTests( os.path.abspath(source), jsontest_path ) return runjsontests.runAllTests( os.path.abspath(source[0].path), jsontest_path )
def runJSONTests_string( target, source = None, env = None ): def runJSONTests_string( target, source = None, env = None ):
return 'RunJSONTests("%s")' % source return 'RunJSONTests("%s")' % source[0]
import SCons.Action import SCons.Action
ActionFactory = SCons.Action.ActionFactory ActionFactory = SCons.Action.ActionFactory

View File

@ -9,7 +9,6 @@
import os import os
import os.path import os.path
import glob
from fnmatch import fnmatch from fnmatch import fnmatch
import SCons import SCons

View File

@ -1,6 +1,5 @@
import os import os
import os.path import os.path
import glob
from fnmatch import fnmatch from fnmatch import fnmatch
import targz import targz

View File

@ -44,15 +44,15 @@ def valueTreeToString( fout, value, path = '.' ):
assert False and "Unexpected value type" assert False and "Unexpected value type"
def parseAndSaveValueTree( input, actual_path ): def parseAndSaveValueTree( input, actual_path ):
root = json.read( input ) root = json.loads( input )
fout = file( actual_path, 'wt' ) fout = file( actual_path, 'wt' )
valueTreeToString( fout, root ) valueTreeToString( fout, root )
fout.close() fout.close()
return root return root
def rewriteValueTree( value, rewrite_path ): def rewriteValueTree( value, rewrite_path ):
rewrite = json.write( value ) rewrite = json.dumps( value )
rewrite = rewrite[1:-1] # Somehow the string is quoted ! jsonpy bug ? #rewrite = rewrite[1:-1] # Somehow the string is quoted ! jsonpy bug ?
file( rewrite_path, 'wt').write( rewrite + '\n' ) file( rewrite_path, 'wt').write( rewrite + '\n' )
return rewrite return rewrite

View File

@ -1,7 +1,7 @@
import sys import sys
import os import os
import os.path import os.path
import glob from glob import glob
def compareOutputs( expected, actual, message ): def compareOutputs( expected, actual, message ):
@ -38,30 +38,49 @@ def safeReadFile( path ):
def runAllTests( jsontest_executable_path, input_dir = None ): def runAllTests( jsontest_executable_path, input_dir = None ):
if not input_dir: if not input_dir:
input_dir = os.getcwd() input_dir = os.getcwd()
tests = glob.glob( os.path.join( input_dir, '*.json' ) ) tests = glob( os.path.join( input_dir, '*.json' ) )
test_jsonchecker = glob( os.path.join( input_dir, 'jsonchecker', '*.json' ) )
failed_tests = [] failed_tests = []
for input_path in tests: for input_path in tests + test_jsonchecker:
is_json_checker_test = input_path in test_jsonchecker
print 'TESTING:', input_path, print 'TESTING:', input_path,
pipe = os.popen( "%s %s" % (jsontest_executable_path, input_path) ) options = is_json_checker_test and '--json-checker' or ''
pipe = os.popen( "%s %s %s" % (jsontest_executable_path, options,
input_path) )
process_output = pipe.read() process_output = pipe.read()
status = pipe.close() status = pipe.close()
base_path = os.path.splitext(input_path)[0] if is_json_checker_test:
actual_output = safeReadFile( base_path + '.actual' ) expect_failure = os.path.basename( input_path ).startswith( 'fail' )
actual_rewrite_output = safeReadFile( base_path + '.actual-rewrite' ) if expect_failure:
file(base_path + '.process-output','wt').write( process_output ) if status is None:
if status: print 'FAILED'
print 'parsing failed' failed_tests.append( (input_path, 'Parsing should have failed') )
failed_tests.append( (input_path, 'Parsing failed:\n' + process_output) ) else:
else: print 'OK'
expected_output_path = os.path.splitext(input_path)[0] + '.expected'
expected_output = file( expected_output_path, 'rt' ).read()
detail = ( compareOutputs( expected_output, actual_output, 'input' )
or compareOutputs( expected_output, actual_rewrite_output, 'rewrite' ) )
if detail:
print 'FAILED'
failed_tests.append( (input_path, detail) )
else: else:
print 'OK' if status is not None:
print 'FAILED'
failed_tests.append( (input_path, 'Parsing failed:\n' + process_output) )
else:
print 'OK'
else:
base_path = os.path.splitext(input_path)[0]
actual_output = safeReadFile( base_path + '.actual' )
actual_rewrite_output = safeReadFile( base_path + '.actual-rewrite' )
file(base_path + '.process-output','wt').write( process_output )
if status:
print 'parsing failed'
failed_tests.append( (input_path, 'Parsing failed:\n' + process_output) )
else:
expected_output_path = os.path.splitext(input_path)[0] + '.expected'
expected_output = file( expected_output_path, 'rt' ).read()
detail = ( compareOutputs( expected_output, actual_output, 'input' )
or compareOutputs( expected_output, actual_rewrite_output, 'rewrite' ) )
if detail:
print 'FAILED'
failed_tests.append( (input_path, detail) )
else:
print 'OK'
if failed_tests: if failed_tests:
print print