#!/usr/bin/env python # Copyright 2015 The PDFium Authors. All rights reserved. # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. import glob import os import subprocess import sys def os_name(): if sys.platform.startswith('linux'): return 'linux' if sys.platform.startswith('win'): return 'win' if sys.platform.startswith('darwin'): return 'mac' raise Exception('Confused, can not determine OS, aborting.') def RunCommand(cmd): try: subprocess.check_call(cmd) return None except subprocess.CalledProcessError as e: return e # RunCommandExtractHashedFiles returns a tuple: (raised_exception, hashed_files) # It runs the given command. If it fails it will return an exception and None. # If it succeeds it will return None and the list of processed files extracted # from the output of the command. It expects lines in this format: # MD5:: # The returned hashed_files is a list of (file_path, MD5-hash) pairs. def RunCommandExtractHashedFiles(cmd): try: output = subprocess.check_output(cmd, universal_newlines=True) ret = [] for line in output.split('\n'): line = line.strip() if line.startswith("MD5:"): ret.append([x.strip() for x in line.lstrip("MD5:").rsplit(":", 1)]) return None, ret except subprocess.CalledProcessError as e: return e, None class DirectoryFinder: '''A class for finding directories and paths under either a standalone checkout or a chromium checkout of PDFium.''' def __init__(self, build_location): # |build_location| is typically "out/Debug" or "out/Release". # Expect |my_dir| to be .../pdfium/testing/tools. self.my_dir = os.path.dirname(os.path.realpath(__file__)) self.testing_dir = os.path.dirname(self.my_dir) if (os.path.basename(self.my_dir) != 'tools' or os.path.basename(self.testing_dir) != 'testing'): raise Exception('Confused, can not find pdfium root directory, aborting.') self.pdfium_dir = os.path.dirname(self.testing_dir) # Find path to build directory. This depends on whether this is a # standalone build vs. a build as part of a chromium checkout. For # standalone, we expect a path like .../pdfium/out/Debug, but for # chromium, we expect a path like .../src/out/Debug two levels # higher (to skip over the third_party/pdfium path component under # which chromium sticks pdfium). self.base_dir = self.pdfium_dir one_up_dir = os.path.dirname(self.base_dir) two_up_dir = os.path.dirname(one_up_dir) if (os.path.basename(two_up_dir) == 'src' and os.path.basename(one_up_dir) == 'third_party'): self.base_dir = two_up_dir self.build_dir = os.path.join(self.base_dir, build_location) self.os_name = os_name() def ExecutablePath(self, name): '''Finds compiled binaries under the build path.''' result = os.path.join(self.build_dir, name) if self.os_name == 'win': result = result + '.exe' return result def ScriptPath(self, name): '''Finds other scripts in the same directory as this one.''' return os.path.join(self.my_dir, name) def WorkingDir(self, other_components=''): '''Places generated files under the build directory, not source dir.''' result = os.path.join(self.build_dir, 'gen', 'pdfium') if other_components: result = os.path.join(result, other_components) return result def TestingDir(self, other_components=''): '''Finds test files somewhere under the testing directory.''' result = self.testing_dir if other_components: result = os.path.join(result, other_components) return result