Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(578)

Unified Diff: build/config/ios/rules.gni

Issue 1879493002: [iOS/GN] Convert //ios/third_party/ochamcrest to build a framework. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@gn-framework-bundle
Patch Set: Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | build/config/mac/rules.gni » ('j') | build/config/mac/rules.gni » ('J')
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: build/config/ios/rules.gni
diff --git a/build/config/ios/rules.gni b/build/config/ios/rules.gni
index 604e7abec65b1ea63c80a47a95a254ea4864789b..e1937e12c48bb4e5fc375a88428fc5be8a310984 100644
--- a/build/config/ios/rules.gni
+++ b/build/config/ios/rules.gni
@@ -76,8 +76,8 @@ template("ios_app_bundle") {
"-s=PRODUCT_NAME=$_output_name",
"-s=XCODE_BUILD=$xcode_build",
"-s=XCODE_VERSION=$xcode_version",
- "-o=" + rebase_path(outputs[0], root_build_dir),
- ] + rebase_path(sources, root_build_dir)
+ "-o=" + rebase_path(outputs[0], root_out_dir),
+ ] + rebase_path(sources, root_out_dir)
args = [ "@{{response_file_name}}" ]
}
@@ -110,7 +110,7 @@ template("ios_app_bundle") {
"visibility",
])
- output_name = rebase_path("$target_gen_dir/$_output_name", root_build_dir)
+ output_name = rebase_path("$target_gen_dir/$_output_name", root_out_dir)
if (!defined(libs)) {
libs = []
}
@@ -210,7 +210,7 @@ template("bundle_data_xib") {
"--output",
rebase_path("$target_gen_dir/$_nib_filename"),
"--input",
- rebase_path(invoker.source, root_build_dir),
+ rebase_path(invoker.source, root_out_dir),
]
}
@@ -246,10 +246,97 @@ template("bundle_data_xib") {
# structure will not be created, and build output will go directly
# into the framework subdirectory.
#
+# public_headers:
+# (optional) list of paths to header file that needs to be copied
+# into the framework bundle Headers subdirectory. If omitted or
+# empty then the Headers subdirectory is not created.
+#
# See "gn help shared_library" for more information on arguments supported
# by shared library target.
template("ios_framework_bundle") {
+ if (defined(invoker.public_headers) && invoker.public_headers != []) {
+ _target_name = target_name
Robert Sesek 2016/04/11 18:32:28 optional: pull _target_name and _output_name out o
sdefresne 2016/04/12 13:05:19 I tried to pull _output_name outside of the "if" b
+ _output_name = target_name
+ if (defined(invoker.output_name)) {
+ _output_name = invoker.output_name
+ }
+
+ _public_headers = invoker.public_headers
+ _framework_name = _output_name + ".framework"
Robert Sesek 2016/04/11 18:32:28 I wish we didn't have to duplicate this, but I don
sdefresne 2016/04/12 13:05:19 Acknowledge. One option would be to change framewo
+ _framework_root = "$root_out_dir/$_framework_name"
+
+ _header_map_filename = "$target_gen_dir/$_output_name.headers.map"
+
+ _compile_headers_map_target = _target_name + "_compile_headers_map"
+ action(_compile_headers_map_target) {
Robert Sesek 2016/04/11 18:32:29 Should each of these sub-targets have visibility s
sdefresne 2016/04/12 13:05:19 Done, except for "_create_module_map_target" as I
+ script = "$root_out_dir/gyp-mac-tool"
+ outputs = [
+ _header_map_filename,
+ ]
+
+ sources = []
+ foreach(_source_file, invoker.sources) {
+ _source_extension = get_path_info(_source_file, "extension")
+ if (_source_extension == "h") {
+ sources += [ _source_file ]
+ }
+ }
+
+ args = [
+ "compile-ios-framework-header-map",
+ rebase_path(_header_map_filename),
+ rebase_path(_framework_root, root_out_dir),
+ ] + rebase_path(sources, root_out_dir)
+ }
+
+ _create_module_map_target = _target_name + "_module_map"
+ action(_create_module_map_target) {
+ script = "$root_out_dir/gyp-mac-tool"
+ outputs = [
+ "$_framework_root/Modules/module.modulemap",
+ ]
+ args = [
+ "package-ios-framework",
+ rebase_path("$_framework_root", root_out_dir),
+ ]
+ }
+
+ _copy_public_headers_target = _target_name + "_copy_public_headers"
+ copy(_copy_public_headers_target) {
+ sources = _public_headers
+ outputs = [
+ "$_framework_root/Headers/{{source_file_part}}",
+ ]
+ }
+
+ _headers_map_config = _target_name + "_headers_map"
+ config(_headers_map_config) {
+ include_dirs = [ _header_map_filename ]
+ }
+
+ _framework_headers_target = _target_name + "_framework_headers"
+ group(_framework_headers_target) {
+ deps = [
+ ":$_compile_headers_map_target",
+ ":$_copy_public_headers_target",
+ ":$_create_module_map_target",
+ ]
+ }
+ }
+
framework_bundle(target_name) {
- forward_variables_from(invoker, "*")
+ forward_variables_from(invoker, "*", [ "configs" ])
+
+ configs = []
+ if (defined(invoker.configs)) {
+ configs += invoker.configs
+ }
+
+ if (defined(_public_headers)) {
+ configs += [ ":$_headers_map_config" ]
+ deps = [
+ ":$_framework_headers_target",
+ ]
+ }
}
}
« no previous file with comments | « no previous file | build/config/mac/rules.gni » ('j') | build/config/mac/rules.gni » ('J')

Powered by Google App Engine
This is Rietveld 408576698