Skip to content

Commit

Permalink
[dart2wasm] Build product snapshot when building for the SDK.
Browse files Browse the repository at this point in the history
The `dartaotruntime` is built in `product` mode even when we do a release build. This CL wires up a product flag so we always build the Dart2Wasm product snapshot when creating the SDK.

Change-Id: Ic8c6a6da180a47a19ba818d7c449f712c9e60123
Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/264887
Reviewed-by: Slava Egorov <[email protected]>
Commit-Queue: Joshua Litt <[email protected]>
Reviewed-by: Jake Macdonald <[email protected]>
  • Loading branch information
joshualitt authored and Commit Queue committed Oct 26, 2022
1 parent 478f2bb commit 1ed2a07
Show file tree
Hide file tree
Showing 5 changed files with 35 additions and 6 deletions.
8 changes: 6 additions & 2 deletions BUILD.gn
Original file line number Diff line number Diff line change
Expand Up @@ -109,8 +109,12 @@ group("dart2wasm_platform") {
"utils/dart2wasm:compile_dart2wasm_platform",
"utils/dart2wasm:dart2wasm_snapshot",
]
if (defined(is_product) && !is_product) {
deps += [ "utils/dart2wasm:dart2wasm_asserts_snapshot" ]
if (defined(is_product)) {
if (is_product) {
deps += [ "utils/dart2wasm:dart2wasm_product_snapshot" ]
} else {
deps += [ "utils/dart2wasm:dart2wasm_asserts_snapshot" ]
}
}
}

Expand Down
13 changes: 12 additions & 1 deletion build/dart/dart_action.gni
Original file line number Diff line number Diff line change
Expand Up @@ -347,6 +347,10 @@ template("dart_action") {
# packages (optional):
# The un-rebased path to the package_config.json file.
#
# force_product_mode (optional):
# Setting this to true will cause snapshot to be built in product mode even
# if dart_runtime_mode is not product.
#
# Forwarded to action() with the usual meaning:
# depfile
# deps
Expand All @@ -355,12 +359,19 @@ template("dart_action") {
# testonly
# visibility
template("gen_snapshot_action") {
product_mode =
(defined(dart_runtime_mode) && dart_runtime_mode == "release") ||
(defined(invoker.force_product_mode) && invoker.force_product_mode)
assert(
!defined(invoker.script),
"script must not be defined for $target_name. If there is a script use args instead.")
if (!_is_fuchsia || !use_prebuilt_dart_sdk) {
_built_tool_action(target_name) {
tool = "$_dart_root/runtime/bin:gen_snapshot"
if (product_mode) {
tool = "$_dart_root/runtime/bin:gen_snapshot_product"
} else {
tool = "$_dart_root/runtime/bin:gen_snapshot"
}
forward_variables_from(invoker,
[
"args",
Expand Down
6 changes: 3 additions & 3 deletions sdk/BUILD.gn
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ declare_args() {
# ......snapshots/
# ........analysis_server.dart.snapshot
# ........dart2js.dart.snapshot
# ........dart2wasm.dart.snapshot (if not on ia32)
# ........dart2wasm_product.snapshot (if not on ia32)
# ........dartdev.dart.snapshot
# ........dartdev.dill
# ........dartdevc.dart.snapshot
Expand Down Expand Up @@ -510,9 +510,9 @@ copy("copy_dart2wasm_snapshot") {
visibility = [ ":create_full_sdk" ]
deps = [
":copy_libraries",
"../utils/dart2wasm:dart2wasm_snapshot",
"../utils/dart2wasm:dart2wasm_product_snapshot",
]
sources = [ "$root_out_dir/dart2wasm.snapshot" ]
sources = [ "$root_out_dir/dart2wasm_product.snapshot" ]
outputs =
[ "$root_out_dir/$dart_sdk_output/bin/snapshots/{{source_file_part}}" ]
}
Expand Down
8 changes: 8 additions & 0 deletions utils/aot_snapshot.gni
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,9 @@ _dart_root = get_path_info("..", "abspath")

template("aot_snapshot") {
assert(defined(invoker.main_dart), "Must specify 'main_dart'")
product_mode =
(defined(dart_runtime_mode) && dart_runtime_mode == "release") ||
(defined(invoker.force_product_mode) && invoker.force_product_mode)
gen_kernel_args = []
if (defined(invoker.gen_kernel_args)) {
gen_kernel_args = invoker.gen_kernel_args
Expand Down Expand Up @@ -92,6 +95,9 @@ template("aot_snapshot") {
]
args += gen_kernel_args
args += [ rebase_path(main_dart) ]
if (product_mode) {
args += [ "-Ddart.vm.product=true" ]
}
}

# Create a snapshot from kernel built above.
Expand All @@ -114,5 +120,7 @@ template("aot_snapshot") {
] + gen_snapshot_args

args = [ rebase_path(dill) ]

force_product_mode = product_mode
}
}
6 changes: 6 additions & 0 deletions utils/dart2wasm/BUILD.gn
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,12 @@ aot_snapshot("dart2wasm_asserts_snapshot") {
gen_snapshot_args = [ "--enable-asserts" ]
}

aot_snapshot("dart2wasm_product_snapshot") {
main_dart = "../../pkg/dart2wasm/bin/dart2wasm.dart"
name = "dart2wasm_product"
force_product_mode = true
}

compile_platform("compile_dart2wasm_platform") {
single_root_scheme = "org-dartlang-sdk"
single_root_base = rebase_path("$sdk_root/")
Expand Down

0 comments on commit 1ed2a07

Please sign in to comment.