From 8b43e6ce4d327e418a5a93ef2d3cbe5fbbd37bda Mon Sep 17 00:00:00 2001 From: Greg Magolan Date: Fri, 4 Oct 2019 09:38:42 -0700 Subject: [PATCH] feat(typescript): add JSNamedModuleInfo provider to ts_library outputs --- WORKSPACE | 9 +-- 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 | 14 +++- 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/rollup/rollup_bundle.bzl | 21 ++--- packages/jasmine/docs/BUILD.bazel | 1 + packages/karma/docs/BUILD.bazel | 1 + packages/karma/src/karma_web_test.bzl | 77 +++++++++++-------- 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 ++- packages/rollup/src/rollup_bundle.bzl | 10 +-- .../typescript/src/internal/build_defs.bzl | 30 ++++---- .../src/internal/devserver/ts_devserver.bzl | 37 +++++---- .../devmode_consumer/devmode_consumer.bzl | 21 +++-- providers.bzl | 45 +++++++++++ 28 files changed, 349 insertions(+), 319 deletions(-) delete mode 100644 internal/common/sources_aspect.bzl diff --git a/WORKSPACE b/WORKSPACE index 60801ed33f..61b90fb148 100644 --- a/WORKSPACE +++ b/WORKSPACE @@ -67,11 +67,10 @@ yarn_install( name = "npm", # The @npm//:node_modules_filegroup generated by manual_build_file_contents # is used in the //packages/typescript/test/reference_types_directive:tsconfig_types - # test. For now we're still supporting node_modules as a filegroup tho this - # may change in the future. The default generated //:node_modules target is a - # node_module_library rule which provides NodeModuleInfo and NodeModuleSources - # but that rule is not yet in the public API and we have not yet dropped support - # for filegroup based node_modules target. + # test. For now we're still supporting node_modules as a filegroup tho this may + # change in the future. The default generated //:node_modules target is a node_module_library + # rule which provides NodeModuleInfo but that rule is not yet in the public API and we + # have not yet dropped support for filegroup based node_modules target. manual_build_file_contents = """ filegroup( name = "node_modules_filegroup", 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 710286f98c..ff3ee8c12d 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..3d4ea86308 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,15 @@ 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): + # Also include files from npm fine grained deps as inputs. + # These deps are identified by the NodeModuleInfo provider. + inputs_depsets = [] + for d in ctx.attr.data: + if NodeModuleInfo in d: + 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 +40,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 67ccb664c1..f364f75333 100644 --- a/internal/npm_install/generate_build_file.js +++ b/internal/npm_install/generate_build_file.js @@ -798,14 +798,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 = ''; @@ -852,7 +852,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 @@ -1026,4 +1026,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';\nimport * as crypto from 'crypto';\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_PATH = 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  const sha256sum = crypto.createHash('sha256');\n  sha256sum.update(fs.readFileSync(LOCK_FILE_PATH, {encoding: 'utf8'}));\n  writeFileSync(\n      path.posix.join(workspaceSourcePath, '_bazel_workspace_marker'),\n      `# Marker file to used by custom copy_repository rule\\n${sha256sum.digest('hex')}`);\n\n  bzlFile += `def install_${workspace}():\n    _maybe(\n        copy_repository,\n        name = \"${workspace}\",\n        marker_file = \"@${WORKSPACE}//_workspaces/${workspace}:_bazel_workspace_marker\",\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 =\n        pkgs.filter(\n                // Filter entries like\n                // \"_dir\":\"check-side-effects/node_modules/rollup-plugin-node-resolve\"\n                x => !x._dir.includes('/node_modules/') && !!x._moduleName &&\n                    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';\nimport * as crypto from 'crypto';\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_PATH = 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  const sha256sum = crypto.createHash('sha256');\n  sha256sum.update(fs.readFileSync(LOCK_FILE_PATH, {encoding: 'utf8'}));\n  writeFileSync(\n      path.posix.join(workspaceSourcePath, '_bazel_workspace_marker'),\n      `# Marker file to used by custom copy_repository rule\\n${sha256sum.digest('hex')}`);\n\n  bzlFile += `def install_${workspace}():\n    _maybe(\n        copy_repository,\n        name = \"${workspace}\",\n        marker_file = \"@${WORKSPACE}//_workspaces/${workspace}:_bazel_workspace_marker\",\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 =\n        pkgs.filter(\n                // Filter entries like\n                // \"_dir\":\"check-side-effects/node_modules/rollup-plugin-node-resolve\"\n                x => !x._dir.includes('/node_modules/') && !!x._moduleName &&\n                    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 96fa4d3023..d39599a44a 100644 --- a/internal/npm_install/generate_build_file.ts +++ b/internal/npm_install/generate_build_file.ts @@ -888,15 +888,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 ')} ],`; } @@ -948,7 +948,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/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 f3b5fa8758..2a182cfcf3 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 @@ -130,13 +134,14 @@ def _write_karma_config(ctx, files, amd_names_shim): # Thus they should come after the require.js script, but before any srcs or deps runtime_files = [] for dep in ctx.attr.runtime_deps: - if hasattr(dep, "typescript"): - for src in dep.typescript.es5_sources.to_list(): + if JSNamedModuleInfo in dep: + for src in dep[JSNamedModuleInfo].sources.to_list(): runtime_files.append(_to_manifest_path(ctx, src)) - elif hasattr(dep, "files"): + 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 "typescript" provider. These files must be in named - # AMD or named UMD format. + # dep that has no JSNamedModuleInfo provider or NodeModuleInfo + # provider (not an npm dep). These files must be in named AMD or named + # UMD format. for src in dep.files.to_list(): runtime_files.append(_to_manifest_path(ctx, src)) @@ -144,6 +149,7 @@ def _write_karma_config(ctx, files, amd_names_shim): 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 @@ -189,19 +195,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) @@ -252,11 +264,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, @@ -272,7 +287,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/rollup/src/rollup_bundle.bzl b/packages/rollup/src/rollup_bundle.bzl index 0e3babd356..d42c38c05a 100644 --- a/packages/rollup/src/rollup_bundle.bzl +++ b/packages/rollup/src/rollup_bundle.bzl @@ -1,7 +1,7 @@ "Rules for running Rollup under Bazel" load("@build_bazel_rules_nodejs//:providers.bzl", "JSEcmaScriptModuleInfo") -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("@build_bazel_rules_nodejs//internal/linker:link_node_modules.bzl", "module_mappings_aspect", "register_node_modules_linker") _DOC = """Runs the Rollup.js CLI under Bazel. @@ -152,7 +152,7 @@ Passed to the [`--sourcemap` option](https://github.com/rollup/rollup/blob/maste values = ["inline", "true", "false"], ), "deps": attr.label_list( - aspects = [module_mappings_aspect, collect_node_modules_aspect], + aspects = [module_mappings_aspect, node_modules_aspect], doc = """Other libraries that are required by the code, or by the rollup.config.js""", ), } @@ -250,9 +250,9 @@ def _rollup_bundle(ctx): deps_depsets.append(dep.files) # Also include files from npm deps as inputs. - # These deps are identified by the NodeModuleSources provider. - if NodeModuleSources in dep: - deps_depsets.append(dep[NodeModuleSources].sources) + # These deps are identified by the NodeModuleInfo provider. + if NodeModuleInfo in dep: + deps_depsets.append(dep[NodeModuleInfo].sources) deps_inputs = depset(transitive = deps_depsets).to_list() inputs = _filter_js(ctx.files.entry_point) + _filter_js(ctx.files.entry_points) + ctx.files.srcs + deps_inputs 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.