| # Copyright 2020 The Fuchsia 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("//build/fidl/fidl.gni") |
| import("//sdk/ctf/build/internal/ctf_element.gni") |
| import("//sdk/ctf/build/internal/ctf_version.gni") |
| import("//sdk/ctf/build/internal/write_ctf_file.gni") |
| |
| # Declares a FIDL Library that can be used in CTF. |
| # |
| # An equivalent to fidl.gni, but ensures dependencies are allowed in CTF. |
| template("ctf_fidl") { |
| assert(defined(invoker.sources), "Sources must be defined.") |
| assert(!defined(invoker.deps), "All FIDL dependencies should be public.") |
| |
| invoker_deps = [] |
| if (defined(invoker.public_deps)) { |
| invoker_deps += invoker.public_deps |
| } |
| if (defined(invoker.non_fidl_deps)) { |
| invoker_deps += invoker.non_fidl_deps |
| } |
| |
| if (invoker_deps != [] && cts_version == "") { |
| verify_target = target_name + "_verify_deps" |
| } |
| write_file_target = target_name + "_ctf_file" |
| |
| # This will only end up being referenced in the FIDL toolchain (as a dep to |
| # the action which runs fidlc), so we only need to define it in there. |
| if (defined(verify_target) && current_toolchain == fidl_toolchain) { |
| ctf_element(verify_target) { |
| deps_to_verify = invoker_deps |
| invoker_label = |
| get_label_info(":${invoker.target_name}", "label_no_toolchain") |
| } |
| } |
| |
| write_ctf_file(write_file_target) { |
| } |
| |
| fidl(target_name) { |
| forward_variables_from(invoker, "*") |
| if (!defined(non_fidl_deps)) { |
| non_fidl_deps = [] |
| } |
| |
| if (defined(verify_target)) { |
| non_fidl_deps += [ ":$verify_target" ] |
| } |
| non_fidl_deps += [ ":$write_file_target" ] |
| } |
| } |