| Index: platform_tools/android/bin/gyp_to_android.py
|
| diff --git a/platform_tools/android/bin/gyp_to_android.py b/platform_tools/android/bin/gyp_to_android.py
|
| index f7199b8ddb68e5b9778d5f4057ce2d9766f26e29..f43d597a15a1bd048826dba260f5f76f876545c4 100755
|
| --- a/platform_tools/android/bin/gyp_to_android.py
|
| +++ b/platform_tools/android/bin/gyp_to_android.py
|
| @@ -10,7 +10,6 @@ Script for generating the Android framework's version of Skia from gyp
|
| files.
|
| """
|
|
|
| -import android_framework_gyp
|
| import os
|
| import shutil
|
| import sys
|
| @@ -25,53 +24,48 @@ SKIA_DIR = os.path.normpath(os.path.join(SCRIPT_DIR, os.pardir, os.pardir,
|
| GYP_GEN_DIR = os.path.join(SKIA_DIR, 'platform_tools', 'android', 'gyp_gen')
|
| sys.path.append(GYP_GEN_DIR)
|
|
|
| +import android_framework_gyp
|
| import gypd_parser
|
| import generate_user_config
|
| import makefile_writer
|
| +import tool_makefile_writer
|
| import vars_dict_lib
|
|
|
| # Folder containing all gyp files and generated gypd files.
|
| GYP_FOLDER = 'gyp'
|
|
|
| -# TODO(scroggo): Update the docstrings to match the style guide:
|
| -# http://google-styleguide.googlecode.com/svn/trunk/pyguide.html#Comments
|
| -def clean_gypd_files(folder):
|
| - """
|
| - Remove the gypd files generated by android_framework_gyp.main().
|
| - @param folder Folder in which to delete all files ending with 'gypd'.
|
| - """
|
| - assert os.path.isdir(folder)
|
| - files = os.listdir(folder)
|
| - for f in files:
|
| - if f.endswith('gypd'):
|
| - os.remove(os.path.join(folder, f))
|
|
|
| def generate_var_dict(target_dir, target_file, skia_arch_type, have_neon):
|
| - """
|
| - Create a VarsDict for a particular arch type. Each paramater is passed
|
| - directly to android_framework_gyp.main().
|
| - @param target_dir Directory containing gyp files.
|
| - @param target_file Target gyp file.
|
| - @param skia_arch_type Target architecture.
|
| - @param have_neon Whether the target should build for neon.
|
| - @return a VarsDict containing the variable definitions determined by gyp.
|
| + """Create a VarsDict for a particular arch type.
|
| +
|
| + Each paramater is passed directly to android_framework_gyp.main().
|
| +
|
| + Args:
|
| + target_dir: Directory containing gyp files.
|
| + target_file: Target gyp file.
|
| + skia_arch_type: Target architecture.
|
| + have_neon: Whether the target should build for neon.
|
| + Returns:
|
| + A VarsDict containing the variable definitions determined by gyp.
|
| """
|
| result_file = android_framework_gyp.main(target_dir, target_file,
|
| skia_arch_type, have_neon)
|
| var_dict = vars_dict_lib.VarsDict()
|
| - gypd_parser.parse_gypd(var_dict, result_file)
|
| - clean_gypd_files(target_dir)
|
| + gypd_parser.parse_gypd(var_dict, result_file, '.')
|
| + android_framework_gyp.clean_gypd_files(target_dir)
|
| print '.',
|
| return var_dict
|
|
|
| def main(target_dir=None, require_sk_user_config=False):
|
| - """
|
| - Read gyp files and create Android.mk for the Android framework's
|
| - external/skia.
|
| - @param target_dir Directory in which to place 'Android.mk'. If None, the file
|
| - will be placed in skia's root directory.
|
| - @param require_sk_user_config If True, raise an AssertionError if
|
| - SkUserConfig.h does not exist.
|
| + """Create Android.mk for the Android framework's external/skia.
|
| +
|
| + Builds Android.mk using Skia's gyp files.
|
| +
|
| + Args:
|
| + target_dir: Directory in which to place 'Android.mk'. If None, the file
|
| + will be placed in skia's root directory.
|
| + require_sk_user_config: If True, raise an AssertionError if
|
| + SkUserConfig.h does not exist.
|
| """
|
| # Create a temporary folder to hold gyp and gypd files. Create it in SKIA_DIR
|
| # so that it is a sibling of gyp/, so the relationships between gyp files and
|
| @@ -119,6 +113,8 @@ def main(target_dir=None, require_sk_user_config=False):
|
| x86_var_dict, mips_var_dict, arm64_var_dict]
|
| common = vars_dict_lib.intersect(var_dict_list)
|
|
|
| + common.LOCAL_MODULE.add('libskia')
|
| +
|
| # Create SkUserConfig
|
| user_config = os.path.join(SKIA_DIR, 'include', 'config', 'SkUserConfig.h')
|
| if target_dir:
|
| @@ -131,8 +127,26 @@ def main(target_dir=None, require_sk_user_config=False):
|
| require_sk_user_config=require_sk_user_config, target_dir=dst_dir,
|
| ordered_set=common.DEFINES)
|
|
|
| - # Now that the defines have been written to SkUserConfig, they are not
|
| - # needed in Android.mk.
|
| + tool_makefile_writer.generate_tool(gyp_dir=tmp_folder,
|
| + target_file='tests.gyp',
|
| + skia_trunk=target_dir,
|
| + dest_dir='tests',
|
| + skia_lib_var_dict=common,
|
| + local_module_name='skia_test',
|
| + local_module_tags=['eng', 'tests'])
|
| +
|
| + # TODO (scroggo): Generate bench/Android.mk. See skbug.com/2448
|
| + #tool_makefile_writer.generate_tool(gyp_dir=tmp_folder,
|
| + # target_file='bench.gyp',
|
| + # skia_trunk=target_dir,
|
| + # dest_dir='bench',
|
| + # skia_lib_var_dict=common,
|
| + # local_module_name='skia_bench',
|
| + # local_module_tags=['tests'])
|
| +
|
| + # Now that the defines have been written to SkUserConfig and they've been
|
| + # used to skip adding them to the tools makefiles, they are not needed in
|
| + # Android.mk. Reset DEFINES.
|
| common.DEFINES.reset()
|
|
|
| # Further trim arm_neon_var_dict with arm_var_dict. After this call,
|
|
|