Fixes the scons script to build gtest-death-test_test on Linux.
This commit is contained in:
		| @@ -99,8 +99,8 @@ env = env.Clone() | |||||||
| # Include paths to gtest headers are relative to either the gtest | # Include paths to gtest headers are relative to either the gtest | ||||||
| # directory or the 'include' subdirectory of it, and this SConscript | # directory or the 'include' subdirectory of it, and this SConscript | ||||||
| # file is one directory deeper than the gtest directory. | # file is one directory deeper than the gtest directory. | ||||||
| env.Prepend(CPPPATH = ['..', | env.Prepend(CPPPATH = ['#/..', | ||||||
|                        '../include']) |                        '#/../include']) | ||||||
|  |  | ||||||
| # Sources used by base library and library that includes main. | # Sources used by base library and library that includes main. | ||||||
| gtest_source = '../src/gtest-all.cc' | gtest_source = '../src/gtest-all.cc' | ||||||
| @@ -117,8 +117,7 @@ gtest_main = env.StaticLibrary(target='gtest_main', | |||||||
|                                source=[gtest_source, gtest_main_source]) |                                source=[gtest_source, gtest_main_source]) | ||||||
|  |  | ||||||
| env_with_exceptions = env.Clone() | env_with_exceptions = env.Clone() | ||||||
| platform = env_with_exceptions['PLATFORM'] | if env_with_exceptions['PLATFORM'] == 'win32': | ||||||
| if platform == 'win32': |  | ||||||
|   env_with_exceptions.Append(CCFLAGS = ['/EHsc']) |   env_with_exceptions.Append(CCFLAGS = ['/EHsc']) | ||||||
|   env_with_exceptions.Append(CPPDEFINES = '_HAS_EXCEPTIONS=1') |   env_with_exceptions.Append(CPPDEFINES = '_HAS_EXCEPTIONS=1') | ||||||
|   # Undoes the _TYPEINFO_ hack, which is unnecessary and only creates |   # Undoes the _TYPEINFO_ hack, which is unnecessary and only creates | ||||||
| @@ -205,7 +204,14 @@ GtestUnitTest(env, 'gtest_output_test_', gtest) | |||||||
| GtestUnitTest(env, 'gtest_color_test_', gtest) | GtestUnitTest(env, 'gtest_color_test_', gtest) | ||||||
| GtestUnitTest(env, 'gtest-linked_ptr_test', gtest_main) | GtestUnitTest(env, 'gtest-linked_ptr_test', gtest_main) | ||||||
| GtestUnitTest(env, 'gtest-port_test', gtest_main) | GtestUnitTest(env, 'gtest-port_test', gtest_main) | ||||||
| GtestUnitTest(env, 'gtest-death-test_test', gtest_main) |  | ||||||
|  | env_with_pthread = env.Clone() | ||||||
|  | if env_with_pthread['PLATFORM'] not in ['win32', 'darwin']: | ||||||
|  |   # Assuming POSIX-like environment with GCC. | ||||||
|  |   env_with_pthread.Append(CCFLAGS = ['-pthread']) | ||||||
|  |   env_with_pthread.Append(LINKFLAGS = ['-pthread']) | ||||||
|  |  | ||||||
|  | GtestUnitTest(env_with_pthread, 'gtest-death-test_test', gtest_main) | ||||||
|  |  | ||||||
| gtest_unittest_ex_obj = env_with_exceptions.Object( | gtest_unittest_ex_obj = env_with_exceptions.Object( | ||||||
|     target='gtest_unittest_ex', |     target='gtest_unittest_ex', | ||||||
| @@ -226,16 +232,17 @@ GtestBinary(env_with_exceptions, | |||||||
| # - gtest_xml_outfile2_test_ | # - gtest_xml_outfile2_test_ | ||||||
| # - gtest_xml_output_unittest_ | # - gtest_xml_output_unittest_ | ||||||
|  |  | ||||||
| # We need to disable some optimization flags for a couple of tests, | # We need to disable some optimization flags for some tests on | ||||||
| # otherwise the redirection of stdout does not work (apparently | # Windows; otherwise the redirection of stdout does not work | ||||||
| # because of a compiler bug). | # (apparently because of a compiler bug). | ||||||
| special_env = env.Clone() | env_with_less_optimization = env.Clone() | ||||||
| linker_flags = special_env['LINKFLAGS'] | if env_with_less_optimization['PLATFORM'] == 'win32': | ||||||
| for flag in ["/O1", "/Os", "/Og", "/Oy"]: |   linker_flags = env_with_less_optimization['LINKFLAGS'] | ||||||
|   if flag in linker_flags: |   for flag in ["/O1", "/Os", "/Og", "/Oy"]: | ||||||
|     linker_flags.remove(flag) |     if flag in linker_flags: | ||||||
| GtestUnitTest(special_env, 'gtest_env_var_test_', gtest) |       linker_flags.remove(flag) | ||||||
| GtestUnitTest(special_env, 'gtest_uninitialized_test_', gtest) | GtestUnitTest(env_with_less_optimization, 'gtest_env_var_test_', gtest) | ||||||
|  | GtestUnitTest(env_with_less_optimization, 'gtest_uninitialized_test_', gtest) | ||||||
|  |  | ||||||
| def GtestSample(env, target, gtest_lib, additional_sources=None): | def GtestSample(env, target, gtest_lib, additional_sources=None): | ||||||
|   """Helper to create gtest samples. |   """Helper to create gtest samples. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 zhanyong.wan
					zhanyong.wan