diff --git a/common.py b/common.py index 1f94a57..d04c6be 100644 --- a/common.py +++ b/common.py @@ -3,7 +3,7 @@ from fnmatch import fnmatch from glob import glob from logging import debug, info, error -from os import path, environ +from os import path import contextlib import distutils.spawn import os @@ -450,12 +450,14 @@ def make(name, target=None, **makevars): execute('make', *args) -def require_header(header, symbol = False, value = False): +def require_header(header, lang, msg = '', symbol = False, value = False): debug('require_header "%s"', header) - cmd = environ['CC'].split() + ['-fsyntax-only', '-x', 'c', '-'] - proc = subprocess.Popen(cmd, stdin = subprocess.PIPE, env = environ) - stdin_line = '#include ' + header + cmd = {'c':'{cc}', 'c++':'{cxx}'}[lang] + cmd = fill_in(cmd).split() + ['-fsyntax-only', '-x', lang, '-'] + proc = subprocess.Popen(cmd, stdin = subprocess.PIPE, stdout = subprocess.PIPE, stderr = subprocess.PIPE) + + stdin_line = '#include <' + header + '>' if symbol: if value: stdin_line += """\n#if %s != %s @@ -466,11 +468,16 @@ def require_header(header, symbol = False, value = False): #error #endif """ % (symbol) - proc.communicate(stdin_line) + (result_stdout, result_stderr) = proc.communicate(stdin_line) proc.wait() - if proc.returncode != 0: - panic('require_header "%s" failed', header) + cmd = ' '.join(cmd) + + if proc.returncode == 0: + debug('output from "%s":\n%s', cmd, result_stdout) + else: + debug('error output from "%s":\n%s', cmd, result_stderr) + panic('require_header failed: %s', msg) __all__ = ['setvar', 'panic', 'cmpver', 'find_executable', 'chmod', 'execute', diff --git a/toolchain-m68k b/toolchain-m68k index 1d57fe3..75718ff 100755 --- a/toolchain-m68k +++ b/toolchain-m68k @@ -241,13 +241,14 @@ def build(): path.join('{host}', 'bin'), environ['PATH']]) + setvar(cc = environ['CC'], cxx = environ['CXX']) + """ When we have a working compiler in our path, we can also check if the required headers/libraries are present. """ - require_header('') - require_header('', symbol = 'NCURSES_VERSION_MAJOR', value = 5) + require_header('ncurses.h', 'c', 'libncurses-dev 5.x missing', 'NCURSES_VERSION_MAJOR', 5) unpack('{m4}') configure('{m4}', '--prefix={host}')