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

Unified Diff: third_party/WebKit/Source/bindings/scripts/scripts.gni

Issue 2970003002: Add code generation for ConditionalFeatures bindings code (Closed)
Patch Set: Readability fixes Created 3 years, 5 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
Index: third_party/WebKit/Source/bindings/scripts/scripts.gni
diff --git a/third_party/WebKit/Source/bindings/scripts/scripts.gni b/third_party/WebKit/Source/bindings/scripts/scripts.gni
index 9fefa29e601331ce506918801092f702ddc707e1..647c8a13438c5614aaea164f1ff6d2e19d66ac48 100644
--- a/third_party/WebKit/Source/bindings/scripts/scripts.gni
+++ b/third_party/WebKit/Source/bindings/scripts/scripts.gni
@@ -434,3 +434,55 @@ template("generate_global_constructors") {
deps = invoker.deps
}
}
+
+# Calls the generate_conditional_features script.
+#
+# Parameters:
+# sources = a list of source IDL files.
+# component = component for which to generate conditional feature bindings
+# ("Core" or "Modules")
+# output_dir = output directory to generate cpp file and header file.
+# deps = dependencies
+#
+template("generate_conditional_features") {
+ action(target_name) {
+ script = "//third_party/WebKit/Source/bindings/scripts/generate_conditional_features.py"
+
+ # Write the file list to a unique temp file to avoid blowing out the
+ # command line length limit.
+ idl_files_list = "$target_gen_dir/${target_name}_file_list.tmp"
+ write_file(idl_files_list, rebase_path(invoker.sources, root_build_dir))
+
+ inputs = [
+ "//third_party/WebKit/Source/bindings/scripts/utilities.py",
+ "//third_party/WebKit/Source/bindings/templates/ConditionalFeaturesFor${invoker.component}.cpp.tmpl",
+ "//third_party/WebKit/Source/bindings/templates/ConditionalFeaturesFor${invoker.component}.h.tmpl",
+ idl_files_list,
+ ] + invoker.sources
+
+ args = [
+ "--output-directory",
+ rebase_path(invoker.output_dir, root_build_dir),
+ "--info-dir",
+ "gen/blink/bindings",
+ "--cache-dir",
+ rebase_path(bindings_scripts_output_dir, root_build_dir),
+ "--target-component",
+ invoker.component,
+ "--idl-files-list",
+ rebase_path(idl_files_list, root_build_dir),
+ ]
+
+ outputs = [
+ "${invoker.output_dir}/ConditionalFeaturesFor${invoker.component}.cpp",
+ "${invoker.output_dir}/ConditionalFeaturesFor${invoker.component}.h",
+ ]
+
+ # TODO: This should not always require modules; For core features, this
+ # should be interfaces_info_core (w/o modules). This is the same issue as
+ # above in the idl_compiler template.
+ # http://crbug.com/358074
+ deps = invoker.deps +
+ [ "//third_party/WebKit/Source/bindings/modules:interfaces_info" ]
+ }
+}

Powered by Google App Engine
This is Rietveld 408576698