blob: 5d5befc0846594f58555e0791e4e7db3a0dd3e7a [file]
#!/usr/bin/python
# Copyright 2014 Google Inc.
#
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
"""
Modified version of gyp_skia, used by gyp_to_android.py to generate Android.mk
"""
import os
import sys
SCRIPT_DIR = os.path.abspath(os.path.dirname(__file__))
# Unlike gyp_skia, this file is nested deep inside Skia. Find Skia's trunk dir.
# This line depends on the fact that the script is three levels deep
# (specifically, it is in platform_tools/android/bin).
SKIA_DIR = os.path.normpath(os.path.join(SCRIPT_DIR, os.pardir, os.pardir,
os.pardir))
DIR_CONTENTS = os.listdir(SKIA_DIR)
assert 'gyp' in DIR_CONTENTS
# Directory within which we can find the gyp source.
if 'third_party' in DIR_CONTENTS:
GYP_SOURCE_DIR = os.path.join(SKIA_DIR, 'third_party', 'externals', 'gyp')
else:
# In an Android tree, there is no third_party/externals/gyp, which would
# require running gclient sync. Use chromium's instead.
GYP_SOURCE_DIR = os.path.join(SKIA_DIR, os.pardir, 'chromium_org', 'tools',
'gyp')
assert os.path.exists(GYP_SOURCE_DIR)
# Ensure we import our current gyp source's module, not any version
# pre-installed in your PYTHONPATH.
sys.path.insert(0, os.path.join(GYP_SOURCE_DIR, 'pylib'))
import gyp
def main(target_dir, target_file, skia_arch_type, have_neon):
"""
Create gypd files based on target_file.
@param target_dir Directory containing all gyp files, including common.gypi
@param target_file Gyp file to start on. Other files within target_dir will
be read if target_file depends on them.
@param skia_arch_type Target architecture to pass to gyp.
@param have_neon Whether to generate files including neon optimizations.
Only meaningful if skia_arch_type is 'arm'.
@return path Path to root gypd file created by running gyp.
"""
# Set GYP_DEFINES for building for the android framework.
gyp_defines = ('skia_android_framework=1 OS=android skia_arch_type=%s '
% skia_arch_type)
if skia_arch_type == 'arm':
# Always use thumb and version 7 for arm
gyp_defines += 'arm_thumb=1 arm_version=7 '
if have_neon:
gyp_defines += 'arm_neon=1 '
else:
gyp_defines += 'arm_neon=0 '
os.environ['GYP_DEFINES'] = gyp_defines
args = []
args.extend(['--depth', '.'])
full_path = os.path.join(target_dir, target_file)
args.extend([full_path])
# Common conditions
args.extend(['-I', os.path.join(target_dir, 'common.gypi')])
# Use the debugging format. We'll use these to create one master make file.
args.extend(['-f', 'gypd'])
# Off we go...
ret = gyp.main(args)
if ret != 0:
raise Exception("gyp failed!")
# Running gyp should have created a gypd file, with the same name as
# full_path but with a 'd' on the end.
gypd_file = full_path + 'd'
if not os.path.exists(gypd_file):
raise Exception("gyp failed to produce gypd file!")
return gypd_file