Skip to content

Commit

Permalink
fix(builtin): support directory_file_path entry_point in nodejs_binar…
Browse files Browse the repository at this point in the history
…y & nodejs_test when --bazel_patch_module_resolver is set
  • Loading branch information
Greg Magolan authored and alexeagle committed Jun 10, 2021
1 parent e980107 commit 50e6d1d
Show file tree
Hide file tree
Showing 3 changed files with 14 additions and 7 deletions.
6 changes: 3 additions & 3 deletions internal/node/launcher.sh
Original file line number Diff line number Diff line change
Expand Up @@ -361,9 +361,9 @@ else
# Always set up source-map-support using our vendored copy, just like the require_patch_script
register_source_map_support=$(rlocation build_bazel_rules_nodejs/third_party/github.com/source-map-support/register.js)
LAUNCHER_NODE_OPTIONS+=( "--require" "${register_source_map_support}" )
fi
if [[ -n "TEMPLATED_entry_point_main" ]]; then
MAIN="${MAIN}/"TEMPLATED_entry_point_main
if [[ -n "TEMPLATED_entry_point_main" ]]; then
MAIN="${MAIN}/"TEMPLATED_entry_point_main
fi
fi

# The EXPECTED_EXIT_CODE lets us write bazel tests which assert that
Expand Down
6 changes: 4 additions & 2 deletions internal/node/loader.js
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,10 @@ process.env.PATH = [require('path').dirname(process.execPath), process.env.PATH]
if (require.main === module) {
// Set the actual entry point in the arguments list.
// argv[0] == node, argv[1] == entry point.
// NB: 'TEMPLATED_entry_point' below is replaced during the build process.
var mainScript = process.argv[1] = 'TEMPLATED_entry_point';
// NB: 'TEMPLATED_entry_point_path' & 'TEMPLATED_entry_point' below are replaced during the build process.
var entryPointPath = 'TEMPLATED_entry_point_path';
var entryPointMain = 'TEMPLATED_entry_point_main';
var mainScript = process.argv[1] = entryPointMain ? `${entryPointPath}/${entryPointMain}` : entryPointPath;
try {
module.constructor._load(mainScript, this, /*isMain=*/true);
} catch (e) {
Expand Down
9 changes: 7 additions & 2 deletions internal/node/node.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -117,12 +117,17 @@ def _get_entry_point_file(ctx):
fail("entry_point must either be a file, or provide DirectoryFilePathInfo")

def _write_loader_script(ctx):
entry_point_path = _ts_to_js(_to_manifest_path(ctx, _get_entry_point_file(ctx)))
substitutions = {}
substitutions["TEMPLATED_entry_point_path"] = _ts_to_js(_to_manifest_path(ctx, _get_entry_point_file(ctx)))
if DirectoryFilePathInfo in ctx.attr.entry_point:
substitutions["TEMPLATED_entry_point_main"] = ctx.attr.entry_point[DirectoryFilePathInfo].path
else:
substitutions["TEMPLATED_entry_point_main"] = ""

ctx.actions.expand_template(
template = ctx.file._loader_template,
output = ctx.outputs.loader_script,
substitutions = {"TEMPLATED_entry_point": entry_point_path},
substitutions = substitutions,
is_executable = True,
)

Expand Down

0 comments on commit 50e6d1d

Please sign in to comment.