summaryrefslogtreecommitdiffstats
path: root/configure.py
diff options
context:
space:
mode:
authorEvan Martin <martine@danga.com>2011-12-20 19:38:56 (GMT)
committerEvan Martin <martine@danga.com>2011-12-20 19:38:56 (GMT)
commit9bf145d98746d60d7d757ab6a8bc0c016d9c4360 (patch)
treeef87968fcd10ccb109fac31d981e872e86d2f2ac /configure.py
parenta3ace781e54b0c29322f5578d9de41efb05bb484 (diff)
downloadNinja-9bf145d98746d60d7d757ab6a8bc0c016d9c4360.zip
Ninja-9bf145d98746d60d7d757ab6a8bc0c016d9c4360.tar.gz
Ninja-9bf145d98746d60d7d757ab6a8bc0c016d9c4360.tar.bz2
inline gtest to simplify windows build
Diffstat (limited to 'configure.py')
-rwxr-xr-xconfigure.py39
1 files changed, 23 insertions, 16 deletions
diff --git a/configure.py b/configure.py
index 6b4c0d3..8bb5d24 100755
--- a/configure.py
+++ b/configure.py
@@ -41,7 +41,7 @@ parser.add_option('--profile', metavar='TYPE',
choices=profilers,
help='enable profiling (' + '/'.join(profilers) + ')',)
parser.add_option('--with-gtest', metavar='PATH',
- help='use gtest built in directory PATH')
+ help='use gtest unpacked in directory PATH')
(options, args) = parser.parse_args()
platform = options.platform
@@ -74,6 +74,10 @@ def doc(filename):
return os.path.join('doc', filename)
def cxx(name, **kwargs):
return n.build(built(name + '.o'), 'cxx', src(name + '.cc'), **kwargs)
+def binary(name):
+ if platform == 'mingw':
+ return name + '.exe'
+ return name
n.variable('builddir', 'build')
n.variable('cxx', os.environ.get('CXX', 'g++'))
@@ -91,8 +95,6 @@ libs = []
if platform == 'mingw':
cflags.remove('-fvisibility=hidden');
- cflags.append('-Igtest-1.6.0/include')
- ldflags.append('-Lgtest-1.6.0/lib/.libs')
ldflags.append('-static')
else:
if options.profile == 'gmon':
@@ -169,11 +171,8 @@ libs.append('-lninja')
n.comment('Main executable is library plus main() function.')
objs = cxx('ninja')
-binary = 'ninja'
-if platform == 'mingw':
- binary = 'ninja.exe'
-n.build(binary, 'link', objs, implicit=ninja_lib,
- variables=[('libs', libs)])
+ninja = n.build(binary('ninja'), 'link', objs, implicit=ninja_lib,
+ variables=[('libs', libs)])
n.newline()
n.comment('Tests all build into ninja_test executable.')
@@ -181,15 +180,23 @@ n.comment('Tests all build into ninja_test executable.')
variables = []
test_cflags = None
test_ldflags = None
+test_libs = libs
+objs = []
if options.with_gtest:
path = options.with_gtest
+
+ gtest_all_incs = '-I%s -I%s' % (path, os.path.join(path, 'include'))
+ objs += n.build(built('gtest-all.o'), 'cxx',
+ os.path.join(path, 'src/gtest-all.cc'),
+ variables=[('cflags', gtest_all_incs)])
+ objs += n.build(built('gtest_main.o'), 'cxx',
+ os.path.join(path, 'src/gtest_main.cc'),
+ variables=[('cflags', gtest_all_incs)])
+
test_cflags = cflags + ['-I%s' % os.path.join(path, 'include')]
- test_libs = libs + [os.path.join(path, 'lib/.libs/lib%s.a' % lib)
- for lib in ['gtest_main', 'gtest']]
else:
- test_libs = libs + ['-lgtest_main', '-lgtest']
+ test_libs.extend(['-lgtest_main', '-lgtest'])
-objs = []
for name in ['build_log_test',
'build_test',
'clean_test',
@@ -207,14 +214,14 @@ for name in ['build_log_test',
if platform != 'mingw':
test_libs.append('-lpthread')
-n.build('ninja_test', 'link', objs, implicit=ninja_lib,
+n.build(binary('ninja_test'), 'link', objs, implicit=ninja_lib,
variables=[('ldflags', test_ldflags),
('libs', test_libs)])
n.newline()
n.comment('Perftest executable.')
objs = cxx('parser_perftest')
-n.build('parser_perftest', 'link', objs, implicit=ninja_lib,
+n.build(binary('parser_perftest'), 'link', objs, implicit=ninja_lib,
variables=[('libs', '-L$builddir -lninja')])
n.newline()
@@ -252,7 +259,7 @@ n.build('doxygen', 'doxygen', doc('doxygen.config'),
implicit=mainpage)
n.newline()
-if platform != 'mingw':
+if host != 'mingw':
n.comment('Regenerate build files if build script changes.')
n.rule('configure',
command='./configure.py $configure_args',
@@ -262,6 +269,6 @@ if platform != 'mingw':
n.newline()
n.comment('Build only the main binary by default.')
-n.default(binary)
+n.default(ninja)
print 'wrote %s.' % BUILD_FILENAME