#!/usr/bin/env python # Copyright (C) 2011 Igalia S.L. # # This library is free software; you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public # License as published by the Free Software Foundation; either # version 2 of the License, or (at your option) any later version. # # This library is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public # License along with this library; if not, write to the Free Software # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA import errno import os import select import subprocess import sys top_level_dir = None build_dir = None library_build_dir = None binary_build_dir = None build_types = ('Release', 'Debug') def top_level_path(*args): global top_level_dir if not top_level_dir: top_level_dir = os.path.join(os.path.dirname(__file__), '..', '..') return os.path.join(*(top_level_dir,) + args) def set_build_types(new_build_types): global build_types build_types = new_build_types def library_build_path(*args): global library_build_dir if not library_build_dir: library_build_dir = build_path('lib', *args) return library_build_dir def binary_build_path(*args): global binary_build_dir if not binary_build_dir: binary_build_dir = build_path('bin', *args) return binary_build_dir def get_build_path(fatal=True): global build_dir if build_dir: return build_dir def is_valid_build_directory(path): return os.path.exists(os.path.join(path, 'CMakeCache.txt')) or \ os.path.exists(os.path.join(path, 'bin/MiniBrowser')) if len(sys.argv[1:]) > 1 and os.path.exists(sys.argv[-1]) and is_valid_build_directory(sys.argv[-1]): return sys.argv[-1] # Debian and Ubuntu build both flavours of the library (with gtk2 # and with gtk3); they use directories build-2.0 and build-3.0 for # that, which is not handled by the above cases; we check that the # directory where we are called from is a valid build directory, # which should handle pretty much all other non-standard cases. build_dir = os.getcwd() if is_valid_build_directory(build_dir): return build_dir global build_types for build_type in build_types: build_dir = top_level_path('WebKitBuild', build_type) if is_valid_build_directory(build_dir): return build_dir # distcheck builds in a directory named _build in the top-level path. build_dir = top_level_path("_build") if is_valid_build_directory(build_dir): return build_dir build_dir = top_level_path() if is_valid_build_directory(build_dir): return build_dir build_dir = top_level_path("WebKitBuild") if is_valid_build_directory(build_dir): return build_dir print('Could not determine build directory.') if fatal: sys.exit(1) def build_path(*args): return os.path.join(*(get_build_path(),) + args) def pkg_config_file_variable(package, variable): process = subprocess.Popen(['pkg-config', '--variable=%s' % variable, package], stdout=subprocess.PIPE) stdout = process.communicate()[0].decode("utf-8") if process.returncode: return None return stdout.strip() def prefix_of_pkg_config_file(package): return pkg_config_file_variable(package, 'prefix') def parse_output_lines(fd, parse_line_callback): output = '' read_set = [fd] while read_set: try: rlist, wlist, xlist = select.select(read_set, [], []) except select.error as e: parse_line_callback("WARNING: error while waiting for fd %d to become readable\n" % fd) parse_line_callback(" error code: %d, error message: %s\n" % (e[0], e[1])) continue if fd in rlist: try: chunk = os.read(fd, 1024) except OSError as e: if e.errno == errno.EIO: # Child process finished. chunk = '' else: raise e if not chunk: read_set.remove(fd) output += chunk while '\n' in output: pos = output.find('\n') parse_line_callback(output[:pos + 1]) output = output[pos + 1:] if not chunk and output: parse_line_callback(output) output = ''