From 4fb81dd42d2ed06bf71beeec3af0f4645e09dfc6 Mon Sep 17 00:00:00 2001 From: Greg Magolan Date: Mon, 30 Sep 2019 12:26:05 -0700 Subject: [PATCH] feat(typescript): add JSNamedModuleInfo provider to ts_library outputs All rules that require devmode named sources are updated to use JSNamedModuleInfo. The rules affected are karma, protractor, ts_devserver, ts_proto_library (in labs) & npm_package. BREAKING CHANGES: The following breaking changes are from internal details so they should not affect most users, however, some downstream projects such as Angular rely on these and will need to be updated accordingly when updating to the next release. * `sources_aspect` from `/internal/node/node.bzl` and `/internal/common/sources_aspect.bzl` is removed; its functionality was duplicate to what JSNamedModuleInfo providers * NodeModuleSources is removed and its `sources` field is moved to NodeModuleInfo; sources in the `scripts` field are now provided by JSNamedModuleInfo * node_module_library `scripts` attribute renamed to `named_sources` * `collect_node_modules_aspect` renamed to just `node_modules_aspect` --- internal/common/devmode_js_sources.bzl | 26 ++++--- internal/common/node_module_info.bzl | 73 +++++++------------ internal/common/sources_aspect.bzl | 61 ---------------- internal/linker/link_node_modules.bzl | 6 +- internal/node.bzl | 2 - internal/node/node.bzl | 29 +++++--- internal/node/npm_package_bin.bzl | 16 +++- internal/npm_install/generate_build_file.js | 16 ++-- internal/npm_install/generate_build_file.ts | 14 ++-- internal/npm_install/node_module_library.bzl | 38 +++++----- internal/npm_install/npm_umd_bundle.bzl | 6 +- .../golden/@angular/core/BUILD.bazel.golden | 2 +- internal/npm_package/npm_package.bzl | 40 +++++----- internal/npm_package/test/BUILD.bazel | 9 +-- internal/npm_package/test/foo.d.ts | 1 - internal/npm_package/test/foo.js | 1 - internal/npm_package/test/foo.ts | 1 + internal/npm_package/test/npm_package.spec.js | 4 +- internal/rollup/rollup_bundle.bzl | 21 +++--- packages/jasmine/docs/BUILD.bazel | 1 + packages/karma/docs/BUILD.bazel | 1 + packages/karma/src/karma_web_test.bzl | 72 ++++++++++-------- packages/karma/src/web_test.bzl | 4 +- .../labs/src/protobufjs/ts_proto_library.bzl | 5 +- packages/protractor/docs/BUILD.bazel | 1 + .../protractor/src/protractor_web_test.bzl | 68 ++++++++++------- .../protractor/test/protractor-2/BUILD.bazel | 11 ++- .../typescript/src/internal/build_defs.bzl | 30 ++++---- .../src/internal/devserver/ts_devserver.bzl | 37 ++++++---- .../devmode_consumer/devmode_consumer.bzl | 21 +++--- providers.bzl | 45 ++++++++++++ 31 files changed, 345 insertions(+), 317 deletions(-) delete mode 100644 internal/common/sources_aspect.bzl delete mode 100644 internal/npm_package/test/foo.d.ts delete mode 100644 internal/npm_package/test/foo.js create mode 100644 internal/npm_package/test/foo.ts diff --git a/internal/common/devmode_js_sources.bzl b/internal/common/devmode_js_sources.bzl index f19d32b7c5..8c5b348f69 100644 --- a/internal/common/devmode_js_sources.bzl +++ b/internal/common/devmode_js_sources.bzl @@ -17,7 +17,7 @@ Outputs a manifest file with the sources listed. """ -load(":sources_aspect.bzl", "sources_aspect") +load("@build_bazel_rules_nodejs//:providers.bzl", "JSNamedModuleInfo") # Avoid using non-normalized paths (workspace/../other_workspace/path) def _to_manifest_path(ctx, file): @@ -27,26 +27,30 @@ def _to_manifest_path(ctx, file): return ctx.workspace_name + "/" + file.short_path def _devmode_js_sources_impl(ctx): - files = depset() - - for d in ctx.attr.deps: - if hasattr(d, "node_sources"): - files = depset(transitive = [files, d.node_sources]) - elif hasattr(d, "files"): - files = depset(transitive = [files, d.files]) + sources_depsets = [] + for dep in ctx.attr.deps: + if JSNamedModuleInfo in dep: + sources_depsets.append(dep[JSNamedModuleInfo].sources) + if hasattr(dep, "files"): + sources_depsets.append(dep.files) + sources = depset(transitive = sources_depsets) ctx.actions.write(ctx.outputs.manifest, "".join([ _to_manifest_path(ctx, f) + "\n" - for f in files.to_list() + for f in sources.to_list() + if f.path.endswith(".js") or f.path.endswith(".mjs") ])) - return [DefaultInfo(files = files)] + + return [DefaultInfo( + files = sources, + runfiles = ctx.runfiles(transitive_files = sources), + )] devmode_js_sources = rule( implementation = _devmode_js_sources_impl, attrs = { "deps": attr.label_list( allow_files = True, - aspects = [sources_aspect], ), }, outputs = { diff --git a/internal/common/node_module_info.bzl b/internal/common/node_module_info.bzl index 044daed558..4f5cc8f95c 100644 --- a/internal/common/node_module_info.bzl +++ b/internal/common/node_module_info.bzl @@ -12,63 +12,40 @@ # See the License for the specific language governing permissions and # limitations under the License. -"""NodeModuleInfo & NodeModuleSources providers and apsect to collect node_modules from deps. +"""NodeModuleInfo providers and apsect to collect node_modules from deps. """ -# NodeModuleInfo provider is only provided by targets that are npm dependencies by the -# `node_module_library` rule. This provider is currently used by different rules to filter out -# npm dependencies such as -# ``` -# [d for d in ctx.attr.deps if not NodeModuleInfo in d] -# ``` -# in `packages/typescript/internal/build_defs.bzl` or -# ``` -# hasattr(target, "files") and not NodeModuleInfo in target: -# ``` -# in `internal/common/sources_aspect.bzl`. -# Similar filtering is done in downstream repositories such as angular/angular so this provider -# needs to go through a deprecation period before it can be phased out. -NodeModuleInfo = provider( - doc = "Provides information about npm dependencies installed with yarn_install and npm_install rules", - fields = { - "workspace": "The workspace name that the npm dependencies are provided from", - }, -) - -# NodeModuleSources provider is provided by targets that are npm dependencies by the +# NodeModuleInfo provider is provided by targets that are npm dependencies by the # `node_module_library` rule as well as other targets that have direct or transitive deps on -# `node_module_library` targets via the `collect_node_modules_aspect` below. -# TODO: rename to NodeModuleSourcesInfo so name doesn't trigger name-conventions warning -# buildozer: disable=name-conventions -NodeModuleSources = provider( - doc = "Provides sources for npm dependencies installed with yarn_install and npm_install rules", +# `node_module_library` targets via the `node_modules_aspect` below. +NodeModuleInfo = provider( + doc = "Provides information about npm dependencies", fields = { - "scripts": "Source files that are javascript named-UMD or named-AMD modules for use in rules such as ts_devserver", - "sources": "Source files that are npm dependencies", + "sources": "Source files that are direct & transitive npm depedendencies", "workspace": "The workspace name that the npm dependencies are provided from", }, ) -def _collect_node_modules_aspect_impl(target, ctx): - nm_wksp = None - - if NodeModuleSources in target: - return [] +def _node_modules_aspect_impl(target, ctx): + providers = [] - if hasattr(ctx.rule.attr, "deps"): + # provide NodeModuleInfo if it is not already provided there are NodeModuleInfo deps + if not NodeModuleInfo in target: sources = depset() - for dep in ctx.rule.attr.deps: - if NodeModuleSources in dep: - if nm_wksp and dep[NodeModuleSources].workspace != nm_wksp: - fail("All npm dependencies need to come from a single workspace. Found '%s' and '%s'." % (nm_wksp, dep[NodeModuleSources].workspace)) - nm_wksp = dep[NodeModuleSources].workspace - sources = depset(transitive = [dep[NodeModuleSources].sources, sources]) - if sources: - return [NodeModuleSources(sources = sources, workspace = nm_wksp)] - - return [] - -collect_node_modules_aspect = aspect( - implementation = _collect_node_modules_aspect_impl, + nm_wksp = None + if hasattr(ctx.rule.attr, "deps"): + for dep in ctx.rule.attr.deps: + if NodeModuleInfo in dep: + if nm_wksp and dep[NodeModuleInfo].workspace != nm_wksp: + fail("All npm dependencies need to come from a single workspace. Found '%s' and '%s'." % (nm_wksp, dep[NodeModuleInfo].workspace)) + nm_wksp = dep[NodeModuleInfo].workspace + sources = depset(transitive = [dep[NodeModuleInfo].sources, sources]) + if nm_wksp: + providers.extend([NodeModuleInfo(sources = sources, workspace = nm_wksp)]) + + return providers + +node_modules_aspect = aspect( + _node_modules_aspect_impl, attr_aspects = ["deps"], ) diff --git a/internal/common/sources_aspect.bzl b/internal/common/sources_aspect.bzl deleted file mode 100644 index 2da1c284ed..0000000000 --- a/internal/common/sources_aspect.bzl +++ /dev/null @@ -1,61 +0,0 @@ -# Copyright 2017 The Bazel Authors. All rights reserved. -# -# Licensed under the Apache License, Version 2.0 (the "License"); -# you may not use this file except in compliance with the License. -# You may obtain a copy of the License at -# -# http://www.apache.org/licenses/LICENSE-2.0 -# -# Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -# See the License for the specific language governing permissions and -# limitations under the License. - -"""Aspect to collect es5 js sources and scripts from deps. -""" - -load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleInfo", "NodeModuleSources") - -def _sources_aspect_impl(target, ctx): - # TODO(kyliau): node_sources here is a misnomer because it implies that - # the sources have got something to do with node modules. In fact, - # node_sources collects es5 output from typescript and "javascript-like" - # targets that are *not* node modules. This name is kept as-is to maintain - # compatibility with existing rules but should be renamed and cleaned up. - node_sources = depset() - - # dev_scripts is a collection of "scripts" from "node-module-like" targets - # such as `node_module_library` - dev_scripts = depset() - - # Note layering: until we have JS interop providers, this needs to know how to - # get TypeScript outputs. - if hasattr(target, "typescript"): - node_sources = depset(transitive = [node_sources, target.typescript.es5_sources]) - elif hasattr(target, "files") and not NodeModuleInfo in target: - # Sources from npm fine grained deps should not be included - node_sources = depset( - [f for f in target.files.to_list() if f.path.endswith(".js")], - transitive = [node_sources], - ) - - if NodeModuleSources in target: - dev_scripts = depset(target[NodeModuleSources].scripts) - - if hasattr(ctx.rule.attr, "deps"): - for dep in ctx.rule.attr.deps: - if hasattr(dep, "node_sources"): - node_sources = depset(transitive = [node_sources, dep.node_sources]) - if hasattr(dep, "dev_scripts"): - dev_scripts = depset(transitive = [dev_scripts, dep.dev_scripts]) - - return struct( - node_sources = node_sources, - dev_scripts = dev_scripts, - ) - -sources_aspect = aspect( - _sources_aspect_impl, - attr_aspects = ["deps"], -) diff --git a/internal/linker/link_node_modules.bzl b/internal/linker/link_node_modules.bzl index ef49e99902..d974c6c26b 100644 --- a/internal/linker/link_node_modules.bzl +++ b/internal/linker/link_node_modules.bzl @@ -10,7 +10,7 @@ linker, which uses the mappings to link a node_modules directory for runtimes to locate all the first-party packages. """ -load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleSources") +load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleInfo") def _debug(vars, *args): if "VERBOSE_LOGS" in vars.keys(): @@ -42,8 +42,8 @@ def register_node_modules_linker(ctx, args, inputs): # Look through data/deps attributes to find... for dep in getattr(ctx.attr, "data", []) + getattr(ctx.attr, "deps", []): # ...the root directory for the third-party node_modules; we'll symlink the local "node_modules" to it - if NodeModuleSources in dep: - possible_root = "/".join([dep[NodeModuleSources].workspace, "node_modules"]) + if NodeModuleInfo in dep: + possible_root = "/".join([dep[NodeModuleInfo].workspace, "node_modules"]) if not node_modules_root: node_modules_root = possible_root elif node_modules_root != possible_root: diff --git a/internal/node.bzl b/internal/node.bzl index c8115f6f82..cd80d47fdf 100644 --- a/internal/node.bzl +++ b/internal/node.bzl @@ -23,7 +23,5 @@ load( "//internal/common:expand_into_runfiles.bzl", _expand_location_into_runfiles = "expand_location_into_runfiles", ) -load("//internal/common:sources_aspect.bzl", _sources_aspect = "sources_aspect") -sources_aspect = _sources_aspect expand_location_into_runfiles = _expand_location_into_runfiles diff --git a/internal/node/node.bzl b/internal/node/node.bzl index 3cb0dd3cd7..462c9bb48d 100644 --- a/internal/node/node.bzl +++ b/internal/node/node.bzl @@ -20,10 +20,11 @@ They support module mapping: any targets in the transitive dependencies with a `module_name` attribute can be `require`d by that name. """ -load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleSources", "collect_node_modules_aspect") +load("@build_bazel_rules_nodejs//:declaration_provider.bzl", "DeclarationInfo") +load("@build_bazel_rules_nodejs//:providers.bzl", "JSNamedModuleInfo") +load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleInfo", "node_modules_aspect") load("//internal/common:expand_into_runfiles.bzl", "expand_location_into_runfiles") load("//internal/common:module_mappings.bzl", "module_mappings_runtime_aspect") -load("//internal/common:sources_aspect.bzl", "sources_aspect") load("//internal/common:windows_utils.bzl", "create_windows_native_launcher_script", "is_windows") def _trim_package_node_modules(package_name): @@ -48,8 +49,8 @@ def _compute_node_modules_root(ctx): """ node_modules_root = None if ctx.attr.node_modules: - if NodeModuleSources in ctx.attr.node_modules: - node_modules_root = "/".join([ctx.attr.node_modules[NodeModuleSources].workspace, "node_modules"]) + if NodeModuleInfo in ctx.attr.node_modules: + node_modules_root = "/".join([ctx.attr.node_modules[NodeModuleInfo].workspace, "node_modules"]) elif ctx.files.node_modules: # ctx.files.node_modules is not an empty list workspace = ctx.attr.node_modules.label.workspace_root.split("/")[1] if ctx.attr.node_modules.label.workspace_root else ctx.workspace_name @@ -59,8 +60,8 @@ def _compute_node_modules_root(ctx): "node_modules", ] if f]) for d in ctx.attr.data: - if NodeModuleSources in d: - possible_root = "/".join([d[NodeModuleSources].workspace, "node_modules"]) + if NodeModuleInfo in d: + possible_root = "/".join([d[NodeModuleInfo].workspace, "node_modules"]) if not node_modules_root: node_modules_root = possible_root elif node_modules_root != possible_root: @@ -130,10 +131,10 @@ def _nodejs_binary_impl(ctx): node_modules = depset(ctx.files.node_modules) # Also include files from npm fine grained deps as inputs. - # These deps are identified by the NodeModuleSources provider. + # These deps are identified by the NodeModuleInfo provider. for d in ctx.attr.data: - if NodeModuleSources in d: - node_modules = depset(transitive = [node_modules, d[NodeModuleSources].sources]) + if NodeModuleInfo in d: + node_modules = depset(transitive = [node_modules, d[NodeModuleInfo].sources]) # Using a depset will allow us to avoid flattening files and sources # inside this loop. This should reduce the performances hits, @@ -141,8 +142,12 @@ def _nodejs_binary_impl(ctx): sources = depset() for d in ctx.attr.data: - if hasattr(d, "node_sources"): - sources = depset(transitive = [sources, d.node_sources]) + if DeclarationInfo in d: + sources = depset(transitive = [sources, d[DeclarationInfo].transitive_declarations]) + + # TODO: switch to JSModuleInfo when it is available + if JSNamedModuleInfo in d: + sources = depset(transitive = [sources, d[JSNamedModuleInfo].sources]) if hasattr(d, "files"): sources = depset(transitive = [sources, d.files]) @@ -262,7 +267,7 @@ _NODEJS_EXECUTABLE_ATTRS = { "data": attr.label_list( doc = """Runtime dependencies which may be loaded during execution.""", allow_files = True, - aspects = [sources_aspect, module_mappings_runtime_aspect, collect_node_modules_aspect], + aspects = [node_modules_aspect, module_mappings_runtime_aspect], ), "default_env_vars": attr.string_list( doc = """Default environment variables that are added to `configuration_env_vars`. diff --git a/internal/node/npm_package_bin.bzl b/internal/node/npm_package_bin.bzl index 3b40f729a8..8ed3904450 100644 --- a/internal/node/npm_package_bin.bzl +++ b/internal/node/npm_package_bin.bzl @@ -1,5 +1,6 @@ "A generic rule to run a tool that appears in node_modules/.bin" +load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleInfo", "node_modules_aspect") load("@build_bazel_rules_nodejs//internal/linker:link_node_modules.bzl", "module_mappings_aspect", "register_node_modules_linker") # Note: this API is chosen to match nodejs_binary @@ -7,7 +8,7 @@ load("@build_bazel_rules_nodejs//internal/linker:link_node_modules.bzl", "module _ATTRS = { "outs": attr.output_list(), "args": attr.string_list(mandatory = True), - "data": attr.label_list(allow_files = True, aspects = [module_mappings_aspect]), + "data": attr.label_list(allow_files = True, aspects = [module_mappings_aspect, node_modules_aspect]), "output_dir": attr.bool(), "tool": attr.label( executable = True, @@ -23,6 +24,17 @@ def _expand_location(ctx, s): s = s.replace("$@", "/".join([ctx.bin_dir.path, ctx.label.package, ctx.attr.name])) return ctx.expand_location(s, targets = ctx.attr.data) +def _inputs(ctx): + inputs_depsets = [] + + # Also include files from npm fine grained deps as inputs. + # These deps are identified by the NodeModuleInfo provider. + for d in ctx.attr.data: + if NodeModuleInfo in d: + # Note: we can't avoid calling .to_list() on sources + inputs_depsets.append(d[NodeModuleInfo].sources) + return depset(ctx.files.data, transitive = inputs_depsets).to_list() + def _impl(ctx): if ctx.attr.output_dir and ctx.attr.outs: fail("Only one of output_dir and outs may be specified") @@ -30,7 +42,7 @@ def _impl(ctx): fail("One of output_dir and outs must be specified") args = ctx.actions.args() - inputs = ctx.files.data[:] + inputs = _inputs(ctx) outputs = [] if ctx.attr.output_dir: outputs = [ctx.actions.declare_directory(ctx.attr.name)] diff --git a/internal/npm_install/generate_build_file.js b/internal/npm_install/generate_build_file.js index cd0a728639..162a1598d5 100644 --- a/internal/npm_install/generate_build_file.js +++ b/internal/npm_install/generate_build_file.js @@ -792,14 +792,14 @@ def _maybe(repo_rule, name, **kwargs): const dtsSources = filterFiles(pkg._files, ['.d.ts']); // TODO(gmagolan): add UMD & AMD scripts to scripts even if not an APF package _but_ only if they // are named? - const scripts = getNgApfScripts(pkg); + const namedSources = getNgApfScripts(pkg); const deps = [pkg].concat(pkg._dependencies.filter(dep => dep !== pkg && !dep._isNested)); - let scriptStarlark = ''; - if (scripts.length) { - scriptStarlark = ` + let namedSourcesStarlark = ''; + if (namedSources.length) { + namedSourcesStarlark = ` # subset of srcs that are javascript named-UMD or named-AMD scripts - scripts = [ - ${scripts.map((f) => `"//:node_modules/${pkg._dir}/${f}",`).join('\n ')} + named_sources = [ + ${namedSources.map((f) => `"//:node_modules/${pkg._dir}/${f}",`).join('\n ')} ],`; } let srcsStarlark = ''; @@ -846,7 +846,7 @@ node_module_library( # circular dependencies errors node_module_library( name = "${pkg._name}__contents", - srcs = [":${pkg._name}__files"],${scriptStarlark} + srcs = [":${pkg._name}__files"],${namedSourcesStarlark} ) # ${pkg._name}__typings is the subset of ${pkg._name}__contents that are declarations @@ -1020,4 +1020,4 @@ node_module_library( `; } }); -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generate_build_file.js","sourceRoot":"","sources":["../../../../../internal/npm_install/generate_build_file.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright 2017 The Bazel Authors. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n *\n * You may obtain a copy of the License at\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * @fileoverview This script generates BUILD.bazel files by analyzing\n * the node_modules folder layed out by yarn or npm. It generates\n * fine grained Bazel `node_module_library` targets for each root npm package\n * and all files for that package and its transitive deps are included\n * in the target. For example, `@<workspace>//jasmine` would\n * include all files in the jasmine npm package and all of its\n * transitive dependencies.\n *\n * nodejs_binary targets are also generated for all `bin` scripts\n * in each package. For example, the `@<workspace>//jasmine/bin:jasmine`\n * target will be generated for the `jasmine` binary in the `jasmine`\n * npm package.\n *\n * Additionally, a `@<workspace>//:node_modules` `node_module_library`\n * is generated that includes all packages under node_modules\n * as well as the .bin folder.\n *\n * This work is based off the fine grained deps concepts in\n * https://github.com/pubref/rules_node developed by @pcj.\n *\n * @see https://docs.google.com/document/d/1AfjHMLVyE_vYwlHSK7k7yW_IIGppSxsQtPm9PTr1xEo\n */\n'use strict';\n\n\nimport * as fs from 'fs';\nimport * as path from 'path';\n\nfunction log_verbose(...m: any[]) {\n  if (!!process.env['VERBOSE_LOGS']) console.error('[generate_build_file.js]', ...m);\n}\n\nconst BUILD_FILE_HEADER = `# Generated file from yarn_install/npm_install rule.\n# See $(bazel info output_base)/external/build_bazel_rules_nodejs/internal/npm_install/generate_build_file.js\n\n# All rules in other repositories can use these targets\npackage(default_visibility = [\"//visibility:public\"])\n\n`\n\nconst args = process.argv.slice(2);\nconst WORKSPACE = args[0];\nconst RULE_TYPE = args[1];\nconst ERROR_ON_BAZEL_FILES = parseInt(args[2]);\nconst LOCK_FILE_LABEL = args[3];\nconst INCLUDED_FILES = args[4] ? args[4].split(',') : [];\nconst DYNAMIC_DEPS = JSON.parse(args[5] || '{}');\n\nif (require.main === module) {\n  main();\n}\n\n/**\n * Create a new directory and any necessary subdirectories\n * if they do not exist.\n */\nfunction mkdirp(p: string) {\n  if (!fs.existsSync(p)) {\n    mkdirp(path.dirname(p));\n    fs.mkdirSync(p);\n  }\n}\n\n/**\n * Writes a file, first ensuring that the directory to\n * write to exists.\n */\nfunction writeFileSync(p: string, content: string) {\n  mkdirp(path.dirname(p));\n  fs.writeFileSync(p, content);\n}\n\n/**\n * Main entrypoint.\n */\nfunction main() {\n  // find all packages (including packages in nested node_modules)\n  const pkgs = findPackages();\n\n  // flatten dependencies\n  flattenDependencies(pkgs);\n\n  // generate Bazel workspaces\n  generateBazelWorkspaces(pkgs)\n\n  // generate all BUILD files\n  generateBuildFiles(pkgs)\n}\n\nmodule.exports = {\n  main,\n  printPackageBin,\n  addDynamicDependencies,\n  printIndexBzl,\n};\n\n/**\n * Generates all build files\n */\nfunction generateBuildFiles(pkgs: Dep[]) {\n  generateRootBuildFile(pkgs.filter(pkg => !pkg._isNested))\n  pkgs.filter(pkg => !pkg._isNested).forEach(pkg => generatePackageBuildFiles(pkg));\n  findScopes().forEach(scope => generateScopeBuildFiles(scope, pkgs));\n}\n\n/**\n * Flattens dependencies on all packages\n */\nfunction flattenDependencies(pkgs: Dep[]) {\n  const pkgsMap = new Map();\n  pkgs.forEach(pkg => pkgsMap.set(pkg._dir, pkg));\n  pkgs.forEach(pkg => flattenPkgDependencies(pkg, pkg, pkgsMap));\n}\n\n/**\n * Handles Bazel files in npm distributions.\n */\nfunction hideBazelFiles(pkg: Dep) {\n  const hasHideBazelFiles = isDirectory('node_modules/@bazel/hide-bazel-files');\n  pkg._files = pkg._files.map(file => {\n    const basename = path.basename(file);\n    const basenameUc = basename.toUpperCase();\n    if (basenameUc === 'BUILD' || basenameUc === 'BUILD.BAZEL') {\n      // If bazel files are detected and there is no @bazel/hide-bazel-files npm\n      // package then error out and suggest adding the package. It is possible to\n      // have bazel BUILD files with the package installed as it's postinstall\n      // step, which hides bazel BUILD files, only runs when the @bazel/hide-bazel-files\n      // is installed and not when new packages are added (via `yarn add`\n      // for example) after the initial install. In this case, however, the repo rule\n      // will re-run as the package.json && lock file has changed so we just\n      // hide the added BUILD files during the repo rule run here since @bazel/hide-bazel-files\n      // was not run.\n      if (!hasHideBazelFiles && ERROR_ON_BAZEL_FILES) {\n        console.error(`npm package '${pkg._dir}' from @${WORKSPACE} ${RULE_TYPE} rule\nhas a Bazel BUILD file '${file}'. Use the @bazel/hide-bazel-files utility to hide these files.\nSee https://github.com/bazelbuild/rules_nodejs/blob/master/packages/hide-bazel-files/README.md\nfor installation instructions.`);\n        process.exit(1);\n      } else {\n        // All Bazel files in the npm distribution should be renamed by\n        // adding a `_` prefix so that file targets don't cross package boundaries.\n        const newFile = path.posix.join(path.dirname(file), `_${basename}`);\n        const srcPath = path.posix.join('node_modules', pkg._dir, file);\n        const dstPath = path.posix.join('node_modules', pkg._dir, newFile);\n        fs.renameSync(srcPath, dstPath);\n        return newFile;\n      }\n    }\n    return file;\n  });\n}\n\n/**\n * Generates the root BUILD file.\n */\nfunction generateRootBuildFile(pkgs: Dep[]) {\n  let exportsStarlark = '';\n  pkgs.forEach(pkg => {pkg._files.forEach(f => {\n                 exportsStarlark += `    \"node_modules/${pkg._dir}/${f}\",\n`;\n               })});\n\n  let srcsStarlark = '';\n  if (pkgs.length) {\n    const list = pkgs.map(pkg => `\"//${pkg._dir}:${pkg._name}__files\",`).join('\\n        ');\n    srcsStarlark = `\n    # direct sources listed for strict deps support\n    srcs = [\n        ${list}\n    ],`;\n  }\n\n  let depsStarlark = '';\n  if (pkgs.length) {\n    const list = pkgs.map(pkg => `\"//${pkg._dir}:${pkg._name}__contents\",`).join('\\n        ');\n    depsStarlark = `\n    # flattened list of direct and transitive dependencies hoisted to root by the package manager\n    deps = [\n        ${list}\n    ],`;\n  }\n\n  let buildFile = BUILD_FILE_HEADER +\n      `load(\"@build_bazel_rules_nodejs//internal/npm_install:node_module_library.bzl\", \"node_module_library\")\n\nexports_files([\n${exportsStarlark}])\n\n# The node_modules directory in one catch-all node_module_library.\n# NB: Using this target may have bad performance implications if\n# there are many files in target.\n# See https://github.com/bazelbuild/bazel/issues/5153.\nnode_module_library(\n    name = \"node_modules\",${srcsStarlark}${depsStarlark}\n)\n\n`\n\n  // Add the manual build file contents if they exists\n  try {\n    buildFile += fs.readFileSync(`manual_build_file_contents`, {encoding: 'utf8'});\n  } catch (e) {\n  }\n\n  writeFileSync('BUILD.bazel', buildFile);\n}\n\n/**\n * Generates all BUILD & bzl files for a package.\n */\nfunction generatePackageBuildFiles(pkg: Dep) {\n  let buildFile = printPackage(pkg);\n\n  const binBuildFile = printPackageBin(pkg);\n  if (binBuildFile.length) {\n    writeFileSync(\n        path.posix.join(pkg._dir, 'bin', 'BUILD.bazel'), BUILD_FILE_HEADER + binBuildFile);\n  }\n\n  const indexFile = printIndexBzl(pkg);\n  if (indexFile.length) {\n    writeFileSync(path.posix.join(pkg._dir, 'index.bzl'), indexFile);\n    buildFile = `${buildFile}\n# For integration testing\nexports_files([\"index.bzl\"])\n`;\n  }\n\n  writeFileSync(path.posix.join(pkg._dir, 'BUILD.bazel'), BUILD_FILE_HEADER + buildFile);\n}\n\n/**\n * Generate install_<workspace_name>.bzl files with function to install each workspace.\n */\nfunction generateBazelWorkspaces(pkgs: Dep[]) {\n  const workspaces: Bag<string> = {};\n\n  for (const pkg of pkgs) {\n    if (!pkg.bazelWorkspaces) {\n      continue;\n    }\n\n    for (const workspace of Object.keys(pkg.bazelWorkspaces)) {\n      // A bazel workspace can only be setup by one npm package\n      if (workspaces[workspace]) {\n        console.error(\n            `Could not setup Bazel workspace ${workspace} requested by npm ` +\n            `package ${pkg._dir}@${pkg.version}. Already setup by ${workspaces[workspace]}`);\n        process.exit(1);\n      }\n\n      generateBazelWorkspace(pkg, workspace);\n\n      // Keep track of which npm package setup this bazel workspace for later use\n      workspaces[workspace] = `${pkg._dir}@${pkg.version}`;\n    }\n  }\n\n  // Finally generate install_bazel_dependencies.bzl\n  generateInstallBazelDependencies(Object.keys(workspaces));\n}\n\n/**\n * Generate install_<workspace>.bzl file with function to install the workspace.\n */\nfunction generateBazelWorkspace(pkg: Dep, workspace: string) {\n  let bzlFile = `# Generated by the yarn_install/npm_install rule\nload(\"@build_bazel_rules_nodejs//internal/copy_repository:copy_repository.bzl\", \"copy_repository\")\n\ndef _maybe(repo_rule, name, **kwargs):\n    if name not in native.existing_rules():\n        repo_rule(name = name, **kwargs)\n`;\n\n  const rootPath = pkg.bazelWorkspaces[workspace].rootPath;\n  if (!rootPath) {\n    console.error(\n        `Malformed bazelWorkspaces attribute in ${pkg._dir}@${pkg.version}. ` +\n        `Missing rootPath for workspace ${workspace}.`);\n    process.exit(1);\n  }\n\n  // Copy all files for this workspace to a folder under _workspaces\n  // to restore the Bazel files which have be renamed from the npm package\n  const workspaceSourcePath = path.posix.join('_workspaces', workspace);\n  mkdirp(workspaceSourcePath);\n  pkg._files.forEach(file => {\n    if (/^node_modules[/\\\\]/.test(file)) {\n      // don't copy over nested node_modules\n      return;\n    }\n    let destFile = path.relative(rootPath, file);\n    if (destFile.startsWith('..')) {\n      // this file is not under the rootPath\n      return;\n    }\n    const basename = path.basename(file);\n    const basenameUc = basename.toUpperCase();\n    // Bazel BUILD files from npm distribution would have been renamed earlier with a _ prefix so\n    // we restore the name on the copy\n    if (basenameUc === '_BUILD' || basenameUc === '_BUILD.BAZEL') {\n      destFile = path.posix.join(path.dirname(destFile), basename.substr(1));\n    }\n    const src = path.posix.join('node_modules', pkg._dir, file);\n    const dest = path.posix.join(workspaceSourcePath, destFile);\n    mkdirp(path.dirname(dest));\n    fs.copyFileSync(src, dest);\n  });\n\n  // We create _bazel_workspace_marker that is used by the custom copy_repository\n  // rule to resolve the path to the repository source root. A root BUILD file\n  // is required to reference _bazel_workspace_marker as a target so we also create\n  // an empty one if one does not exist.\n  if (!hasRootBuildFile(pkg, rootPath)) {\n    writeFileSync(\n        path.posix.join(workspaceSourcePath, 'BUILD.bazel'),\n        '# Marker file that this directory is a bazel package');\n  }\n  writeFileSync(\n      path.posix.join(workspaceSourcePath, '_bazel_workspace_marker'),\n      '# Marker file to used by custom copy_repository rule');\n\n  bzlFile += `def install_${workspace}():\n    _maybe(\n        copy_repository,\n        name = \"${workspace}\",\n        marker_file = \"@${WORKSPACE}//_workspaces/${workspace}:_bazel_workspace_marker\",\n        # Ensure that changes to the node_modules cause the copy to re-execute\n        lock_file = \"@${WORKSPACE}${LOCK_FILE_LABEL}\",\n    )\n`;\n\n  writeFileSync(`install_${workspace}.bzl`, bzlFile);\n}\n\n/**\n * Generate install_bazel_dependencies.bzl with function to install all workspaces.\n */\nfunction generateInstallBazelDependencies(workspaces: string[]) {\n  let bzlFile = `# Generated by the yarn_install/npm_install rule\n`;\n  workspaces.forEach(workspace => {\n    bzlFile += `load(\\\":install_${workspace}.bzl\\\", \\\"install_${workspace}\\\")\n`;\n  });\n  bzlFile += `def install_bazel_dependencies():\n    \"\"\"Installs all workspaces listed in bazelWorkspaces of all npm packages\"\"\"\n`;\n  workspaces.forEach(workspace => {\n    bzlFile += `    install_${workspace}()\n`;\n  });\n\n  writeFileSync('install_bazel_dependencies.bzl', bzlFile);\n}\n\n/**\n * Generate build files for a scope.\n */\nfunction generateScopeBuildFiles(scope: string, pkgs: Dep[]) {\n  const buildFile = BUILD_FILE_HEADER + printScope(scope, pkgs);\n  writeFileSync(path.posix.join(scope, 'BUILD.bazel'), buildFile);\n}\n\n/**\n * Checks if a path is a file.\n */\nfunction isFile(p: string) {\n  return fs.existsSync(p) && fs.statSync(p).isFile();\n}\n\n/**\n * Checks if a path is an npm package which is is a directory with a package.json file.\n */\nfunction isDirectory(p: string) {\n  return fs.existsSync(p) && fs.statSync(p).isDirectory();\n}\n\n/**\n * Returns an array of all the files under a directory as relative\n * paths to the directory.\n */\nfunction listFiles(rootDir: string, subDir: string = ''): string[] {\n  const dir = path.posix.join(rootDir, subDir);\n  if (!isDirectory(dir)) {\n    return [];\n  }\n  return fs.readdirSync(dir)\n      .reduce(\n          (files: string[], file) => {\n            const fullPath = path.posix.join(dir, file);\n            const relPath = path.posix.join(subDir, file);\n            const isSymbolicLink = fs.lstatSync(fullPath).isSymbolicLink();\n            let stat;\n            try {\n              stat = fs.statSync(fullPath);\n            } catch (e) {\n              if (isSymbolicLink) {\n                // Filter out broken symbolic links. These cause fs.statSync(fullPath)\n                // to fail with `ENOENT: no such file or directory ...`\n                return files;\n              }\n              throw e;\n            }\n            const isDirectory = stat.isDirectory();\n            if (isDirectory && isSymbolicLink) {\n              // Filter out symbolic links to directories. An issue in yarn versions\n              // older than 1.12.1 creates symbolic links to folders in the .bin folder\n              // which leads to Bazel targets that cross package boundaries.\n              // See https://github.com/bazelbuild/rules_nodejs/issues/428 and\n              // https://github.com/bazelbuild/rules_nodejs/issues/438.\n              // This is tested in /e2e/fine_grained_symlinks.\n              return files;\n            }\n            return isDirectory ? files.concat(listFiles(rootDir, relPath)) : files.concat(relPath);\n          },\n          [])\n      // Files with spaces (\\x20) or unicode characters (<\\x20 && >\\x7E) are not allowed in\n      // Bazel runfiles. See https://github.com/bazelbuild/bazel/issues/4327\n      .filter(f => !/[^\\x21-\\x7E]/.test(f))\n      // We return a sorted array so that the order of files\n      // is the same regardless of platform\n      .sort();\n}\n\n/**\n * Returns true if the npm package distribution contained a\n * root /BUILD or /BUILD.bazel file.\n */\nfunction hasRootBuildFile(pkg: Dep, rootPath: string) {\n  for (const file of pkg._files) {\n    // Bazel files would have been renamed earlier with a `_` prefix\n    const fileUc = path.relative(rootPath, file).toUpperCase();\n    if (fileUc === '_BUILD' || fileUc === '_BUILD.BAZEL') {\n      return true;\n    }\n  }\n  return false;\n}\n\n\nfunction addDynamicDependencies(pkgs: Dep[], dynamic_deps = DYNAMIC_DEPS) {\n  function match(name: string, p: Dep) {\n    // Automatically include dynamic dependency on plugins of the form pkg-plugin-foo\n    if (name.startsWith(`${p._moduleName}-plugin-`)) return true;\n\n    const value = dynamic_deps[p._moduleName];\n    if (name === value) return true;\n\n    // Support wildcard match\n    if (value && value.includes('*') && name.startsWith(value.substring(0, value.indexOf('*')))) {\n      return true;\n    }\n\n    return false;\n  }\n  pkgs.forEach(p => {\n    p._dynamicDependencies = pkgs.filter(x => !!x._moduleName && match(x._moduleName, p))\n                                 .map(dyn => `//${dyn._dir}:${dyn._name}`);\n  });\n}\n\n/**\n * Finds and returns an array of all packages under a given path.\n */\nfunction findPackages(p = 'node_modules') {\n  if (!isDirectory(p)) {\n    return [];\n  }\n\n  const pkgs: Dep[] = [];\n\n  const listing = fs.readdirSync(p);\n\n  const packages = listing\n                       // filter out scopes\n                       .filter(f => !f.startsWith('@'))\n                       // filter out folders such as `.bin` which can create\n                       // issues on Windows since these are \"hidden\" by default\n                       .filter(f => !f.startsWith('.'))\n                       .map(f => path.posix.join(p, f))\n                       .filter(f => isDirectory(f));\n\n  packages.forEach(\n      f => pkgs.push(parsePackage(f), ...findPackages(path.posix.join(f, 'node_modules'))));\n\n  const scopes = listing.filter(f => f.startsWith('@'))\n                     .map(f => path.posix.join(p, f))\n                     .filter(f => isDirectory(f));\n  scopes.forEach(f => pkgs.push(...findPackages(f)));\n\n  addDynamicDependencies(pkgs);\n\n  return pkgs;\n}\n\n/**\n * Finds and returns an array of all package scopes in node_modules.\n */\nfunction findScopes() {\n  const p = 'node_modules';\n  if (!isDirectory(p)) {\n    return [];\n  }\n\n  const listing = fs.readdirSync(p);\n\n  const scopes = listing.filter(f => f.startsWith('@'))\n                     .map(f => path.posix.join(p, f))\n                     .filter(f => isDirectory(f))\n                     .map(f => f.replace(/^node_modules\\//, ''));\n\n  return scopes;\n}\n\n/**\n * Given the name of a top-level folder in node_modules, parse the\n * package json and return it as an object along with\n * some additional internal attributes prefixed with '_'.\n */\nfunction parsePackage(p: string): Dep {\n  // Parse the package.json file of this package\n  const packageJson = path.posix.join(p, 'package.json');\n  const pkg = isFile(packageJson) ? JSON.parse(fs.readFileSync(packageJson, {encoding: 'utf8'})) :\n                                    {version: '0.0.0'};\n\n  // Trim the leading node_modules from the path and\n  // assign to _dir for future use\n  pkg._dir = p.replace(/^node_modules\\//, '');\n\n  // Stash the package directory name for future use\n  pkg._name = pkg._dir.split('/').pop();\n\n  // Module name of the package. Unlike \"_name\" this represents the\n  // full package name (including scope name).\n  pkg._moduleName = pkg.name || `${pkg._dir}/${pkg._name}`;\n\n  // Keep track of whether or not this is a nested package\n  pkg._isNested = /\\/node_modules\\//.test(p);\n\n  // List all the files in the npm package for later use\n  pkg._files = listFiles(p);\n\n  // Initialize _dependencies to an empty array\n  // which is later filled with the flattened dependency list\n  pkg._dependencies = [];\n\n  // Hide bazel files in this package. We do this before parsing\n  // the next package to prevent issues caused by symlinks between\n  // package and nested packages setup by the package manager.\n  hideBazelFiles(pkg);\n\n  return pkg;\n}\n\n/**\n * Check if a bin entry is a non-empty path\n */\nfunction isValidBinPath(entry: any) {\n  return isValidBinPathStringValue(entry) || isValidBinPathObjectValues(entry);\n}\n\n/**\n * If given a string, check if a bin entry is a non-empty path\n */\nfunction isValidBinPathStringValue(entry: any) {\n  return typeof entry === 'string' && entry !== '';\n}\n\n/**\n * If given an object literal, check if a bin entry objects has at least one a non-empty path\n * Example 1: { entry: './path/to/script.js' } ==> VALID\n * Example 2: { entry: '' } ==> INVALID\n * Example 3: { entry: './path/to/script.js', empty: '' } ==> VALID\n */\nfunction isValidBinPathObjectValues(entry: Bag<string>): boolean {\n  // We allow at least one valid entry path (if any).\n  return entry && typeof entry === 'object' &&\n      Object['values'](entry).filter(_entry => isValidBinPath(_entry)).length > 0;\n}\n\n/**\n * Cleanup a package.json \"bin\" path.\n *\n * Bin paths usually come in 2 flavors: './bin/foo' or 'bin/foo',\n * sometimes other stuff like 'lib/foo'.  Remove prefix './' if it\n * exists.\n */\nfunction cleanupBinPath(p: string) {\n  p = p.replace(/\\\\/g, '/');\n  if (p.indexOf('./') === 0) {\n    p = p.slice(2);\n  }\n  return p;\n}\n\n/**\n * Cleanup a package.json entry point such as \"main\"\n *\n * Removes './' if it exists.\n * Appends `index.js` if p ends with `/`.\n */\nfunction cleanupEntryPointPath(p: string) {\n  p = p.replace(/\\\\/g, '/');\n  if (p.indexOf('./') === 0) {\n    p = p.slice(2);\n  }\n  if (p.endsWith('/')) {\n    p += 'index.js';\n  }\n  return p;\n}\n\n/**\n * Cleans up the given path\n * Then tries to resolve the path into a file and warns if VERBOSE_LOGS set and the file dosen't\n * exist\n * @param {any} pkg\n * @param {string} path\n * @returns {string | undefined}\n */\nfunction findEntryFile(pkg: Dep, path: string) {\n  const cleanPath = cleanupEntryPointPath(path);\n  // check if main entry point exists\n  const entryFile = findFile(pkg, cleanPath) || findFile(pkg, `${cleanPath}.js`);\n  if (!entryFile) {\n    // If entryPoint entry point listed could not be resolved to a file\n    // This can happen\n    // in some npm packages that list an incorrect main such as v8-coverage@1.0.8\n    // which lists `\"main\": \"index.js\"` but that file does not exist.\n    log_verbose(\n        `could not find entry point for the path ${cleanPath} given by npm package ${pkg._name}`);\n  }\n  return entryFile;\n}\n\n/**\n * Tries to resolve the entryPoint file from the pkg for a given mainFileName\n *\n * @param {any} pkg\n * @param {'browser' | 'module' | 'main'} mainFileName\n * @returns {string | undefined} the path or undefined if we cant resolve the file\n */\nfunction resolveMainFile(pkg: Dep, mainFileName: string) {\n  const mainEntryField = pkg[mainFileName];\n\n  if (mainEntryField) {\n    if (typeof mainEntryField === 'string') {\n      return findEntryFile(pkg, mainEntryField)\n\n    } else if (typeof mainEntryField === 'object' && mainFileName === 'browser') {\n      // browser has a weird way of defining this\n      // the browser value is an object listing files to alias, usually pointing to a browser dir\n      const indexEntryPoint = mainEntryField['index.js'] || mainEntryField['./index.js'];\n      if (indexEntryPoint) {\n        return findEntryFile(pkg, indexEntryPoint)\n      }\n    }\n  }\n}\n\n/**\n * Tries to resolve the mainFile from a given pkg\n * This uses seveal mainFileNames in priority to find a correct usable file\n * @param {any} pkg\n * @returns {string | undefined}\n */\nfunction resolvePkgMainFile(pkg: Dep) {\n  // es2015 is another option for mainFile here\n  // but its very uncommon and im not sure what priority it takes\n  //\n  // this list is ordered, we try resolve `browser` first, then `module` and finally fall back to\n  // `main`\n  const mainFileNames = ['browser', 'module', 'main']\n\n      for (const mainFile of mainFileNames) {\n    const resolvedMainFile = resolveMainFile(pkg, mainFile);\n    if (resolvedMainFile) {\n      return resolvedMainFile;\n    }\n  }\n\n  // if we cant find any correct file references from the pkg\n  // then we just try looking around for common patterns\n  const maybeRootIndex = findEntryFile(pkg, 'index.js');\n  if (maybeRootIndex) {\n    return maybeRootIndex\n  }\n\n  const maybeSelfNamedIndex = findEntryFile(pkg, `${pkg._name}.js`);\n  if (maybeSelfNamedIndex) {\n    return maybeSelfNamedIndex;\n  }\n\n  // none of the methods we tried resulted in a file\n  log_verbose(`could not find entry point for npm package ${pkg._name}`);\n\n  // at this point there's nothing left for us to try, so return nothing\n  return undefined;\n}\n\ntype Bag<T> =\n    {\n      [k: string]: T\n    }\n\n/**\n * Flattens all transitive dependencies of a package\n * into a _dependencies array.\n */\nfunction flattenPkgDependencies(pkg: Dep, dep: Dep, pkgsMap: Map<string, Dep>) {\n  if (pkg._dependencies.indexOf(dep) !== -1) {\n    // circular dependency\n    return;\n  }\n  pkg._dependencies.push(dep);\n  const findDeps = function(targetDeps: Bag<string>, required: boolean, depType: string) {\n    Object.keys(targetDeps || {})\n        .map(targetDep => {\n          // look for matching nested package\n          const dirSegments = dep._dir.split('/');\n          while (dirSegments.length) {\n            const maybe = path.posix.join(...dirSegments, 'node_modules', targetDep);\n            if (pkgsMap.has(maybe)) {\n              return pkgsMap.get(maybe);\n            }\n            dirSegments.pop();\n          }\n          // look for matching root package\n          if (pkgsMap.has(targetDep)) {\n            return pkgsMap.get(targetDep);\n          }\n          // dependency not found\n          if (required) {\n            console.error(`could not find ${depType} '${targetDep}' of '${dep._dir}'`);\n            process.exit(1);\n          }\n          return null;\n        })\n        .filter(dep => !!dep)\n        .forEach(dep => flattenPkgDependencies(pkg, dep!, pkgsMap));\n  };\n  // npm will in some cases add optionalDependencies to the list\n  // of dependencies to the package.json it writes to node_modules.\n  // We delete these here if they exist as they may result\n  // in expected dependencies that are not found.\n  if (dep.dependencies && dep.optionalDependencies) {\n    Object.keys(dep.optionalDependencies).forEach(optionalDep => {\n      delete dep.dependencies[optionalDep];\n    });\n  }\n\n  findDeps(dep.dependencies, true, 'dependency');\n  findDeps(dep.peerDependencies, true, 'peer dependency');\n  // `optionalDependencies` that are missing should be silently\n  // ignored since the npm/yarn will not fail if these dependencies\n  // fail to install. Packages should handle the cases where these\n  // dependencies are missing gracefully at runtime.\n  // An example of this is the `chokidar` package which specifies\n  // `fsevents` as an optionalDependency. On OSX, `fsevents`\n  // is installed successfully, but on Windows & Linux, `fsevents`\n  // fails to install and the package will not be present when\n  // checking the dependencies of `chokidar`.\n  findDeps(dep.optionalDependencies, false, 'optional dependency');\n}\n\n/**\n * Reformat/pretty-print a json object as a skylark comment (each line\n * starts with '# ').\n */\nfunction printJson(pkg: Dep) {\n  // Clone and modify _dependencies to avoid circular issues when JSONifying\n  // & delete _files array\n  const cloned: any = {...pkg};\n  cloned._dependencies = pkg._dependencies.map(dep => dep._dir);\n  delete cloned._files;\n  return JSON.stringify(cloned, null, 2).split('\\n').map(line => `# ${line}`).join('\\n');\n}\n\n/**\n * A filter function for files in an npm package. Comparison is case-insensitive.\n * @param files array of files to filter\n * @param exts list of white listed case-insensitive extensions; if empty, no filter is\n *             done on extensions; '' empty string denotes to allow files with no extensions,\n *             other extensions are listed with '.ext' notation such as '.d.ts'.\n */\nfunction filterFiles(files: string[], exts: string[] = []) {\n  if (exts.length) {\n    const allowNoExts = exts.includes('');\n    files = files.filter(f => {\n      // include files with no extensions if noExt is true\n      if (allowNoExts && !path.extname(f)) return true;\n      // filter files in exts\n      const lc = f.toLowerCase();\n      for (const e of exts) {\n        if (e && lc.endsWith(e.toLowerCase())) {\n          return true;\n        }\n      }\n      return false;\n    })\n  }\n  // Filter out BUILD files that came with the npm package\n  return files.filter(file => {\n    const basenameUc = path.basename(file).toUpperCase();\n    if (basenameUc === '_BUILD' || basenameUc === '_BUILD.BAZEL') {\n      return false;\n    }\n    return true;\n  });\n}\n\n/**\n * Returns true if the specified `pkg` conforms to Angular Package Format (APF),\n * false otherwise. If the package contains `*.metadata.json` and a\n * corresponding sibling `.d.ts` file, then the package is considered to be APF.\n */\nfunction isNgApfPackage(pkg: Dep) {\n  const set = new Set(pkg._files);\n  if (set.has('ANGULAR_PACKAGE')) {\n    // This file is used by the npm/yarn_install rule to detect APF. See\n    // https://github.com/bazelbuild/rules_nodejs/issues/927\n    return true;\n  }\n  const metadataExt = /\\.metadata\\.json$/;\n  return pkg._files.some((file) => {\n    if (metadataExt.test(file)) {\n      const sibling = file.replace(metadataExt, '.d.ts');\n      if (set.has(sibling)) {\n        return true;\n      }\n    }\n    return false;\n  });\n}\n\n/**\n * If the package is in the Angular package format returns list\n * of package files that end with `.umd.js`, `.ngfactory.js` and `.ngsummary.js`.\n */\nfunction getNgApfScripts(pkg: Dep) {\n  return isNgApfPackage(pkg) ?\n      filterFiles(pkg._files, ['.umd.js', '.ngfactory.js', '.ngsummary.js']) :\n      [];\n}\n\n/**\n * Looks for a file within a package and returns it if found.\n */\nfunction findFile(pkg: Dep, m: string) {\n  const ml = m.toLowerCase();\n  for (const f of pkg._files) {\n    if (f.toLowerCase() === ml) {\n      return f;\n    }\n  }\n  return undefined;\n}\n\n/**\n * Given a pkg, return the skylark `node_module_library` targets for the package.\n */\nfunction printPackage(pkg: Dep) {\n  const sources = filterFiles(pkg._files, INCLUDED_FILES);\n  const dtsSources = filterFiles(pkg._files, ['.d.ts']);\n  // TODO(gmagolan): add UMD & AMD scripts to scripts even if not an APF package _but_ only if they\n  // are named?\n  const scripts = getNgApfScripts(pkg);\n  const deps = [pkg].concat(pkg._dependencies.filter(dep => dep !== pkg && !dep._isNested));\n\n  let scriptStarlark = '';\n  if (scripts.length) {\n    scriptStarlark = `\n    # subset of srcs that are javascript named-UMD or named-AMD scripts\n    scripts = [\n        ${scripts.map((f: string) => `\"//:node_modules/${pkg._dir}/${f}\",`).join('\\n        ')}\n    ],`;\n  }\n\n  let srcsStarlark = '';\n  if (sources.length) {\n    srcsStarlark = `\n    # ${pkg._dir} package files (and files in nested node_modules)\n    srcs = [\n        ${sources.map((f: string) => `\"//:node_modules/${pkg._dir}/${f}\",`).join('\\n        ')}\n    ],`;\n  }\n\n  let depsStarlark = '';\n  if (deps.length) {\n    const list = deps.map(dep => `\"//${dep._dir}:${dep._name}__contents\",`).join('\\n        ');\n    depsStarlark = `\n    # flattened list of direct and transitive dependencies hoisted to root by the package manager\n    deps = [\n        ${list}\n    ],`;\n  }\n\n  let dtsStarlark = '';\n  if (dtsSources.length) {\n    dtsStarlark = `\n    # ${pkg._dir} package declaration files (and declaration files in nested node_modules)\n    srcs = [\n        ${dtsSources.map(f => `\"//:node_modules/${pkg._dir}/${f}\",`).join('\\n        ')}\n    ],`;\n  }\n\n  let result =\n      `load(\"@build_bazel_rules_nodejs//internal/npm_install:node_module_library.bzl\", \"node_module_library\")\n\n# Generated targets for npm package \"${pkg._dir}\"\n${printJson(pkg)}\n\nfilegroup(\n    name = \"${pkg._name}__files\",${srcsStarlark}\n)\n\nnode_module_library(\n    name = \"${pkg._name}\",\n    # direct sources listed for strict deps support\n    srcs = [\":${pkg._name}__files\"],${depsStarlark}\n)\n\n# ${pkg._name}__contents target is used as dep for main targets to prevent\n# circular dependencies errors\nnode_module_library(\n    name = \"${pkg._name}__contents\",\n    srcs = [\":${pkg._name}__files\"],${scriptStarlark}\n)\n\n# ${pkg._name}__typings is the subset of ${pkg._name}__contents that are declarations\nnode_module_library(\n    name = \"${pkg._name}__typings\",${dtsStarlark}\n)\n\n`;\n\n  let mainEntryPoint = resolvePkgMainFile(pkg)\n\n  // add an `npm_umd_bundle` target to generate an UMD bundle if one does\n  // not exists\n  if (mainEntryPoint && !findFile(pkg, `${pkg._name}.umd.js`)) {\n    result +=\n        `load(\"@build_bazel_rules_nodejs//internal/npm_install:npm_umd_bundle.bzl\", \"npm_umd_bundle\")\n\nnpm_umd_bundle(\n    name = \"${pkg._name}__umd\",\n    package_name = \"${pkg._name}\",\n    entry_point = \"//:node_modules/${pkg._dir}/${mainEntryPoint}\",\n    package = \":${pkg._name}\",\n)\n\n`;\n  }\n\n  return result;\n}\n\nfunction _findExecutables(pkg: Dep) {\n  const executables = new Map();\n\n  // For root packages, transform the pkg.bin entries\n  // into a new Map called _executables\n  // NOTE: we do this only for non-empty bin paths\n  if (isValidBinPath(pkg.bin)) {\n    if (!pkg._isNested) {\n      if (Array.isArray(pkg.bin)) {\n        if (pkg.bin.length == 1) {\n          executables.set(pkg._dir, cleanupBinPath(pkg.bin[0]));\n        } else {\n          // should not happen, but ignore it if present\n        }\n      } else if (typeof pkg.bin === 'string') {\n        executables.set(pkg._dir, cleanupBinPath(pkg.bin));\n      } else if (typeof pkg.bin === 'object') {\n        for (let key in pkg.bin) {\n          if (isValidBinPathStringValue(pkg.bin[key])) {\n            executables.set(key, cleanupBinPath(pkg.bin[key]));\n          }\n        }\n      }\n    }\n  }\n\n  return executables;\n}\n\n// Handle additionalAttributes of format:\n// ```\n// \"bazelBin\": {\n//   \"ngc-wrapped\": {\n//     \"additionalAttributes\": {\n//       \"configuration_env_vars\": \"[\\\"compile\\\"]\"\n//   }\n// },\n// ```\nfunction additionalAttributes(pkg: Dep, name: string) {\n  let additionalAttributes = '';\n  if (pkg.bazelBin && pkg.bazelBin[name] && pkg.bazelBin[name].additionalAttributes) {\n    const attrs = pkg.bazelBin[name].additionalAttributes;\n    for (const attrName of Object.keys(attrs)) {\n      const attrValue = attrs[attrName];\n      additionalAttributes += `\\n    ${attrName} = ${attrValue},`;\n    }\n  }\n  return additionalAttributes;\n}\n\n/**\n * Given a pkg, return the skylark nodejs_binary targets for the package.\n */\nfunction printPackageBin(pkg: Dep) {\n  let result = '';\n  const executables = _findExecutables(pkg);\n  if (executables.size) {\n    result = `load(\"@build_bazel_rules_nodejs//:index.bzl\", \"nodejs_binary\")\n\n`;\n    const data = [`//${pkg._dir}:${pkg._name}`];\n    if (pkg._dynamicDependencies) {\n      data.push(...pkg._dynamicDependencies);\n    }\n\n    for (const [name, path] of executables.entries()) {\n      result += `# Wire up the \\`bin\\` entry \\`${name}\\`\nnodejs_binary(\n    name = \"${name}\",\n    entry_point = \"//:node_modules/${pkg._dir}/${path}\",\n    install_source_map_support = False,\n    data = [${data.map(p => `\"${p}\"`).join(', ')}],${additionalAttributes(pkg, name)}\n)\n\n`;\n    }\n  }\n\n  return result;\n}\n\nfunction printIndexBzl(pkg: Dep) {\n  let result = '';\n  const executables = _findExecutables(pkg);\n  if (executables.size) {\n    result = `load(\"@build_bazel_rules_nodejs//:index.bzl\", \"nodejs_binary\", \"npm_package_bin\")\n\n`;\n    const data = [`@${WORKSPACE}//${pkg._dir}:${pkg._name}`];\n    if (pkg._dynamicDependencies) {\n      data.push(...pkg._dynamicDependencies);\n    }\n\n    for (const [name, path] of executables.entries()) {\n      result = `${result}\n\n# Generated helper macro to call ${name}\ndef ${name.replace(/-/g, '_')}(**kwargs):\n    output_dir = kwargs.pop(\"output_dir\", False)\n    if \"outs\" in kwargs or output_dir:\n        npm_package_bin(tool = \"@${WORKSPACE}//${pkg._dir}/bin:${\n          name}\", output_dir = output_dir, **kwargs)\n    else:\n        nodejs_binary(\n            entry_point = \"@${WORKSPACE}//:node_modules/${pkg._dir}/${path}\",\n            install_source_map_support = False,\n            data = [${data.map(p => `\"${p}\"`).join(', ')}] + kwargs.pop(\"data\", []),${\n          additionalAttributes(pkg, name)}\n            **kwargs\n        )\n  `;\n    }\n  }\n  return result;\n}\n\ntype Dep = {\n  _dir: string,\n  _isNested: boolean,\n  _dependencies: Dep[],\n  _files: string[],\n  [k: string]: any\n}\n\n/**\n * Given a scope, return the skylark `node_module_library` target for the scope.\n */\nfunction printScope(scope: string, pkgs: Dep[]) {\n  pkgs = pkgs.filter(pkg => !pkg._isNested && pkg._dir.startsWith(`${scope}/`));\n  let deps: Dep[] = [];\n  pkgs.forEach(pkg => {\n    deps = deps.concat(pkg._dependencies.filter(dep => !dep._isNested && !pkgs.includes(pkg)));\n  });\n  // filter out duplicate deps\n  deps = [...pkgs, ...new Set(deps)];\n\n  let srcsStarlark = '';\n  if (deps.length) {\n    const list = deps.map(dep => `\"//${dep._dir}:${dep._name}__files\",`).join('\\n        ');\n    srcsStarlark = `\n    # direct sources listed for strict deps support\n    srcs = [\n        ${list}\n    ],`;\n  }\n\n  let depsStarlark = '';\n  if (deps.length) {\n    const list = deps.map(dep => `\"//${dep._dir}:${dep._name}__contents\",`).join('\\n        ');\n    depsStarlark = `\n    # flattened list of direct and transitive dependencies hoisted to root by the package manager\n    deps = [\n        ${list}\n    ],`;\n  }\n\n  return `load(\"@build_bazel_rules_nodejs//internal/npm_install:node_module_library.bzl\", \"node_module_library\")\n\n# Generated target for npm scope ${scope}\nnode_module_library(\n    name = \"${scope}\",${srcsStarlark}${depsStarlark}\n)\n\n`;\n}\n"]} \ No newline at end of file +//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generate_build_file.js","sourceRoot":"","sources":["../../../../../internal/npm_install/generate_build_file.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright 2017 The Bazel Authors. All rights reserved.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n *\n * You may obtain a copy of the License at\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * @fileoverview This script generates BUILD.bazel files by analyzing\n * the node_modules folder layed out by yarn or npm. It generates\n * fine grained Bazel `node_module_library` targets for each root npm package\n * and all files for that package and its transitive deps are included\n * in the target. For example, `@<workspace>//jasmine` would\n * include all files in the jasmine npm package and all of its\n * transitive dependencies.\n *\n * nodejs_binary targets are also generated for all `bin` scripts\n * in each package. For example, the `@<workspace>//jasmine/bin:jasmine`\n * target will be generated for the `jasmine` binary in the `jasmine`\n * npm package.\n *\n * Additionally, a `@<workspace>//:node_modules` `node_module_library`\n * is generated that includes all packages under node_modules\n * as well as the .bin folder.\n *\n * This work is based off the fine grained deps concepts in\n * https://github.com/pubref/rules_node developed by @pcj.\n *\n * @see https://docs.google.com/document/d/1AfjHMLVyE_vYwlHSK7k7yW_IIGppSxsQtPm9PTr1xEo\n */\n'use strict';\n\n\nimport * as fs from 'fs';\nimport * as path from 'path';\n\nfunction log_verbose(...m: any[]) {\n  if (!!process.env['VERBOSE_LOGS']) console.error('[generate_build_file.js]', ...m);\n}\n\nconst BUILD_FILE_HEADER = `# Generated file from yarn_install/npm_install rule.\n# See $(bazel info output_base)/external/build_bazel_rules_nodejs/internal/npm_install/generate_build_file.js\n\n# All rules in other repositories can use these targets\npackage(default_visibility = [\"//visibility:public\"])\n\n`\n\nconst args = process.argv.slice(2);\nconst WORKSPACE = args[0];\nconst RULE_TYPE = args[1];\nconst ERROR_ON_BAZEL_FILES = parseInt(args[2]);\nconst LOCK_FILE_LABEL = args[3];\nconst INCLUDED_FILES = args[4] ? args[4].split(',') : [];\nconst DYNAMIC_DEPS = JSON.parse(args[5] || '{}');\n\nif (require.main === module) {\n  main();\n}\n\n/**\n * Create a new directory and any necessary subdirectories\n * if they do not exist.\n */\nfunction mkdirp(p: string) {\n  if (!fs.existsSync(p)) {\n    mkdirp(path.dirname(p));\n    fs.mkdirSync(p);\n  }\n}\n\n/**\n * Writes a file, first ensuring that the directory to\n * write to exists.\n */\nfunction writeFileSync(p: string, content: string) {\n  mkdirp(path.dirname(p));\n  fs.writeFileSync(p, content);\n}\n\n/**\n * Main entrypoint.\n */\nfunction main() {\n  // find all packages (including packages in nested node_modules)\n  const pkgs = findPackages();\n\n  // flatten dependencies\n  flattenDependencies(pkgs);\n\n  // generate Bazel workspaces\n  generateBazelWorkspaces(pkgs)\n\n  // generate all BUILD files\n  generateBuildFiles(pkgs)\n}\n\nmodule.exports = {\n  main,\n  printPackageBin,\n  addDynamicDependencies,\n  printIndexBzl,\n};\n\n/**\n * Generates all build files\n */\nfunction generateBuildFiles(pkgs: Dep[]) {\n  generateRootBuildFile(pkgs.filter(pkg => !pkg._isNested))\n  pkgs.filter(pkg => !pkg._isNested).forEach(pkg => generatePackageBuildFiles(pkg));\n  findScopes().forEach(scope => generateScopeBuildFiles(scope, pkgs));\n}\n\n/**\n * Flattens dependencies on all packages\n */\nfunction flattenDependencies(pkgs: Dep[]) {\n  const pkgsMap = new Map();\n  pkgs.forEach(pkg => pkgsMap.set(pkg._dir, pkg));\n  pkgs.forEach(pkg => flattenPkgDependencies(pkg, pkg, pkgsMap));\n}\n\n/**\n * Handles Bazel files in npm distributions.\n */\nfunction hideBazelFiles(pkg: Dep) {\n  const hasHideBazelFiles = isDirectory('node_modules/@bazel/hide-bazel-files');\n  pkg._files = pkg._files.map(file => {\n    const basename = path.basename(file);\n    const basenameUc = basename.toUpperCase();\n    if (basenameUc === 'BUILD' || basenameUc === 'BUILD.BAZEL') {\n      // If bazel files are detected and there is no @bazel/hide-bazel-files npm\n      // package then error out and suggest adding the package. It is possible to\n      // have bazel BUILD files with the package installed as it's postinstall\n      // step, which hides bazel BUILD files, only runs when the @bazel/hide-bazel-files\n      // is installed and not when new packages are added (via `yarn add`\n      // for example) after the initial install. In this case, however, the repo rule\n      // will re-run as the package.json && lock file has changed so we just\n      // hide the added BUILD files during the repo rule run here since @bazel/hide-bazel-files\n      // was not run.\n      if (!hasHideBazelFiles && ERROR_ON_BAZEL_FILES) {\n        console.error(`npm package '${pkg._dir}' from @${WORKSPACE} ${RULE_TYPE} rule\nhas a Bazel BUILD file '${file}'. Use the @bazel/hide-bazel-files utility to hide these files.\nSee https://github.com/bazelbuild/rules_nodejs/blob/master/packages/hide-bazel-files/README.md\nfor installation instructions.`);\n        process.exit(1);\n      } else {\n        // All Bazel files in the npm distribution should be renamed by\n        // adding a `_` prefix so that file targets don't cross package boundaries.\n        const newFile = path.posix.join(path.dirname(file), `_${basename}`);\n        const srcPath = path.posix.join('node_modules', pkg._dir, file);\n        const dstPath = path.posix.join('node_modules', pkg._dir, newFile);\n        fs.renameSync(srcPath, dstPath);\n        return newFile;\n      }\n    }\n    return file;\n  });\n}\n\n/**\n * Generates the root BUILD file.\n */\nfunction generateRootBuildFile(pkgs: Dep[]) {\n  let exportsStarlark = '';\n  pkgs.forEach(pkg => {pkg._files.forEach(f => {\n                 exportsStarlark += `    \"node_modules/${pkg._dir}/${f}\",\n`;\n               })});\n\n  let srcsStarlark = '';\n  if (pkgs.length) {\n    const list = pkgs.map(pkg => `\"//${pkg._dir}:${pkg._name}__files\",`).join('\\n        ');\n    srcsStarlark = `\n    # direct sources listed for strict deps support\n    srcs = [\n        ${list}\n    ],`;\n  }\n\n  let depsStarlark = '';\n  if (pkgs.length) {\n    const list = pkgs.map(pkg => `\"//${pkg._dir}:${pkg._name}__contents\",`).join('\\n        ');\n    depsStarlark = `\n    # flattened list of direct and transitive dependencies hoisted to root by the package manager\n    deps = [\n        ${list}\n    ],`;\n  }\n\n  let buildFile = BUILD_FILE_HEADER +\n      `load(\"@build_bazel_rules_nodejs//internal/npm_install:node_module_library.bzl\", \"node_module_library\")\n\nexports_files([\n${exportsStarlark}])\n\n# The node_modules directory in one catch-all node_module_library.\n# NB: Using this target may have bad performance implications if\n# there are many files in target.\n# See https://github.com/bazelbuild/bazel/issues/5153.\nnode_module_library(\n    name = \"node_modules\",${srcsStarlark}${depsStarlark}\n)\n\n`\n\n  // Add the manual build file contents if they exists\n  try {\n    buildFile += fs.readFileSync(`manual_build_file_contents`, {encoding: 'utf8'});\n  } catch (e) {\n  }\n\n  writeFileSync('BUILD.bazel', buildFile);\n}\n\n/**\n * Generates all BUILD & bzl files for a package.\n */\nfunction generatePackageBuildFiles(pkg: Dep) {\n  let buildFile = printPackage(pkg);\n\n  const binBuildFile = printPackageBin(pkg);\n  if (binBuildFile.length) {\n    writeFileSync(\n        path.posix.join(pkg._dir, 'bin', 'BUILD.bazel'), BUILD_FILE_HEADER + binBuildFile);\n  }\n\n  const indexFile = printIndexBzl(pkg);\n  if (indexFile.length) {\n    writeFileSync(path.posix.join(pkg._dir, 'index.bzl'), indexFile);\n    buildFile = `${buildFile}\n# For integration testing\nexports_files([\"index.bzl\"])\n`;\n  }\n\n  writeFileSync(path.posix.join(pkg._dir, 'BUILD.bazel'), BUILD_FILE_HEADER + buildFile);\n}\n\n/**\n * Generate install_<workspace_name>.bzl files with function to install each workspace.\n */\nfunction generateBazelWorkspaces(pkgs: Dep[]) {\n  const workspaces: Bag<string> = {};\n\n  for (const pkg of pkgs) {\n    if (!pkg.bazelWorkspaces) {\n      continue;\n    }\n\n    for (const workspace of Object.keys(pkg.bazelWorkspaces)) {\n      // A bazel workspace can only be setup by one npm package\n      if (workspaces[workspace]) {\n        console.error(\n            `Could not setup Bazel workspace ${workspace} requested by npm ` +\n            `package ${pkg._dir}@${pkg.version}. Already setup by ${workspaces[workspace]}`);\n        process.exit(1);\n      }\n\n      generateBazelWorkspace(pkg, workspace);\n\n      // Keep track of which npm package setup this bazel workspace for later use\n      workspaces[workspace] = `${pkg._dir}@${pkg.version}`;\n    }\n  }\n\n  // Finally generate install_bazel_dependencies.bzl\n  generateInstallBazelDependencies(Object.keys(workspaces));\n}\n\n/**\n * Generate install_<workspace>.bzl file with function to install the workspace.\n */\nfunction generateBazelWorkspace(pkg: Dep, workspace: string) {\n  let bzlFile = `# Generated by the yarn_install/npm_install rule\nload(\"@build_bazel_rules_nodejs//internal/copy_repository:copy_repository.bzl\", \"copy_repository\")\n\ndef _maybe(repo_rule, name, **kwargs):\n    if name not in native.existing_rules():\n        repo_rule(name = name, **kwargs)\n`;\n\n  const rootPath = pkg.bazelWorkspaces[workspace].rootPath;\n  if (!rootPath) {\n    console.error(\n        `Malformed bazelWorkspaces attribute in ${pkg._dir}@${pkg.version}. ` +\n        `Missing rootPath for workspace ${workspace}.`);\n    process.exit(1);\n  }\n\n  // Copy all files for this workspace to a folder under _workspaces\n  // to restore the Bazel files which have be renamed from the npm package\n  const workspaceSourcePath = path.posix.join('_workspaces', workspace);\n  mkdirp(workspaceSourcePath);\n  pkg._files.forEach(file => {\n    if (/^node_modules[/\\\\]/.test(file)) {\n      // don't copy over nested node_modules\n      return;\n    }\n    let destFile = path.relative(rootPath, file);\n    if (destFile.startsWith('..')) {\n      // this file is not under the rootPath\n      return;\n    }\n    const basename = path.basename(file);\n    const basenameUc = basename.toUpperCase();\n    // Bazel BUILD files from npm distribution would have been renamed earlier with a _ prefix so\n    // we restore the name on the copy\n    if (basenameUc === '_BUILD' || basenameUc === '_BUILD.BAZEL') {\n      destFile = path.posix.join(path.dirname(destFile), basename.substr(1));\n    }\n    const src = path.posix.join('node_modules', pkg._dir, file);\n    const dest = path.posix.join(workspaceSourcePath, destFile);\n    mkdirp(path.dirname(dest));\n    fs.copyFileSync(src, dest);\n  });\n\n  // We create _bazel_workspace_marker that is used by the custom copy_repository\n  // rule to resolve the path to the repository source root. A root BUILD file\n  // is required to reference _bazel_workspace_marker as a target so we also create\n  // an empty one if one does not exist.\n  if (!hasRootBuildFile(pkg, rootPath)) {\n    writeFileSync(\n        path.posix.join(workspaceSourcePath, 'BUILD.bazel'),\n        '# Marker file that this directory is a bazel package');\n  }\n  writeFileSync(\n      path.posix.join(workspaceSourcePath, '_bazel_workspace_marker'),\n      '# Marker file to used by custom copy_repository rule');\n\n  bzlFile += `def install_${workspace}():\n    _maybe(\n        copy_repository,\n        name = \"${workspace}\",\n        marker_file = \"@${WORKSPACE}//_workspaces/${workspace}:_bazel_workspace_marker\",\n        # Ensure that changes to the node_modules cause the copy to re-execute\n        lock_file = \"@${WORKSPACE}${LOCK_FILE_LABEL}\",\n    )\n`;\n\n  writeFileSync(`install_${workspace}.bzl`, bzlFile);\n}\n\n/**\n * Generate install_bazel_dependencies.bzl with function to install all workspaces.\n */\nfunction generateInstallBazelDependencies(workspaces: string[]) {\n  let bzlFile = `# Generated by the yarn_install/npm_install rule\n`;\n  workspaces.forEach(workspace => {\n    bzlFile += `load(\\\":install_${workspace}.bzl\\\", \\\"install_${workspace}\\\")\n`;\n  });\n  bzlFile += `def install_bazel_dependencies():\n    \"\"\"Installs all workspaces listed in bazelWorkspaces of all npm packages\"\"\"\n`;\n  workspaces.forEach(workspace => {\n    bzlFile += `    install_${workspace}()\n`;\n  });\n\n  writeFileSync('install_bazel_dependencies.bzl', bzlFile);\n}\n\n/**\n * Generate build files for a scope.\n */\nfunction generateScopeBuildFiles(scope: string, pkgs: Dep[]) {\n  const buildFile = BUILD_FILE_HEADER + printScope(scope, pkgs);\n  writeFileSync(path.posix.join(scope, 'BUILD.bazel'), buildFile);\n}\n\n/**\n * Checks if a path is a file.\n */\nfunction isFile(p: string) {\n  return fs.existsSync(p) && fs.statSync(p).isFile();\n}\n\n/**\n * Checks if a path is an npm package which is is a directory with a package.json file.\n */\nfunction isDirectory(p: string) {\n  return fs.existsSync(p) && fs.statSync(p).isDirectory();\n}\n\n/**\n * Returns an array of all the files under a directory as relative\n * paths to the directory.\n */\nfunction listFiles(rootDir: string, subDir: string = ''): string[] {\n  const dir = path.posix.join(rootDir, subDir);\n  if (!isDirectory(dir)) {\n    return [];\n  }\n  return fs.readdirSync(dir)\n      .reduce(\n          (files: string[], file) => {\n            const fullPath = path.posix.join(dir, file);\n            const relPath = path.posix.join(subDir, file);\n            const isSymbolicLink = fs.lstatSync(fullPath).isSymbolicLink();\n            let stat;\n            try {\n              stat = fs.statSync(fullPath);\n            } catch (e) {\n              if (isSymbolicLink) {\n                // Filter out broken symbolic links. These cause fs.statSync(fullPath)\n                // to fail with `ENOENT: no such file or directory ...`\n                return files;\n              }\n              throw e;\n            }\n            const isDirectory = stat.isDirectory();\n            if (isDirectory && isSymbolicLink) {\n              // Filter out symbolic links to directories. An issue in yarn versions\n              // older than 1.12.1 creates symbolic links to folders in the .bin folder\n              // which leads to Bazel targets that cross package boundaries.\n              // See https://github.com/bazelbuild/rules_nodejs/issues/428 and\n              // https://github.com/bazelbuild/rules_nodejs/issues/438.\n              // This is tested in /e2e/fine_grained_symlinks.\n              return files;\n            }\n            return isDirectory ? files.concat(listFiles(rootDir, relPath)) : files.concat(relPath);\n          },\n          [])\n      // Files with spaces (\\x20) or unicode characters (<\\x20 && >\\x7E) are not allowed in\n      // Bazel runfiles. See https://github.com/bazelbuild/bazel/issues/4327\n      .filter(f => !/[^\\x21-\\x7E]/.test(f))\n      // We return a sorted array so that the order of files\n      // is the same regardless of platform\n      .sort();\n}\n\n/**\n * Returns true if the npm package distribution contained a\n * root /BUILD or /BUILD.bazel file.\n */\nfunction hasRootBuildFile(pkg: Dep, rootPath: string) {\n  for (const file of pkg._files) {\n    // Bazel files would have been renamed earlier with a `_` prefix\n    const fileUc = path.relative(rootPath, file).toUpperCase();\n    if (fileUc === '_BUILD' || fileUc === '_BUILD.BAZEL') {\n      return true;\n    }\n  }\n  return false;\n}\n\n\nfunction addDynamicDependencies(pkgs: Dep[], dynamic_deps = DYNAMIC_DEPS) {\n  function match(name: string, p: Dep) {\n    // Automatically include dynamic dependency on plugins of the form pkg-plugin-foo\n    if (name.startsWith(`${p._moduleName}-plugin-`)) return true;\n\n    const value = dynamic_deps[p._moduleName];\n    if (name === value) return true;\n\n    // Support wildcard match\n    if (value && value.includes('*') && name.startsWith(value.substring(0, value.indexOf('*')))) {\n      return true;\n    }\n\n    return false;\n  }\n  pkgs.forEach(p => {\n    p._dynamicDependencies = pkgs.filter(x => !!x._moduleName && match(x._moduleName, p))\n                                 .map(dyn => `//${dyn._dir}:${dyn._name}`);\n  });\n}\n\n/**\n * Finds and returns an array of all packages under a given path.\n */\nfunction findPackages(p = 'node_modules') {\n  if (!isDirectory(p)) {\n    return [];\n  }\n\n  const pkgs: Dep[] = [];\n\n  const listing = fs.readdirSync(p);\n\n  const packages = listing\n                       // filter out scopes\n                       .filter(f => !f.startsWith('@'))\n                       // filter out folders such as `.bin` which can create\n                       // issues on Windows since these are \"hidden\" by default\n                       .filter(f => !f.startsWith('.'))\n                       .map(f => path.posix.join(p, f))\n                       .filter(f => isDirectory(f));\n\n  packages.forEach(\n      f => pkgs.push(parsePackage(f), ...findPackages(path.posix.join(f, 'node_modules'))));\n\n  const scopes = listing.filter(f => f.startsWith('@'))\n                     .map(f => path.posix.join(p, f))\n                     .filter(f => isDirectory(f));\n  scopes.forEach(f => pkgs.push(...findPackages(f)));\n\n  addDynamicDependencies(pkgs);\n\n  return pkgs;\n}\n\n/**\n * Finds and returns an array of all package scopes in node_modules.\n */\nfunction findScopes() {\n  const p = 'node_modules';\n  if (!isDirectory(p)) {\n    return [];\n  }\n\n  const listing = fs.readdirSync(p);\n\n  const scopes = listing.filter(f => f.startsWith('@'))\n                     .map(f => path.posix.join(p, f))\n                     .filter(f => isDirectory(f))\n                     .map(f => f.replace(/^node_modules\\//, ''));\n\n  return scopes;\n}\n\n/**\n * Given the name of a top-level folder in node_modules, parse the\n * package json and return it as an object along with\n * some additional internal attributes prefixed with '_'.\n */\nfunction parsePackage(p: string): Dep {\n  // Parse the package.json file of this package\n  const packageJson = path.posix.join(p, 'package.json');\n  const pkg = isFile(packageJson) ? JSON.parse(fs.readFileSync(packageJson, {encoding: 'utf8'})) :\n                                    {version: '0.0.0'};\n\n  // Trim the leading node_modules from the path and\n  // assign to _dir for future use\n  pkg._dir = p.replace(/^node_modules\\//, '');\n\n  // Stash the package directory name for future use\n  pkg._name = pkg._dir.split('/').pop();\n\n  // Module name of the package. Unlike \"_name\" this represents the\n  // full package name (including scope name).\n  pkg._moduleName = pkg.name || `${pkg._dir}/${pkg._name}`;\n\n  // Keep track of whether or not this is a nested package\n  pkg._isNested = /\\/node_modules\\//.test(p);\n\n  // List all the files in the npm package for later use\n  pkg._files = listFiles(p);\n\n  // Initialize _dependencies to an empty array\n  // which is later filled with the flattened dependency list\n  pkg._dependencies = [];\n\n  // Hide bazel files in this package. We do this before parsing\n  // the next package to prevent issues caused by symlinks between\n  // package and nested packages setup by the package manager.\n  hideBazelFiles(pkg);\n\n  return pkg;\n}\n\n/**\n * Check if a bin entry is a non-empty path\n */\nfunction isValidBinPath(entry: any) {\n  return isValidBinPathStringValue(entry) || isValidBinPathObjectValues(entry);\n}\n\n/**\n * If given a string, check if a bin entry is a non-empty path\n */\nfunction isValidBinPathStringValue(entry: any) {\n  return typeof entry === 'string' && entry !== '';\n}\n\n/**\n * If given an object literal, check if a bin entry objects has at least one a non-empty path\n * Example 1: { entry: './path/to/script.js' } ==> VALID\n * Example 2: { entry: '' } ==> INVALID\n * Example 3: { entry: './path/to/script.js', empty: '' } ==> VALID\n */\nfunction isValidBinPathObjectValues(entry: Bag<string>): boolean {\n  // We allow at least one valid entry path (if any).\n  return entry && typeof entry === 'object' &&\n      Object['values'](entry).filter(_entry => isValidBinPath(_entry)).length > 0;\n}\n\n/**\n * Cleanup a package.json \"bin\" path.\n *\n * Bin paths usually come in 2 flavors: './bin/foo' or 'bin/foo',\n * sometimes other stuff like 'lib/foo'.  Remove prefix './' if it\n * exists.\n */\nfunction cleanupBinPath(p: string) {\n  p = p.replace(/\\\\/g, '/');\n  if (p.indexOf('./') === 0) {\n    p = p.slice(2);\n  }\n  return p;\n}\n\n/**\n * Cleanup a package.json entry point such as \"main\"\n *\n * Removes './' if it exists.\n * Appends `index.js` if p ends with `/`.\n */\nfunction cleanupEntryPointPath(p: string) {\n  p = p.replace(/\\\\/g, '/');\n  if (p.indexOf('./') === 0) {\n    p = p.slice(2);\n  }\n  if (p.endsWith('/')) {\n    p += 'index.js';\n  }\n  return p;\n}\n\n/**\n * Cleans up the given path\n * Then tries to resolve the path into a file and warns if VERBOSE_LOGS set and the file dosen't\n * exist\n * @param {any} pkg\n * @param {string} path\n * @returns {string | undefined}\n */\nfunction findEntryFile(pkg: Dep, path: string) {\n  const cleanPath = cleanupEntryPointPath(path);\n  // check if main entry point exists\n  const entryFile = findFile(pkg, cleanPath) || findFile(pkg, `${cleanPath}.js`);\n  if (!entryFile) {\n    // If entryPoint entry point listed could not be resolved to a file\n    // This can happen\n    // in some npm packages that list an incorrect main such as v8-coverage@1.0.8\n    // which lists `\"main\": \"index.js\"` but that file does not exist.\n    log_verbose(\n        `could not find entry point for the path ${cleanPath} given by npm package ${pkg._name}`);\n  }\n  return entryFile;\n}\n\n/**\n * Tries to resolve the entryPoint file from the pkg for a given mainFileName\n *\n * @param {any} pkg\n * @param {'browser' | 'module' | 'main'} mainFileName\n * @returns {string | undefined} the path or undefined if we cant resolve the file\n */\nfunction resolveMainFile(pkg: Dep, mainFileName: string) {\n  const mainEntryField = pkg[mainFileName];\n\n  if (mainEntryField) {\n    if (typeof mainEntryField === 'string') {\n      return findEntryFile(pkg, mainEntryField)\n\n    } else if (typeof mainEntryField === 'object' && mainFileName === 'browser') {\n      // browser has a weird way of defining this\n      // the browser value is an object listing files to alias, usually pointing to a browser dir\n      const indexEntryPoint = mainEntryField['index.js'] || mainEntryField['./index.js'];\n      if (indexEntryPoint) {\n        return findEntryFile(pkg, indexEntryPoint)\n      }\n    }\n  }\n}\n\n/**\n * Tries to resolve the mainFile from a given pkg\n * This uses seveal mainFileNames in priority to find a correct usable file\n * @param {any} pkg\n * @returns {string | undefined}\n */\nfunction resolvePkgMainFile(pkg: Dep) {\n  // es2015 is another option for mainFile here\n  // but its very uncommon and im not sure what priority it takes\n  //\n  // this list is ordered, we try resolve `browser` first, then `module` and finally fall back to\n  // `main`\n  const mainFileNames = ['browser', 'module', 'main']\n\n      for (const mainFile of mainFileNames) {\n    const resolvedMainFile = resolveMainFile(pkg, mainFile);\n    if (resolvedMainFile) {\n      return resolvedMainFile;\n    }\n  }\n\n  // if we cant find any correct file references from the pkg\n  // then we just try looking around for common patterns\n  const maybeRootIndex = findEntryFile(pkg, 'index.js');\n  if (maybeRootIndex) {\n    return maybeRootIndex\n  }\n\n  const maybeSelfNamedIndex = findEntryFile(pkg, `${pkg._name}.js`);\n  if (maybeSelfNamedIndex) {\n    return maybeSelfNamedIndex;\n  }\n\n  // none of the methods we tried resulted in a file\n  log_verbose(`could not find entry point for npm package ${pkg._name}`);\n\n  // at this point there's nothing left for us to try, so return nothing\n  return undefined;\n}\n\ntype Bag<T> =\n    {\n      [k: string]: T\n    }\n\n/**\n * Flattens all transitive dependencies of a package\n * into a _dependencies array.\n */\nfunction flattenPkgDependencies(pkg: Dep, dep: Dep, pkgsMap: Map<string, Dep>) {\n  if (pkg._dependencies.indexOf(dep) !== -1) {\n    // circular dependency\n    return;\n  }\n  pkg._dependencies.push(dep);\n  const findDeps = function(targetDeps: Bag<string>, required: boolean, depType: string) {\n    Object.keys(targetDeps || {})\n        .map(targetDep => {\n          // look for matching nested package\n          const dirSegments = dep._dir.split('/');\n          while (dirSegments.length) {\n            const maybe = path.posix.join(...dirSegments, 'node_modules', targetDep);\n            if (pkgsMap.has(maybe)) {\n              return pkgsMap.get(maybe);\n            }\n            dirSegments.pop();\n          }\n          // look for matching root package\n          if (pkgsMap.has(targetDep)) {\n            return pkgsMap.get(targetDep);\n          }\n          // dependency not found\n          if (required) {\n            console.error(`could not find ${depType} '${targetDep}' of '${dep._dir}'`);\n            process.exit(1);\n          }\n          return null;\n        })\n        .filter(dep => !!dep)\n        .forEach(dep => flattenPkgDependencies(pkg, dep!, pkgsMap));\n  };\n  // npm will in some cases add optionalDependencies to the list\n  // of dependencies to the package.json it writes to node_modules.\n  // We delete these here if they exist as they may result\n  // in expected dependencies that are not found.\n  if (dep.dependencies && dep.optionalDependencies) {\n    Object.keys(dep.optionalDependencies).forEach(optionalDep => {\n      delete dep.dependencies[optionalDep];\n    });\n  }\n\n  findDeps(dep.dependencies, true, 'dependency');\n  findDeps(dep.peerDependencies, true, 'peer dependency');\n  // `optionalDependencies` that are missing should be silently\n  // ignored since the npm/yarn will not fail if these dependencies\n  // fail to install. Packages should handle the cases where these\n  // dependencies are missing gracefully at runtime.\n  // An example of this is the `chokidar` package which specifies\n  // `fsevents` as an optionalDependency. On OSX, `fsevents`\n  // is installed successfully, but on Windows & Linux, `fsevents`\n  // fails to install and the package will not be present when\n  // checking the dependencies of `chokidar`.\n  findDeps(dep.optionalDependencies, false, 'optional dependency');\n}\n\n/**\n * Reformat/pretty-print a json object as a skylark comment (each line\n * starts with '# ').\n */\nfunction printJson(pkg: Dep) {\n  // Clone and modify _dependencies to avoid circular issues when JSONifying\n  // & delete _files array\n  const cloned: any = {...pkg};\n  cloned._dependencies = pkg._dependencies.map(dep => dep._dir);\n  delete cloned._files;\n  return JSON.stringify(cloned, null, 2).split('\\n').map(line => `# ${line}`).join('\\n');\n}\n\n/**\n * A filter function for files in an npm package. Comparison is case-insensitive.\n * @param files array of files to filter\n * @param exts list of white listed case-insensitive extensions; if empty, no filter is\n *             done on extensions; '' empty string denotes to allow files with no extensions,\n *             other extensions are listed with '.ext' notation such as '.d.ts'.\n */\nfunction filterFiles(files: string[], exts: string[] = []) {\n  if (exts.length) {\n    const allowNoExts = exts.includes('');\n    files = files.filter(f => {\n      // include files with no extensions if noExt is true\n      if (allowNoExts && !path.extname(f)) return true;\n      // filter files in exts\n      const lc = f.toLowerCase();\n      for (const e of exts) {\n        if (e && lc.endsWith(e.toLowerCase())) {\n          return true;\n        }\n      }\n      return false;\n    })\n  }\n  // Filter out BUILD files that came with the npm package\n  return files.filter(file => {\n    const basenameUc = path.basename(file).toUpperCase();\n    if (basenameUc === '_BUILD' || basenameUc === '_BUILD.BAZEL') {\n      return false;\n    }\n    return true;\n  });\n}\n\n/**\n * Returns true if the specified `pkg` conforms to Angular Package Format (APF),\n * false otherwise. If the package contains `*.metadata.json` and a\n * corresponding sibling `.d.ts` file, then the package is considered to be APF.\n */\nfunction isNgApfPackage(pkg: Dep) {\n  const set = new Set(pkg._files);\n  if (set.has('ANGULAR_PACKAGE')) {\n    // This file is used by the npm/yarn_install rule to detect APF. See\n    // https://github.com/bazelbuild/rules_nodejs/issues/927\n    return true;\n  }\n  const metadataExt = /\\.metadata\\.json$/;\n  return pkg._files.some((file) => {\n    if (metadataExt.test(file)) {\n      const sibling = file.replace(metadataExt, '.d.ts');\n      if (set.has(sibling)) {\n        return true;\n      }\n    }\n    return false;\n  });\n}\n\n/**\n * If the package is in the Angular package format returns list\n * of package files that end with `.umd.js`, `.ngfactory.js` and `.ngsummary.js`.\n */\nfunction getNgApfScripts(pkg: Dep) {\n  return isNgApfPackage(pkg) ?\n      filterFiles(pkg._files, ['.umd.js', '.ngfactory.js', '.ngsummary.js']) :\n      [];\n}\n\n/**\n * Looks for a file within a package and returns it if found.\n */\nfunction findFile(pkg: Dep, m: string) {\n  const ml = m.toLowerCase();\n  for (const f of pkg._files) {\n    if (f.toLowerCase() === ml) {\n      return f;\n    }\n  }\n  return undefined;\n}\n\n/**\n * Given a pkg, return the skylark `node_module_library` targets for the package.\n */\nfunction printPackage(pkg: Dep) {\n  const sources = filterFiles(pkg._files, INCLUDED_FILES);\n  const dtsSources = filterFiles(pkg._files, ['.d.ts']);\n  // TODO(gmagolan): add UMD & AMD scripts to scripts even if not an APF package _but_ only if they\n  // are named?\n  const namedSources = getNgApfScripts(pkg);\n  const deps = [pkg].concat(pkg._dependencies.filter(dep => dep !== pkg && !dep._isNested));\n\n  let namedSourcesStarlark = '';\n  if (namedSources.length) {\n    namedSourcesStarlark = `\n    # subset of srcs that are javascript named-UMD or named-AMD scripts\n    named_sources = [\n        ${namedSources.map((f: string) => `\"//:node_modules/${pkg._dir}/${f}\",`).join('\\n        ')}\n    ],`;\n  }\n\n  let srcsStarlark = '';\n  if (sources.length) {\n    srcsStarlark = `\n    # ${pkg._dir} package files (and files in nested node_modules)\n    srcs = [\n        ${sources.map((f: string) => `\"//:node_modules/${pkg._dir}/${f}\",`).join('\\n        ')}\n    ],`;\n  }\n\n  let depsStarlark = '';\n  if (deps.length) {\n    const list = deps.map(dep => `\"//${dep._dir}:${dep._name}__contents\",`).join('\\n        ');\n    depsStarlark = `\n    # flattened list of direct and transitive dependencies hoisted to root by the package manager\n    deps = [\n        ${list}\n    ],`;\n  }\n\n  let dtsStarlark = '';\n  if (dtsSources.length) {\n    dtsStarlark = `\n    # ${pkg._dir} package declaration files (and declaration files in nested node_modules)\n    srcs = [\n        ${dtsSources.map(f => `\"//:node_modules/${pkg._dir}/${f}\",`).join('\\n        ')}\n    ],`;\n  }\n\n  let result =\n      `load(\"@build_bazel_rules_nodejs//internal/npm_install:node_module_library.bzl\", \"node_module_library\")\n\n# Generated targets for npm package \"${pkg._dir}\"\n${printJson(pkg)}\n\nfilegroup(\n    name = \"${pkg._name}__files\",${srcsStarlark}\n)\n\nnode_module_library(\n    name = \"${pkg._name}\",\n    # direct sources listed for strict deps support\n    srcs = [\":${pkg._name}__files\"],${depsStarlark}\n)\n\n# ${pkg._name}__contents target is used as dep for main targets to prevent\n# circular dependencies errors\nnode_module_library(\n    name = \"${pkg._name}__contents\",\n    srcs = [\":${pkg._name}__files\"],${namedSourcesStarlark}\n)\n\n# ${pkg._name}__typings is the subset of ${pkg._name}__contents that are declarations\nnode_module_library(\n    name = \"${pkg._name}__typings\",${dtsStarlark}\n)\n\n`;\n\n  let mainEntryPoint = resolvePkgMainFile(pkg)\n\n  // add an `npm_umd_bundle` target to generate an UMD bundle if one does\n  // not exists\n  if (mainEntryPoint && !findFile(pkg, `${pkg._name}.umd.js`)) {\n    result +=\n        `load(\"@build_bazel_rules_nodejs//internal/npm_install:npm_umd_bundle.bzl\", \"npm_umd_bundle\")\n\nnpm_umd_bundle(\n    name = \"${pkg._name}__umd\",\n    package_name = \"${pkg._name}\",\n    entry_point = \"//:node_modules/${pkg._dir}/${mainEntryPoint}\",\n    package = \":${pkg._name}\",\n)\n\n`;\n  }\n\n  return result;\n}\n\nfunction _findExecutables(pkg: Dep) {\n  const executables = new Map();\n\n  // For root packages, transform the pkg.bin entries\n  // into a new Map called _executables\n  // NOTE: we do this only for non-empty bin paths\n  if (isValidBinPath(pkg.bin)) {\n    if (!pkg._isNested) {\n      if (Array.isArray(pkg.bin)) {\n        if (pkg.bin.length == 1) {\n          executables.set(pkg._dir, cleanupBinPath(pkg.bin[0]));\n        } else {\n          // should not happen, but ignore it if present\n        }\n      } else if (typeof pkg.bin === 'string') {\n        executables.set(pkg._dir, cleanupBinPath(pkg.bin));\n      } else if (typeof pkg.bin === 'object') {\n        for (let key in pkg.bin) {\n          if (isValidBinPathStringValue(pkg.bin[key])) {\n            executables.set(key, cleanupBinPath(pkg.bin[key]));\n          }\n        }\n      }\n    }\n  }\n\n  return executables;\n}\n\n// Handle additionalAttributes of format:\n// ```\n// \"bazelBin\": {\n//   \"ngc-wrapped\": {\n//     \"additionalAttributes\": {\n//       \"configuration_env_vars\": \"[\\\"compile\\\"]\"\n//   }\n// },\n// ```\nfunction additionalAttributes(pkg: Dep, name: string) {\n  let additionalAttributes = '';\n  if (pkg.bazelBin && pkg.bazelBin[name] && pkg.bazelBin[name].additionalAttributes) {\n    const attrs = pkg.bazelBin[name].additionalAttributes;\n    for (const attrName of Object.keys(attrs)) {\n      const attrValue = attrs[attrName];\n      additionalAttributes += `\\n    ${attrName} = ${attrValue},`;\n    }\n  }\n  return additionalAttributes;\n}\n\n/**\n * Given a pkg, return the skylark nodejs_binary targets for the package.\n */\nfunction printPackageBin(pkg: Dep) {\n  let result = '';\n  const executables = _findExecutables(pkg);\n  if (executables.size) {\n    result = `load(\"@build_bazel_rules_nodejs//:index.bzl\", \"nodejs_binary\")\n\n`;\n    const data = [`//${pkg._dir}:${pkg._name}`];\n    if (pkg._dynamicDependencies) {\n      data.push(...pkg._dynamicDependencies);\n    }\n\n    for (const [name, path] of executables.entries()) {\n      result += `# Wire up the \\`bin\\` entry \\`${name}\\`\nnodejs_binary(\n    name = \"${name}\",\n    entry_point = \"//:node_modules/${pkg._dir}/${path}\",\n    install_source_map_support = False,\n    data = [${data.map(p => `\"${p}\"`).join(', ')}],${additionalAttributes(pkg, name)}\n)\n\n`;\n    }\n  }\n\n  return result;\n}\n\nfunction printIndexBzl(pkg: Dep) {\n  let result = '';\n  const executables = _findExecutables(pkg);\n  if (executables.size) {\n    result = `load(\"@build_bazel_rules_nodejs//:index.bzl\", \"nodejs_binary\", \"npm_package_bin\")\n\n`;\n    const data = [`@${WORKSPACE}//${pkg._dir}:${pkg._name}`];\n    if (pkg._dynamicDependencies) {\n      data.push(...pkg._dynamicDependencies);\n    }\n\n    for (const [name, path] of executables.entries()) {\n      result = `${result}\n\n# Generated helper macro to call ${name}\ndef ${name.replace(/-/g, '_')}(**kwargs):\n    output_dir = kwargs.pop(\"output_dir\", False)\n    if \"outs\" in kwargs or output_dir:\n        npm_package_bin(tool = \"@${WORKSPACE}//${pkg._dir}/bin:${\n          name}\", output_dir = output_dir, **kwargs)\n    else:\n        nodejs_binary(\n            entry_point = \"@${WORKSPACE}//:node_modules/${pkg._dir}/${path}\",\n            install_source_map_support = False,\n            data = [${data.map(p => `\"${p}\"`).join(', ')}] + kwargs.pop(\"data\", []),${\n          additionalAttributes(pkg, name)}\n            **kwargs\n        )\n  `;\n    }\n  }\n  return result;\n}\n\ntype Dep = {\n  _dir: string,\n  _isNested: boolean,\n  _dependencies: Dep[],\n  _files: string[],\n  [k: string]: any\n}\n\n/**\n * Given a scope, return the skylark `node_module_library` target for the scope.\n */\nfunction printScope(scope: string, pkgs: Dep[]) {\n  pkgs = pkgs.filter(pkg => !pkg._isNested && pkg._dir.startsWith(`${scope}/`));\n  let deps: Dep[] = [];\n  pkgs.forEach(pkg => {\n    deps = deps.concat(pkg._dependencies.filter(dep => !dep._isNested && !pkgs.includes(pkg)));\n  });\n  // filter out duplicate deps\n  deps = [...pkgs, ...new Set(deps)];\n\n  let srcsStarlark = '';\n  if (deps.length) {\n    const list = deps.map(dep => `\"//${dep._dir}:${dep._name}__files\",`).join('\\n        ');\n    srcsStarlark = `\n    # direct sources listed for strict deps support\n    srcs = [\n        ${list}\n    ],`;\n  }\n\n  let depsStarlark = '';\n  if (deps.length) {\n    const list = deps.map(dep => `\"//${dep._dir}:${dep._name}__contents\",`).join('\\n        ');\n    depsStarlark = `\n    # flattened list of direct and transitive dependencies hoisted to root by the package manager\n    deps = [\n        ${list}\n    ],`;\n  }\n\n  return `load(\"@build_bazel_rules_nodejs//internal/npm_install:node_module_library.bzl\", \"node_module_library\")\n\n# Generated target for npm scope ${scope}\nnode_module_library(\n    name = \"${scope}\",${srcsStarlark}${depsStarlark}\n)\n\n`;\n}\n"]} \ No newline at end of file diff --git a/internal/npm_install/generate_build_file.ts b/internal/npm_install/generate_build_file.ts index 85d5a85381..cf30ab39e6 100644 --- a/internal/npm_install/generate_build_file.ts +++ b/internal/npm_install/generate_build_file.ts @@ -882,15 +882,15 @@ function printPackage(pkg: Dep) { const dtsSources = filterFiles(pkg._files, ['.d.ts']); // TODO(gmagolan): add UMD & AMD scripts to scripts even if not an APF package _but_ only if they // are named? - const scripts = getNgApfScripts(pkg); + const namedSources = getNgApfScripts(pkg); const deps = [pkg].concat(pkg._dependencies.filter(dep => dep !== pkg && !dep._isNested)); - let scriptStarlark = ''; - if (scripts.length) { - scriptStarlark = ` + let namedSourcesStarlark = ''; + if (namedSources.length) { + namedSourcesStarlark = ` # subset of srcs that are javascript named-UMD or named-AMD scripts - scripts = [ - ${scripts.map((f: string) => `"//:node_modules/${pkg._dir}/${f}",`).join('\n ')} + named_sources = [ + ${namedSources.map((f: string) => `"//:node_modules/${pkg._dir}/${f}",`).join('\n ')} ],`; } @@ -942,7 +942,7 @@ node_module_library( # circular dependencies errors node_module_library( name = "${pkg._name}__contents", - srcs = [":${pkg._name}__files"],${scriptStarlark} + srcs = [":${pkg._name}__files"],${namedSourcesStarlark} ) # ${pkg._name}__typings is the subset of ${pkg._name}__contents that are declarations diff --git a/internal/npm_install/node_module_library.bzl b/internal/npm_install/node_module_library.bzl index 913fc73f29..bd802f6223 100644 --- a/internal/npm_install/node_module_library.bzl +++ b/internal/npm_install/node_module_library.bzl @@ -15,19 +15,15 @@ """Contains the node_module_library which is used by yarn_install & npm_install. """ -load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleInfo", "NodeModuleSources") +load("@build_bazel_rules_nodejs//:declaration_provider.bzl", "DeclarationInfo") +load("@build_bazel_rules_nodejs//:providers.bzl", "transitive_js_named_module_info") +load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleInfo") def _node_module_library_impl(ctx): workspace = ctx.label.workspace_root.split("/")[1] if ctx.label.workspace_root else ctx.workspace_name - # All files in `srcs` and in `deps` - # TODO(gregmagolan): transitive sources should be collected an aspect to go - # into a NodeModuleSources.transitive_sources - sources = depset(ctx.files.srcs, transitive = [dep.files for dep in ctx.attr.deps]) - - # scripts are a subset of sources that are javascript named-UMD or named-AMD scripts for - # use in rules such as ts_devserver - scripts = depset(ctx.files.scripts) + # sources are all files in srcs plus those in direct & transitive dependencies + sources = depset(ctx.files.srcs) # declarations are a subset of sources that are declaration files declarations = depset([ @@ -42,11 +38,13 @@ def _node_module_library_impl(ctx): ]) # transitive_declarations are all .d.ts files in srcs plus those in direct & transitive dependencies - transitive_declarations = depset(transitive = [declarations]) + transitive_declarations = declarations for dep in ctx.attr.deps: - if hasattr(dep, "typescript"): - transitive_declarations = depset(transitive = [transitive_declarations, dep.typescript.transitive_declarations]) + if DeclarationInfo in dep: + transitive_declarations = depset(transitive = [transitive_declarations, dep[DeclarationInfo].transitive_declarations]) + if NodeModuleInfo in dep: + sources = depset(transitive = [sources, dep[NodeModuleInfo].sources]) return struct( typescript = struct( @@ -66,13 +64,17 @@ def _node_module_library_impl(ctx): files = sources, ), NodeModuleInfo( - workspace = workspace, - ), - NodeModuleSources( sources = sources, - scripts = scripts, workspace = workspace, ), + DeclarationInfo( + declarations = declarations, + transitive_declarations = transitive_declarations, + ), + transitive_js_named_module_info( + sources = depset(ctx.files.named_sources), + deps = ctx.attr.deps, + ), ], ) @@ -83,8 +85,8 @@ node_module_library = rule( doc = "The list of files that comprise the package", allow_files = True, ), - "scripts": attr.label_list( - doc = "A subset of srcs that are javascript named-UMD or named-AMD scripts for use in rules such as ts_devserver", + "named_sources": attr.label_list( + doc = "A subset of srcs that are javascript named-UMD or named-AMD for use in rules such as ts_devserver", allow_files = True, ), "deps": attr.label_list( diff --git a/internal/npm_install/npm_umd_bundle.bzl b/internal/npm_install/npm_umd_bundle.bzl index a62c7129bb..1ef82007c4 100644 --- a/internal/npm_install/npm_umd_bundle.bzl +++ b/internal/npm_install/npm_umd_bundle.bzl @@ -17,7 +17,7 @@ For use by yarn_install and npm_install. Not meant to be part of the public API. """ -load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleSources", "collect_node_modules_aspect") +load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleInfo", "node_modules_aspect") def _npm_umd_bundle(ctx): if len(ctx.attr.entry_point.files.to_list()) != 1: @@ -33,7 +33,7 @@ def _npm_umd_bundle(ctx): args.add(output.path) args.add_joined(ctx.attr.excluded, join_with = ",") - sources = ctx.attr.package[NodeModuleSources].sources.to_list() + sources = ctx.attr.package[NodeModuleInfo].sources.to_list() # Only pass .js and package.json files as inputs to browserify. # The latter is required for module resolution in some cases. @@ -91,7 +91,7 @@ This target would be then be used instead of the generated `@npm//typeorm:typeor "package": attr.label( doc = """The npm package target""", mandatory = True, - aspects = [collect_node_modules_aspect], + aspects = [node_modules_aspect], ), "_browserify_wrapped": attr.label( executable = True, diff --git a/internal/npm_install/test/golden/@angular/core/BUILD.bazel.golden b/internal/npm_install/test/golden/@angular/core/BUILD.bazel.golden index 336aa504e7..bf1c2c036f 100644 --- a/internal/npm_install/test/golden/@angular/core/BUILD.bazel.golden +++ b/internal/npm_install/test/golden/@angular/core/BUILD.bazel.golden @@ -677,7 +677,7 @@ node_module_library( node_module_library( name = "core__contents", srcs = [":core__files"], - scripts = [ + named_sources = [ "//:node_modules/@angular/core/bundles/core-testing.umd.js", "//:node_modules/@angular/core/bundles/core.umd.js", ], diff --git a/internal/npm_package/npm_package.bzl b/internal/npm_package/npm_package.bzl index 0cbf203781..8e512dcf87 100644 --- a/internal/npm_package/npm_package.bzl +++ b/internal/npm_package/npm_package.bzl @@ -6,7 +6,8 @@ If all users of your library code use Bazel, they should just add your library to the `deps` of one of their targets. """ -load("//internal/common:sources_aspect.bzl", "sources_aspect") +load("@build_bazel_rules_nodejs//:declaration_provider.bzl", "DeclarationInfo") +load("@build_bazel_rules_nodejs//:providers.bzl", "JSNamedModuleInfo") # Takes a depset of files and returns a corresponding list of file paths without any files # that aren't part of the specified package path. Also include files from external repositories @@ -95,30 +96,28 @@ def create_package(ctx, deps_sources, nested_packages): return package_dir def _npm_package(ctx): - deps_sources = depset() + sources_depsets = [] + for dep in ctx.attr.deps: - transitive = [ - deps_sources, - # Collect whatever is in the "data" - dep.data_runfiles.files, - ] - - if hasattr(dep, "node_sources"): - # For JavaScript-producing rules, gather up the devmode Node.js sources - transitive.append(dep.node_sources) - else: - # For standalone Output File Targets (aspects not invoked on these) - transitive.append(dep.files) + # Collect whatever is in the "data" + sources_depsets.append(dep.data_runfiles.files) + + # Only collect DefaultInfo files (not transitive) + sources_depsets.append(dep.files) + + # All direct & transitive JavaScript-producing deps + # TODO: switch to JSModuleInfo when it is available + if JSNamedModuleInfo in dep: + sources_depsets.append(dep[JSNamedModuleInfo].sources) - # ts_library doesn't include .d.ts outputs in the runfiles - # see comment in rules_typescript/internal/common/compilation.bzl - if hasattr(dep, "typescript"): - transitive.append(dep.typescript.transitive_declarations) + # Include all transitive declerations + if DeclarationInfo in dep: + sources_depsets.append(dep[DeclarationInfo].transitive_declarations) - deps_sources = depset(transitive = transitive) + sources = depset(transitive = sources_depsets) # Note: to_list() should be called once per rule! - package_dir = create_package(ctx, deps_sources.to_list(), ctx.files.packages) + package_dir = create_package(ctx, sources.to_list(), ctx.files.packages) return [DefaultInfo( files = depset([package_dir]), @@ -154,7 +153,6 @@ NPM_PACKAGE_ATTRS = { ), "deps": attr.label_list( doc = """Other targets which produce files that should be included in the package, such as `rollup_bundle`""", - aspects = [sources_aspect], allow_files = True, ), "_packager": attr.label( diff --git a/internal/npm_package/test/BUILD.bazel b/internal/npm_package/test/BUILD.bazel index a7d6513883..bfe1e8ad93 100644 --- a/internal/npm_package/test/BUILD.bazel +++ b/internal/npm_package/test/BUILD.bazel @@ -1,6 +1,6 @@ load("@build_bazel_rules_nodejs//:index.bzl", "npm_package") load("@npm_bazel_jasmine//:index.from_src.bzl", "jasmine_node_test") -load("//internal/common:typescript_mock_lib.bzl", "mock_typescript_lib") +load("@npm_bazel_typescript//:index.from_src.bzl", "ts_library") load("//third_party/github.com/bazelbuild/bazel-skylib:rules/write_file.bzl", "write_file") write_file( @@ -9,12 +9,9 @@ write_file( content = ["a_dep content"], ) -mock_typescript_lib( +ts_library( name = "ts_library", - srcs = [ - "foo.d.ts", - "foo.js", - ], + srcs = ["foo.ts"], data = ["data.json"], ) diff --git a/internal/npm_package/test/foo.d.ts b/internal/npm_package/test/foo.d.ts deleted file mode 100644 index 425b80f244..0000000000 --- a/internal/npm_package/test/foo.d.ts +++ /dev/null @@ -1 +0,0 @@ -export const a: string; diff --git a/internal/npm_package/test/foo.js b/internal/npm_package/test/foo.js deleted file mode 100644 index ca6a755661..0000000000 --- a/internal/npm_package/test/foo.js +++ /dev/null @@ -1 +0,0 @@ -export const a = ''; diff --git a/internal/npm_package/test/foo.ts b/internal/npm_package/test/foo.ts new file mode 100644 index 0000000000..db233fb40c --- /dev/null +++ b/internal/npm_package/test/foo.ts @@ -0,0 +1 @@ +export const a: string = ''; diff --git a/internal/npm_package/test/npm_package.spec.js b/internal/npm_package/test/npm_package.spec.js index cb5d8a4356..2d2c140fed 100644 --- a/internal/npm_package/test/npm_package.spec.js +++ b/internal/npm_package/test/npm_package.spec.js @@ -22,10 +22,10 @@ describe('npm_package srcs', () => { expect(read('dependent_file')).toEqual('dependent_file content'); }); it('copies js files from ts_library', () => { - expect(read('foo.js')).toEqual('export const a = \'\';'); + expect(read('foo.js')).toContain('exports.a = \'\';'); }); it('copies declaration files from ts_library', () => { - expect(read('foo.d.ts')).toEqual('export const a: string;'); + expect(read('foo.d.ts')).toContain('export declare const a: string;'); }); it('copies data dependencies', () => { expect(read('data.json')).toEqual('[]'); diff --git a/internal/rollup/rollup_bundle.bzl b/internal/rollup/rollup_bundle.bzl index bbffa23185..fa662b7c03 100644 --- a/internal/rollup/rollup_bundle.bzl +++ b/internal/rollup/rollup_bundle.bzl @@ -18,7 +18,7 @@ The versions of Rollup and terser are controlled by the Bazel toolchain. You do not need to install them into your project. """ -load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleSources", "collect_node_modules_aspect") +load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleInfo", "node_modules_aspect") load("//internal/common:collect_es6_sources.bzl", _collect_es2015_sources = "collect_es6_sources") load("//internal/common:module_mappings.bzl", "get_module_mappings") @@ -64,8 +64,8 @@ def _compute_node_modules_root(ctx): """ node_modules_root = None if ctx.attr.node_modules: - if NodeModuleSources in ctx.attr.node_modules: - node_modules_root = "/".join(["external", ctx.attr.node_modules[NodeModuleSources].workspace, "node_modules"]) + if NodeModuleInfo in ctx.attr.node_modules: + node_modules_root = "/".join(["external", ctx.attr.node_modules[NodeModuleInfo].workspace, "node_modules"]) elif ctx.files.node_modules: # ctx.files.node_modules is not an empty list node_modules_root = "/".join([f for f in [ @@ -74,8 +74,8 @@ def _compute_node_modules_root(ctx): "node_modules", ] if f]) for d in ctx.attr.deps: - if NodeModuleSources in d: - possible_root = "/".join(["external", d[NodeModuleSources].workspace, "node_modules"]) + if NodeModuleInfo in d: + possible_root = "/".join(["external", d[NodeModuleInfo].workspace, "node_modules"]) if not node_modules_root: node_modules_root = possible_root elif node_modules_root != possible_root: @@ -210,14 +210,15 @@ def _run_rollup(ctx, sources, config, output, map_output = None): args.add_joined(["%s:%s" % g for g in ctx.attr.globals.items()], join_with = ",") direct_inputs = [config] - direct_inputs += _filter_js_inputs(ctx.files.node_modules) + if hasattr(ctx.attr, "node_modules"): + direct_inputs += _filter_js_inputs(ctx.files.node_modules) # Also include files from npm fine grained deps as inputs. - # These deps are identified by the NodeModuleSources provider. + # These deps are identified by the NodeModuleInfo provider. for d in ctx.attr.deps: - if NodeModuleSources in d: + if NodeModuleInfo in d: # Note: we can't avoid calling .to_list() on sources - direct_inputs += _filter_js_inputs(d[NodeModuleSources].sources.to_list()) + direct_inputs += _filter_js_inputs(d[NodeModuleInfo].sources.to_list()) if ctx.file.license_banner: direct_inputs += [ctx.file.license_banner] @@ -569,7 +570,7 @@ def _rollup_bundle(ctx): # If users are in a different repo and load the aspect themselves, they will create # different Provider symbols (e.g. NodeModuleInfo) and we won't find them. # So users must use these symbols that are load'ed in rules_nodejs. -ROLLUP_DEPS_ASPECTS = [rollup_module_mappings_aspect, collect_node_modules_aspect] +ROLLUP_DEPS_ASPECTS = [rollup_module_mappings_aspect, node_modules_aspect] ROLLUP_ATTRS = { "srcs": attr.label_list( diff --git a/packages/jasmine/docs/BUILD.bazel b/packages/jasmine/docs/BUILD.bazel index 556c0544f7..0dd1a0fd2e 100644 --- a/packages/jasmine/docs/BUILD.bazel +++ b/packages/jasmine/docs/BUILD.bazel @@ -34,6 +34,7 @@ stardoc( # ``` "//internal/common:bzl", "//internal/node:bzl", + "//:bzl", ], ) diff --git a/packages/karma/docs/BUILD.bazel b/packages/karma/docs/BUILD.bazel index 6cbcd6523f..1b6b13964f 100644 --- a/packages/karma/docs/BUILD.bazel +++ b/packages/karma/docs/BUILD.bazel @@ -35,6 +35,7 @@ stardoc( # ``` "//internal/common:bzl", "//internal/js_library:bzl", + "//:bzl", ], ) diff --git a/packages/karma/src/karma_web_test.bzl b/packages/karma/src/karma_web_test.bzl index c7f2c8c385..dc1d89255b 100644 --- a/packages/karma/src/karma_web_test.bzl +++ b/packages/karma/src/karma_web_test.bzl @@ -13,7 +13,8 @@ # limitations under the License. "Unit testing with Karma" -load("@build_bazel_rules_nodejs//internal/common:sources_aspect.bzl", "sources_aspect") +load("@build_bazel_rules_nodejs//:providers.bzl", "JSNamedModuleInfo") +load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleInfo", "node_modules_aspect") load("@build_bazel_rules_nodejs//internal/js_library:js_library.bzl", "write_amd_names_shim") load("@io_bazel_rules_webtesting//web:web.bzl", "web_test_suite") load("@io_bazel_rules_webtesting//web/internal:constants.bzl", "DEFAULT_WRAPPED_TEST_TAGS") @@ -50,7 +51,7 @@ KARMA_GENERIC_WEB_TEST_ATTRS = dict(COMMON_WEB_TEST_ATTRS, **{ These should be a list of targets which produce JavaScript such as `ts_library`. The files will be loaded in the same order they are declared by that rule.""", allow_files = True, - aspects = [sources_aspect], + aspects = [node_modules_aspect], ), "_conf_tmpl": attr.label( default = Label(_CONF_TMPL), @@ -65,7 +66,6 @@ KARMA_WEB_TEST_ATTRS = dict(KARMA_GENERIC_WEB_TEST_ATTRS, **{ certain attributes of this configuration file. Attributes that are overridden will be outputted to the test log.""", allow_single_file = True, - aspects = [sources_aspect], ), }) @@ -92,11 +92,15 @@ def _write_karma_config(ctx, files, amd_names_shim): sibling = ctx.outputs.executable, ) - config_file = "" - if hasattr(ctx.file, "config_file"): - config_file = ctx.file.config_file - if hasattr(ctx.attr.config_file, "typescript"): - config_file = ctx.attr.config_file.typescript.es5_sources.to_list()[0] + config_file = None + + # Check for config_file since ts_web_test does not have this attribute + if hasattr(ctx.attr, "config_file") and ctx.attr.config_file: + # TODO: switch to JSModuleInfo when it is available + if JSNamedModuleInfo in ctx.attr.config_file: + config_file = ctx.attr.config_file[JSNamedModuleInfo].sources.to_list()[0] + else: + config_file = ctx.file.config_file # The files in the bootstrap attribute come before the require.js support. # Note that due to frameworks = ['jasmine'], a few scripts will come before @@ -129,19 +133,20 @@ def _write_karma_config(ctx, files, amd_names_shim): # Next we load the "runtime_deps" which we expect to contain named AMD modules # Thus they should come after the require.js script, but before any srcs or deps runtime_files = [] - for d in ctx.attr.runtime_deps: - if not hasattr(d, "typescript"): + for dep in ctx.attr.runtime_deps: + if not JSNamedModuleInfo in dep: # Workaround https://github.com/bazelbuild/rules_nodejs/issues/57 # We should allow any JS source as long as it yields something that # can be loaded by require.js fail("labels in runtime_deps must be created by ts_library") - for src in d.typescript.es5_sources.to_list(): + for src in dep[JSNamedModuleInfo].sources.to_list(): runtime_files.append(_to_manifest_path(ctx, src)) # Finally we load the user's srcs and deps user_entries = [ _to_manifest_path(ctx, f) for f in files.to_list() + if f.path.endswith(".js") ] # Expand static_files paths to runfiles for config @@ -187,19 +192,25 @@ def run_karma_web_test(ctx): Returns: The runfiles for the generated action. """ - files = depset(ctx.files.srcs) - for d in ctx.attr.deps + ctx.attr.runtime_deps: - has_node_sources = hasattr(d, "node_sources") - has_dev_scripts = hasattr(d, "dev_scripts") - if has_node_sources: - files = depset(transitive = [files, d.node_sources]) - if has_dev_scripts: - files = depset(transitive = [files, d.dev_scripts]) - if not has_node_sources and not has_dev_scripts and hasattr(d, "files"): - # These are Javascript files directly specified in "deps". - # They are not collected by `sources_aspect` due to the absence of - # `deps` attr. These files must be in named AMD format. - files = depset(transitive = [files, d.files]) + files_depsets = [depset(ctx.files.srcs)] + for dep in ctx.attr.deps + ctx.attr.runtime_deps: + if JSNamedModuleInfo in dep: + files_depsets.append(dep[JSNamedModuleInfo].sources) + if not JSNamedModuleInfo in dep and not NodeModuleInfo in dep and hasattr(dep, "files"): + # These are javascript files provided by DefaultInfo from a direct + # dep that has no JSNamedModuleInfo provider or NodeModuleInfo + # provider (not an npm dep). These files must be in named AMD or named + # UMD format. + files_depsets.append(dep.files) + files = depset(transitive = files_depsets) + + # Also include files from npm fine grained deps as inputs. + # These deps are identified by the NodeModuleInfo provider. + node_modules_depsets = [] + for dep in ctx.attr.deps + ctx.attr.runtime_deps: + if NodeModuleInfo in dep: + node_modules_depsets.append(dep[NodeModuleInfo].sources) + node_modules = depset(transitive = node_modules_depsets) amd_names_shim = _write_amd_names_shim(ctx) @@ -250,11 +261,14 @@ $KARMA ${{ARGV[@]}} ) config_sources = [] - if hasattr(ctx.file, "config_file"): - if ctx.file.config_file: + + # Check for config_file since ts_web_test does not have this attribute + if hasattr(ctx.attr, "config_file") and ctx.attr.config_file: + # TODO: switch to JSModuleInfo when it is available + if JSNamedModuleInfo in ctx.attr.config_file: + config_sources = ctx.attr.config_file[JSNamedModuleInfo].sources.to_list() + else: config_sources = [ctx.file.config_file] - if hasattr(ctx.attr.config_file, "node_sources"): - config_sources = ctx.attr.config_file.node_sources.to_list() runfiles = [ configuration, @@ -270,7 +284,7 @@ $KARMA ${{ARGV[@]}} return ctx.runfiles( files = runfiles, - transitive_files = files, + transitive_files = depset(transitive = [files, node_modules]), ).merge(ctx.attr.karma[DefaultInfo].data_runfiles) def _karma_web_test_impl(ctx): diff --git a/packages/karma/src/web_test.bzl b/packages/karma/src/web_test.bzl index 7ebb58b259..23c3433744 100644 --- a/packages/karma/src/web_test.bzl +++ b/packages/karma/src/web_test.bzl @@ -13,7 +13,7 @@ # limitations under the License. "Common web_test attributes" -load("@build_bazel_rules_nodejs//internal/common:sources_aspect.bzl", "sources_aspect") +load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "node_modules_aspect") # Attributes shared by any web_test rule (ts_web_test, karma_web_test, protractor_web_test) COMMON_WEB_TEST_ATTRS = { @@ -35,6 +35,6 @@ COMMON_WEB_TEST_ATTRS = { "deps": attr.label_list( doc = "Other targets which produce JavaScript such as `ts_library`", allow_files = True, - aspects = [sources_aspect], + aspects = [node_modules_aspect], ), } diff --git a/packages/labs/src/protobufjs/ts_proto_library.bzl b/packages/labs/src/protobufjs/ts_proto_library.bzl index dc699945da..34561117cf 100644 --- a/packages/labs/src/protobufjs/ts_proto_library.bzl +++ b/packages/labs/src/protobufjs/ts_proto_library.bzl @@ -14,7 +14,7 @@ "Protocol Buffers" load("@build_bazel_rules_nodejs//:declaration_provider.bzl", "DeclarationInfo") -load("@build_bazel_rules_nodejs//:providers.bzl", "JSEcmaScriptModuleInfo") +load("@build_bazel_rules_nodejs//:providers.bzl", "JSEcmaScriptModuleInfo", "JSNamedModuleInfo") def _run_pbjs(actions, executable, output_name, proto_files, suffix = ".js", wrap = "amd", amd_name = ""): js_file = actions.declare_file(output_name + suffix) @@ -118,6 +118,9 @@ def _ts_proto_library(ctx): declarations = declarations, transitive_declarations = declarations, ), + JSNamedModuleInfo( + sources = es5_sources, + ), JSEcmaScriptModuleInfo( sources = es6_sources, ), diff --git a/packages/protractor/docs/BUILD.bazel b/packages/protractor/docs/BUILD.bazel index 3d1521037a..f4fba32997 100644 --- a/packages/protractor/docs/BUILD.bazel +++ b/packages/protractor/docs/BUILD.bazel @@ -31,6 +31,7 @@ stardoc( # `@build_bazel_rules_nodejs//foo:bzl` style deps are not found # by the doc generator: # ``` + # Exception in thread "main" java.lang.IllegalStateException: File external/npm_bazel_jasmine/jasmine_node_test.bzl imported '@build_bazel_rules_nodejs//internal/common:devmode_js_sources.bzl', yet internal/common/devmode_js_sources.bzl was not found, even at roots [.]. # ``` "//:bzl", "//internal/common:bzl", diff --git a/packages/protractor/src/protractor_web_test.bzl b/packages/protractor/src/protractor_web_test.bzl index 69dfa02b98..3b8f22c153 100644 --- a/packages/protractor/src/protractor_web_test.bzl +++ b/packages/protractor/src/protractor_web_test.bzl @@ -14,7 +14,8 @@ "Run end-to-end tests with Protractor" load("@build_bazel_rules_nodejs//:index.bzl", "nodejs_binary") -load("@build_bazel_rules_nodejs//internal/common:sources_aspect.bzl", "sources_aspect") +load("@build_bazel_rules_nodejs//:providers.bzl", "JSNamedModuleInfo") +load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleInfo", "node_modules_aspect") load("@build_bazel_rules_nodejs//internal/common:windows_utils.bzl", "create_windows_native_launcher_script", "is_windows") load("@io_bazel_rules_webtesting//web:web.bzl", "web_test_suite") load("@io_bazel_rules_webtesting//web/internal:constants.bzl", "DEFAULT_WRAPPED_TEST_TAGS") @@ -36,12 +37,25 @@ def _protractor_web_test_impl(ctx): sibling = ctx.outputs.script, ) - files = depset(ctx.files.srcs) - for d in ctx.attr.deps: - if hasattr(d, "node_sources"): - files = depset(transitive = [files, d.node_sources]) - elif hasattr(d, "files"): - files = depset(transitive = [files, d.files]) + files_depsets = [depset(ctx.files.srcs)] + for dep in ctx.attr.deps: + if JSNamedModuleInfo in dep: + files_depsets.append(dep[JSNamedModuleInfo].sources) + if not JSNamedModuleInfo in dep and not NodeModuleInfo in dep and hasattr(dep, "files"): + # These are javascript files provided by DefaultInfo from a direct + # dep that has no JSNamedModuleInfo provider or NodeModuleInfo + # provider (not an npm dep). These files must be in named AMD or named + # UMD format. + files_depsets.append(dep.files) + files = depset(transitive = files_depsets) + + # Also include files from npm fine grained deps as inputs. + # These deps are identified by the NodeModuleInfo provider. + node_modules_depsets = [] + for dep in ctx.attr.deps: + if NodeModuleInfo in dep: + node_modules_depsets.append(dep[NodeModuleInfo].sources) + node_modules = depset(transitive = node_modules_depsets) specs = [ _to_manifest_path(ctx, f) @@ -49,24 +63,26 @@ def _protractor_web_test_impl(ctx): ] configuration_sources = [] - if ctx.file.configuration: - configuration_sources = [ctx.file.configuration] - if hasattr(ctx.attr.configuration, "node_sources"): - configuration_sources = ctx.attr.configuration.node_sources.to_list() - - configuration_file = ctx.file.configuration - if hasattr(ctx.attr.configuration, "typescript"): - configuration_file = ctx.attr.configuration.typescript.es5_sources.to_list()[0] + configuration_file = None + if ctx.attr.configuration: + # TODO: switch to JSModuleInfo when it is available + if JSNamedModuleInfo in ctx.attr.configuration: + configuration_sources = ctx.attr.configuration[JSNamedModuleInfo].sources.to_list() + configuration_file = ctx.attr.configuration[JSNamedModuleInfo].sources.to_list()[0] + else: + configuration_sources = [ctx.file.configuration] + configuration_file = ctx.file.configuration on_prepare_sources = [] - if ctx.file.on_prepare: - on_prepare_sources = [ctx.file.on_prepare] - if hasattr(ctx.attr.on_prepare, "node_sources"): - on_prepare_sources = ctx.attr.on_prepare.node_sources.to_list() - - on_prepare_file = ctx.file.on_prepare - if hasattr(ctx.attr.on_prepare, "typescript"): - on_prepare_file = ctx.attr.on_prepare.typescript.es5_sources.to_list()[0] + on_prepare_file = None + if ctx.attr.on_prepare: + # TODO: switch to JSModuleInfo when it is available + if JSNamedModuleInfo in ctx.attr.on_prepare: + on_prepare_sources = ctx.attr.on_prepare[JSNamedModuleInfo].sources.to_list() + on_prepare_file = ctx.attr.on_prepare[JSNamedModuleInfo].sources.to_list()[0] + else: + on_prepare_sources = [ctx.file.on_prepare] + on_prepare_file = ctx.file.on_prepare ctx.actions.expand_template( output = configuration, @@ -127,7 +143,7 @@ $PROTRACTOR $CONF files = depset([ctx.outputs.script]), runfiles = ctx.runfiles( files = runfiles, - transitive_files = files, + transitive_files = depset(transitive = [files, node_modules]), # Propagate protractor_bin and its runfiles collect_data = True, collect_default = True, @@ -149,7 +165,6 @@ _protractor_web_test = rule( "configuration": attr.label( doc = "Protractor configuration file", allow_single_file = True, - aspects = [sources_aspect], ), "data": attr.label_list( doc = "Runtime dependencies", @@ -159,7 +174,6 @@ _protractor_web_test = rule( If the script exports a function which returns a promise, protractor will wait for the promise to resolve before beginning tests.""", allow_single_file = True, - aspects = [sources_aspect], ), "protractor": attr.label( doc = "Protractor executable target", @@ -176,7 +190,7 @@ _protractor_web_test = rule( "deps": attr.label_list( doc = "Other targets which produce JavaScript such as `ts_library`", allow_files = True, - aspects = [sources_aspect], + aspects = [node_modules_aspect], ), "_conf_tmpl": attr.label( default = Label(_CONF_TMPL), diff --git a/packages/protractor/test/protractor-2/BUILD.bazel b/packages/protractor/test/protractor-2/BUILD.bazel index fb49f3e4ee..5e6ee6fb86 100644 --- a/packages/protractor/test/protractor-2/BUILD.bazel +++ b/packages/protractor/test/protractor-2/BUILD.bazel @@ -1,6 +1,7 @@ -load("@build_bazel_rules_nodejs//:index.bzl", "rollup_bundle") load("@npm//http-server:index.bzl", "http_server") load("@npm_bazel_protractor//:index.from_src.bzl", "protractor_web_test_suite") +load("@npm_bazel_rollup//:index.from_src.bzl", "rollup_bundle") +load("@npm_bazel_terser//:index.from_src.bzl", "terser_minified") load("@npm_bazel_typescript//:index.bzl", "ts_config") load("@npm_bazel_typescript//:index.from_src.bzl", "ts_devserver", "ts_library") @@ -25,16 +26,20 @@ ts_devserver( rollup_bundle( name = "bundle", - enable_code_splitting = False, entry_point = ":app.ts", deps = [":app"], ) +terser_minified( + name = "bundle.min", + src = ":bundle", +) + http_server( name = "prodserver", data = [ "index.html", - ":bundle.min.js", + ":bundle.min", ], # This repeats the default, but is here for coverage # to make sure the generated index.bzl handles it diff --git a/packages/typescript/src/internal/build_defs.bzl b/packages/typescript/src/internal/build_defs.bzl index 76b041445d..01386e28e0 100644 --- a/packages/typescript/src/internal/build_defs.bzl +++ b/packages/typescript/src/internal/build_defs.bzl @@ -14,8 +14,8 @@ "TypeScript compilation" -load("@build_bazel_rules_nodejs//:providers.bzl", "transitive_js_ecma_script_module_info") -load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleSources", "collect_node_modules_aspect") +load("@build_bazel_rules_nodejs//:providers.bzl", "transitive_js_ecma_script_module_info", "transitive_js_named_module_info") +load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleInfo", "node_modules_aspect") # pylint: disable=unused-argument # pylint: disable=missing-docstring @@ -46,7 +46,7 @@ def _trim_package_node_modules(package_name): # but wouldn't work for other rules like nodejs_binary def _uses_bazel_managed_node_modules(ctx): # If the user put a filegroup as the node_modules it will have no provider - return NodeModuleSources in ctx.attr.node_modules + return NodeModuleInfo in ctx.attr.node_modules # This function is similar but slightly different than _compute_node_modules_root # in /internal/node/node.bzl. TODO(gregmagolan): consolidate these functions @@ -61,8 +61,8 @@ def _compute_node_modules_root(ctx): """ node_modules_root = None if ctx.attr.node_modules: - if NodeModuleSources in ctx.attr.node_modules: - node_modules_root = "/".join(["external", ctx.attr.node_modules[NodeModuleSources].workspace, "node_modules"]) + if NodeModuleInfo in ctx.attr.node_modules: + node_modules_root = "/".join(["external", ctx.attr.node_modules[NodeModuleInfo].workspace, "node_modules"]) elif ctx.files.node_modules: # ctx.files.node_modules is not an empty list node_modules_root = "/".join([f for f in [ @@ -71,8 +71,8 @@ def _compute_node_modules_root(ctx): "node_modules", ] if f]) for d in ctx.attr.deps: - if NodeModuleSources in d: - possible_root = "/".join(["external", d[NodeModuleSources].workspace, "node_modules"]) + if NodeModuleInfo in d: + possible_root = "/".join(["external", d[NodeModuleInfo].workspace, "node_modules"]) if not node_modules_root: node_modules_root = possible_root elif node_modules_root != possible_root: @@ -118,11 +118,11 @@ def _compile_action(ctx, inputs, outputs, tsconfig_file, node_opts, description action_inputs.extend(_filter_ts_inputs(ctx.files.node_modules)) # Also include files from npm fine grained deps as action_inputs. - # These deps are identified by the NodeModuleSources provider. + # These deps are identified by the NodeModuleInfo provider. for d in ctx.attr.deps: - if NodeModuleSources in d: + if NodeModuleInfo in d: # Note: we can't avoid calling .to_list() on sources - action_inputs.extend(_filter_ts_inputs(d[NodeModuleSources].sources.to_list())) + action_inputs.extend(_filter_ts_inputs(d[NodeModuleInfo].sources.to_list())) if ctx.file.tsconfig: action_inputs.append(ctx.file.tsconfig) @@ -275,12 +275,16 @@ def _ts_library_impl(ctx): # See design doc https://docs.google.com/document/d/1ggkY5RqUkVL4aQLYm7esRW978LgX3GUCnQirrk5E1C0/edit# # and issue https://github.com/bazelbuild/rules_nodejs/issues/57 for more details. ts_providers["providers"].extend([ + transitive_js_named_module_info( + sources = ts_providers["typescript"]["es5_sources"], + deps = ctx.attr.deps, + ), transitive_js_ecma_script_module_info( sources = ts_providers["typescript"]["es6_sources"], deps = ctx.attr.deps, ), - # TODO: Add remaining shared JS providers from design doc - # (JSModuleInfo and JSNamedModuleInfo) and remove legacy "typescript" provider + # TODO: Add remaining shared JS provider from design doc + # (JSModuleInfo) and remove legacy "typescript" provider # once it is no longer needed. ]) @@ -412,7 +416,7 @@ either: doc = "If using tsickle, instruct it to translate types to ClosureJS format", ), "deps": attr.label_list( - aspects = DEPS_ASPECTS + [collect_node_modules_aspect], + aspects = DEPS_ASPECTS + [node_modules_aspect], doc = "Compile-time dependencies, typically other ts_library targets", ), }), diff --git a/packages/typescript/src/internal/devserver/ts_devserver.bzl b/packages/typescript/src/internal/devserver/ts_devserver.bzl index 66a80c35b8..64abf34d70 100644 --- a/packages/typescript/src/internal/devserver/ts_devserver.bzl +++ b/packages/typescript/src/internal/devserver/ts_devserver.bzl @@ -14,7 +14,8 @@ "Simple development server" -load("@build_bazel_rules_nodejs//internal/common:sources_aspect.bzl", "sources_aspect") +load("@build_bazel_rules_nodejs//:providers.bzl", "JSNamedModuleInfo") +load("@build_bazel_rules_nodejs//internal/common:node_module_info.bzl", "NodeModuleInfo", "node_modules_aspect") load( "@build_bazel_rules_nodejs//internal/js_library:js_library.bzl", "write_amd_names_shim", @@ -33,15 +34,25 @@ def _to_manifest_path(ctx, file): return ctx.workspace_name + "/" + file.short_path def _ts_devserver(ctx): - files = depset() - dev_scripts = depset() - for d in ctx.attr.deps: - if hasattr(d, "node_sources"): - files = depset(transitive = [files, d.node_sources]) - elif hasattr(d, "files"): - files = depset(transitive = [files, d.files]) - if hasattr(d, "dev_scripts"): - dev_scripts = depset(transitive = [dev_scripts, d.dev_scripts]) + files_depsets = [] + for dep in ctx.attr.deps: + if JSNamedModuleInfo in dep: + files_depsets.append(dep[JSNamedModuleInfo].sources) + if not JSNamedModuleInfo in dep and not NodeModuleInfo in dep and hasattr(dep, "files"): + # These are javascript files provided by DefaultInfo from a direct + # dep that has no JSNamedModuleInfo provider or NodeModuleInfo + # provider (not an npm dep). These files must be in named AMD or named + # UMD format. + files_depsets.append(dep.files) + files = depset(transitive = files_depsets) + + # Also include files from npm fine grained deps as inputs. + # These deps are identified by the NodeModuleInfo provider. + node_modules_depsets = [] + for dep in ctx.attr.deps: + if NodeModuleInfo in dep: + node_modules_depsets.append(dep[NodeModuleInfo].sources) + node_modules = depset(transitive = node_modules_depsets) if ctx.label.workspace_root: # We need the workspace_name for the target being visited. @@ -59,6 +70,7 @@ def _ts_devserver(ctx): ctx.actions.write(ctx.outputs.manifest, "".join([ workspace_name + "/" + f.short_path + "\n" for f in files.to_list() + if f.path.endswith(".js") ])) amd_names_shim = ctx.actions.declare_file( @@ -75,7 +87,6 @@ def _ts_devserver(ctx): script_files.append(ctx.file._requirejs_script) script_files.append(amd_names_shim) script_files.extend(ctx.files.scripts) - script_files.extend(dev_scripts.to_list()) ctx.actions.write(ctx.outputs.scripts_manifest, "".join([ workspace_name + "/" + f.short_path + "\n" for f in script_files @@ -128,7 +139,7 @@ def _ts_devserver(ctx): files = devserver_runfiles, # We don't expect executable targets to depend on the devserver, but if they do, # they can see the JavaScript code. - transitive_files = depset(ctx.files.data, transitive = [files]), + transitive_files = depset(ctx.files.data, transitive = [files, node_modules]), collect_data = True, collect_default = True, ), @@ -192,7 +203,7 @@ ts_devserver = rule( "deps": attr.label_list( doc = "Targets that produce JavaScript, such as `ts_library`", allow_files = True, - aspects = [sources_aspect], + aspects = [node_modules_aspect], ), "_bash_runfile_helpers": attr.label(default = Label("@bazel_tools//tools/bash/runfiles")), "_injector": attr.label( diff --git a/packages/typescript/test/devmode_consumer/devmode_consumer.bzl b/packages/typescript/test/devmode_consumer/devmode_consumer.bzl index b23a4b421d..ed90e109cf 100644 --- a/packages/typescript/test/devmode_consumer/devmode_consumer.bzl +++ b/packages/typescript/test/devmode_consumer/devmode_consumer.bzl @@ -15,26 +15,23 @@ """Example of a rule that requires es2015 (devmode) inputs. """ -load("@build_bazel_rules_nodejs//internal/common:sources_aspect.bzl", "sources_aspect") +load("@build_bazel_rules_nodejs//:providers.bzl", "JSNamedModuleInfo") def _devmode_consumer(ctx): - files = depset() - - # Since we apply the sources_aspect to our deps below, we can iterate through - # the deps and grab the attribute attached by that aspect, which is called - # "node_sources". - # See https://github.com/bazelbuild/rules_nodejs/blob/master/internal/node.bzl - for d in ctx.attr.deps: - files = depset(transitive = [files, d.node_sources]) + sources_depsets = [] + for dep in ctx.attr.deps: + if JSNamedModuleInfo in dep: + sources_depsets.append(dep[JSNamedModuleInfo].sources) + sources = depset(transitive = sources_depsets) return [DefaultInfo( - files = files, - runfiles = ctx.runfiles(files.to_list()), + files = sources, + runfiles = ctx.runfiles(transitive_files = sources), )] devmode_consumer = rule( implementation = _devmode_consumer, attrs = { - "deps": attr.label_list(aspects = [sources_aspect]), + "deps": attr.label_list(), }, ) diff --git a/providers.bzl b/providers.bzl index 63512fecbe..9c9f5bf0f4 100644 --- a/providers.bzl +++ b/providers.bzl @@ -22,6 +22,51 @@ If users really need to produce both in a single build, they'll need two rules w differing 'debug' attributes. """ +JSNamedModuleInfo = provider( + doc = """JavaScript files whose module name is self-contained. + +For example named AMD/UMD or goog.module format. +These files can be efficiently served with the concatjs bundler. +These outputs should be named "foo.umd.js" +(note that renaming it from "foo.js" doesn't affect the module id) + +Historical note: this was the typescript.es5_sources output. +""", + fields = { + "sources": "depset of direct and transitive JavaScript files and sourcemaps", + }, +) + +def transitive_js_named_module_info(sources, deps = []): + """Constructs a JSNamedModuleInfo including all transitive sources from JSNamedModuleInfo providers in a list of deps. + +Returns a single JSNamedModuleInfo. +""" + return combine_js_named_module_info([JSNamedModuleInfo(sources = sources)] + collect_js_named_module_infos(deps)) + +def combine_js_named_module_info(modules): + """Combines all JavaScript sources and sourcemaps from a list of JSNamedModuleInfo providers. + +Returns a single JSNamedModuleInfo. +""" + sources_depsets = [] + for module in modules: + sources_depsets.extend([module.sources]) + return JSNamedModuleInfo( + sources = depset(transitive = sources_depsets), + ) + +def collect_js_named_module_infos(deps): + """Collects all JSNamedModuleInfo providers from a list of deps. + +Returns a list of JSNamedModuleInfo providers. +""" + modules = [] + for dep in deps: + if JSNamedModuleInfo in dep: + modules.extend([dep[JSNamedModuleInfo]]) + return modules + JSEcmaScriptModuleInfo = provider( doc = """JavaScript files (and sourcemaps) that are intended to be consumed by downstream tooling.