Skip to content

Commit 079c413

Browse files
committed
Bootstrap source stdlib from rust-src
1 parent b6dd781 commit 079c413

20 files changed

Lines changed: 1088 additions & 81 deletions

MODULE.bazel

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -58,7 +58,7 @@ bazel_dep(name = "protobuf", version = "34.0.bcr.1", repo_name = "com_google_pro
5858
bazel_dep(name = "rules_cc", version = "0.2.8")
5959
bazel_dep(name = "rules_proto", version = "7.1.0")
6060
bazel_dep(name = "rules_python", version = "1.6.3")
61-
bazel_dep(name = "llvm", version = "0.7.7")
61+
bazel_dep(name = "llvm", version = "0.8.0")
6262
bazel_dep(name = "aspect_tools_telemetry", version = "0.3.3")
6363

6464
osx = use_extension("@llvm//extensions:osx.bzl", "osx")

MODULE.bazel.lock

Lines changed: 4 additions & 4 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

rs/platforms/config/declare_config_settings.bzl

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,8 +1,8 @@
11
"""Config settings for Rust target triples."""
22

3-
load("//rs/platforms:triples.bzl", "SUPPORTED_TARGET_TRIPLES", "triple_to_constraint_set")
3+
load("//rs/platforms:triples.bzl", "ALL_TARGET_TRIPLES", "triple_to_constraint_set")
44

5-
def declare_config_settings(targets = SUPPORTED_TARGET_TRIPLES):
5+
def declare_config_settings(targets = ALL_TARGET_TRIPLES):
66
for target_triple in targets:
77
native.config_setting(
88
name = target_triple,

rs/platforms/declare_platforms.bzl

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,8 +1,8 @@
11
"""Platform definitions for Rust target triples."""
22

3-
load("//rs/platforms:triples.bzl", "SUPPORTED_TARGET_TRIPLES", "triple_to_constraint_set")
3+
load("//rs/platforms:triples.bzl", "ALL_TARGET_TRIPLES", "triple_to_constraint_set")
44

5-
def declare_platforms(targets = SUPPORTED_TARGET_TRIPLES):
5+
def declare_platforms(targets = ALL_TARGET_TRIPLES):
66
for target_triple in targets:
77
native.platform(
88
name = target_triple,

rs/platforms/triples.bzl

Lines changed: 36 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -36,7 +36,7 @@ SUPPORTED_EXEC_TRIPLES = [
3636
]
3737

3838
# See https://doc.rust-lang.org/beta/rustc/platform-support.html
39-
SUPPORTED_TARGET_TRIPLES = [
39+
SUPPORTED_TIER_1_AND_2_TRIPLES = [
4040
# Tier 1
4141
"aarch64-apple-darwin", # ARM64 macOS (11.0+, Big Sur+)
4242
"aarch64-pc-windows-msvc", # ARM64 Windows MSVC
@@ -142,6 +142,40 @@ SUPPORTED_TARGET_TRIPLES = [
142142
"x86_64-unknown-none", # * Freestanding/bare-metal x86_64, softfloat
143143
#"x86_64-unknown-redox", # ✓ Redox OS
144144
"x86_64-unknown-uefi", # ? 64-bit UEFI
145+
]
145146

146-
# No Tier3 support.
147+
SUPPORTED_TIER_3_TRIPLES = [
148+
"aarch64-unknown-freebsd",
149+
"aarch64-unknown-netbsd",
150+
"aarch64-unknown-nto-qnx710",
151+
"aarch64-unknown-openbsd",
152+
"arm64e-apple-darwin",
153+
"arm64e-apple-ios",
154+
"armv7-unknown-freebsd",
155+
"armv7-unknown-netbsd-eabihf",
156+
"bpfeb-unknown-none",
157+
"bpfel-unknown-none",
158+
"i386-apple-ios",
159+
"i686-apple-darwin",
160+
"i686-unknown-netbsd",
161+
"i686-unknown-openbsd",
162+
"powerpc-unknown-freebsd",
163+
"powerpc-unknown-linux-musl",
164+
"powerpc-unknown-netbsd",
165+
"powerpc-unknown-openbsd",
166+
"powerpc64-unknown-freebsd",
167+
"powerpc64-unknown-openbsd",
168+
"powerpc64le-unknown-freebsd",
169+
"riscv64-linux-android",
170+
"riscv64gc-unknown-freebsd",
171+
"riscv64gc-unknown-fuchsia",
172+
"riscv64gc-unknown-netbsd",
173+
"riscv64gc-unknown-openbsd",
174+
"s390x-unknown-linux-musl",
175+
"sparc64-unknown-netbsd",
176+
"sparc64-unknown-openbsd",
177+
"wasm64-unknown-unknown",
178+
"x86_64-unknown-openbsd",
147179
]
180+
181+
ALL_TARGET_TRIPLES = SUPPORTED_TIER_1_AND_2_TRIPLES + SUPPORTED_TIER_3_TRIPLES

rs/private/BUILD.bazel

Lines changed: 37 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,11 +1,36 @@
11
load("@bazel_lib//:bzl_library.bzl", "bzl_library")
2+
load("@bazel_skylib//rules:common_settings.bzl", "bool_setting")
3+
load("@rules_rust//rust:defs.bzl", "rust_stdlib_filegroup")
24
load(":all_crate_deps_test.bzl", "all_crate_deps_tests")
5+
load(":cargo_workspace_graph_test.bzl", "cargo_workspace_graph_tests")
36
load(":cfg_parser_test.bzl", "cfg_parser_tests")
47
load(":lint_flags_test.bzl", "lint_flags_tests")
58
load(":semver_test.bzl", "semver_select_tests")
69

10+
bool_setting(
11+
name = "source_stdlib_building",
12+
build_setting_default = False,
13+
visibility = ["//visibility:public"],
14+
)
15+
16+
config_setting(
17+
name = "is_source_stdlib_building",
18+
flag_values = {
19+
":source_stdlib_building": "true",
20+
},
21+
visibility = ["//visibility:public"],
22+
)
23+
24+
rust_stdlib_filegroup(
25+
name = "empty_stdlib",
26+
srcs = [],
27+
visibility = ["//visibility:public"],
28+
)
29+
730
all_crate_deps_tests()
831

32+
cargo_workspace_graph_tests()
33+
934
cfg_parser_tests()
1035

1136
lint_flags_tests()
@@ -109,6 +134,13 @@ bzl_library(
109134
deps = ["@bazel_lib//lib:repo_utils"],
110135
)
111136

137+
bzl_library(
138+
name = "source_stdlib",
139+
srcs = ["source_stdlib.bzl"],
140+
visibility = ["//rs:__subpackages__"],
141+
deps = ["@rules_rust//rust:bzl_lib"],
142+
)
143+
112144
bzl_library(
113145
name = "git_cargo_workspace_repository",
114146
srcs = ["git_cargo_workspace_repository.bzl"],
@@ -169,6 +201,11 @@ bzl_library(
169201
srcs = ["rust_src_repository.bzl"],
170202
visibility = ["//rs:__subpackages__"],
171203
deps = [
204+
":cargo_workspace_graph",
205+
":repository_utils",
206+
":toml2json",
207+
"//rs/platforms:triples",
208+
"@bazel_skylib//lib:paths",
172209
"@bazel_tools//tools/build_defs/repo:utils.bzl",
173210
"@rules_rust//rust/private:bzl_lib",
174211
],

rs/private/cargo_workspace_graph.bzl

Lines changed: 85 additions & 29 deletions
Original file line numberDiff line numberDiff line change
@@ -131,7 +131,10 @@ def cargo_toml_dep_to_dep_dict(dep, spec, package_name, workspace_cargo_toml_jso
131131
return inherited
132132

133133
if type(spec) == "string":
134-
converted = {"name": dep}
134+
converted = {
135+
"name": dep,
136+
"req": spec,
137+
}
135138
else:
136139
converted = {
137140
"name": dep,
@@ -141,6 +144,8 @@ def cargo_toml_dep_to_dep_dict(dep, spec, package_name, workspace_cargo_toml_jso
141144
}
142145
if "package" in spec:
143146
converted["package"] = spec["package"]
147+
if spec.get("version"):
148+
converted["req"] = spec["version"]
144149

145150
if is_build:
146151
converted["kind"] = "build"
@@ -202,8 +207,11 @@ def prepare_possible_deps(dependencies, converter = None, skip_internal_rustc_pl
202207

203208
return possible_deps
204209

210+
def dep_package_name(dep):
211+
return dep.get("package") or dep["name"]
212+
205213
def compute_package_fq_deps(package, versions_by_name, strict = True):
206-
possible_dep_fq_crate_by_name = {}
214+
possible_dep_fq_crates_by_name = {}
207215

208216
for maybe_fq_dep in package.get("dependencies", []):
209217
idx = maybe_fq_dep.find(" ")
@@ -219,9 +227,36 @@ def compute_package_fq_deps(package, versions_by_name, strict = True):
219227
dep = maybe_fq_dep[:idx]
220228
resolved_version = maybe_fq_dep[idx + 1:]
221229

222-
possible_dep_fq_crate_by_name[dep] = fq_crate(dep, resolved_version)
230+
existing = possible_dep_fq_crates_by_name.get(dep)
231+
if not existing:
232+
existing = []
233+
possible_dep_fq_crates_by_name[dep] = existing
234+
existing.append(fq_crate(dep, resolved_version))
235+
236+
return possible_dep_fq_crates_by_name
237+
238+
def select_package_fq_dep(dep, fq_deps):
239+
dep_package = dep_package_name(dep)
240+
candidates = fq_deps.get(dep_package)
241+
if not candidates:
242+
return None
243+
244+
if len(candidates) == 1:
245+
return candidates[0]
223246

224-
return possible_dep_fq_crate_by_name
247+
req = dep.get("req")
248+
if not req:
249+
return None
250+
251+
versions = [
252+
candidate[len(dep_package) + 1:]
253+
for candidate in candidates
254+
]
255+
version = select_matching_version(req, versions)
256+
if not version:
257+
return None
258+
259+
return fq_crate(dep_package, version)
225260

226261
def compute_workspace_fq_deps(workspace_members, versions_by_name):
227262
workspace_fq_deps = {}
@@ -252,41 +287,55 @@ def _relative_to_workspace(path, workspace_root):
252287
rel_parts = [".."] * (len(root_parts) - common) + path_parts[common:]
253288
return "/".join(rel_parts) if rel_parts else "."
254289

255-
def split_lockfile_packages(hub_name, cargo_metadata, workspace_cargo_toml_json, all_packages):
256-
workspace_root = normalize_path(cargo_metadata["workspace_root"])
257-
workspace_root_prefix = workspace_root + "/"
258-
259-
workspace_member_keys = {}
260-
for package in cargo_metadata["packages"]:
261-
workspace_member_keys[(package["name"], package["version"])] = True
290+
def cargo_metadata_dep_paths_by_name(cargo_metadata, workspace_root):
291+
package_dirs = {}
262292

263-
dep_paths_by_name = {}
264293
for package in cargo_metadata["packages"]:
265294
for dep in package.get("dependencies", []):
266295
dep_path = dep.get("path")
267-
if dep_path:
268-
dep_paths_by_name[dep["name"]] = _relative_to_workspace(dep_path, workspace_root)
296+
if not dep_path:
297+
continue
298+
299+
package_dirs[dep["name"]] = _relative_to_workspace(dep_path, workspace_root)
300+
301+
return package_dirs
302+
303+
def cargo_toml_patch_paths_by_name(workspace_cargo_toml, workspace_root, workspace_package_dir = ""):
304+
workspace_root = normalize_path(workspace_root)
305+
workspace_root_prefix = workspace_root + "/"
306+
package_dirs = {}
269307

270-
patch_paths_by_name = {}
271-
for registry_patches in workspace_cargo_toml_json.get("patch", {}).values():
272-
for name, spec in registry_patches.items():
308+
for patches in workspace_cargo_toml.get("patch", {}).values():
309+
for name, spec in patches.items():
273310
if type(spec) != "dict":
274311
continue
275312

276313
patch_path = spec.get("path")
277314
if not patch_path:
278315
continue
279316

280-
if patch_path.startswith("/"):
317+
package = spec.get("package") or name
318+
if paths.is_absolute(patch_path):
281319
normalized = normalize_path(patch_path)
282320
if not normalized.startswith(workspace_root_prefix):
283321
fail("Patch path for %s points outside the workspace: %s" % (name, patch_path))
284-
rel_patch_path = normalized.removeprefix(workspace_root_prefix)
322+
package_dirs[package] = normalized.removeprefix(workspace_root_prefix)
285323
else:
286-
rel_patch_path = normalize_path(paths.normalize(patch_path))
324+
package_dirs[package] = normalize_path(paths.normalize(paths.join(workspace_package_dir, patch_path)))
287325

288-
patch_paths_by_name[name] = rel_patch_path
326+
return package_dirs
289327

328+
def split_lockfile_packages(hub_name, cargo_metadata, workspace_cargo_toml, all_packages, repo_root = None, workspace_package_dir = ""):
329+
if repo_root == None:
330+
repo_root = cargo_metadata["workspace_root"]
331+
repo_root = normalize_path(repo_root)
332+
333+
workspace_member_keys = {}
334+
for package in cargo_metadata["packages"]:
335+
workspace_member_keys[(package["name"], package["version"])] = True
336+
337+
dep_paths_by_name = cargo_metadata_dep_paths_by_name(cargo_metadata, repo_root)
338+
patch_paths_by_name = cargo_toml_patch_paths_by_name(workspace_cargo_toml, repo_root, workspace_package_dir)
290339
workspace_members = []
291340
packages = []
292341

@@ -305,21 +354,22 @@ def split_lockfile_packages(hub_name, cargo_metadata, workspace_cargo_toml_json,
305354
rel_path = patch_paths_by_name.get(pkg["name"]) or dep_paths_by_name.get(pkg["name"])
306355
local_path = rel_path
307356
if rel_path and not rel_path.startswith("/"):
308-
local_path = paths.join(workspace_root, rel_path)
357+
local_path = paths.join(repo_root, rel_path)
309358

310359
if not local_path:
311360
fail("Found a path dependency on %s %s but could not determine its path from Cargo.toml. Please declare it in [patch] or as a path dependency." % (pkg["name"], pkg["version"]))
312361

313362
pkg["source"] = "path+" + hub_name + "/" + rel_path
314363
pkg["local_path"] = local_path
364+
pkg["package_dir"] = rel_path
315365
packages.append(pkg)
316366

317367
return struct(
318368
packages = packages,
319369
workspace_members = workspace_members,
320370
)
321371

322-
def resolve_package_facts(packages, facts_by_fq_crate, platform_triples):
372+
def resolve_package_facts(packages, facts_by_fq_crate, platform_triples, skip_internal_rustc_placeholder_crates = True):
323373
feature_resolutions_by_fq_crate = {}
324374
versions_by_name = {}
325375

@@ -332,7 +382,10 @@ def resolve_package_facts(packages, facts_by_fq_crate, platform_triples):
332382

333383
fact = facts_by_fq_crate[fq_crate(name, version)]
334384
possible_features = fact["features"]
335-
possible_deps = prepare_possible_deps(fact["dependencies"])
385+
possible_deps = prepare_possible_deps(
386+
fact["dependencies"],
387+
skip_internal_rustc_placeholder_crates = skip_internal_rustc_placeholder_crates,
388+
)
336389
feature_resolutions = new_feature_resolutions(package_index, possible_deps, possible_features, platform_triples)
337390
package["feature_resolutions"] = feature_resolutions
338391
feature_resolutions_by_fq_crate[fq_crate(name, version)] = feature_resolutions
@@ -420,6 +473,7 @@ def resolve_cargo_workspace_members(
420473
debug,
421474
dep_label_prefix = None,
422475
allow_missing_resolved_deps = False,
476+
skip_internal_rustc_placeholder_crates = True,
423477
watch_manifests = False,
424478
use_legacy_rules_rust_platforms = False):
425479
platform_cfg_attrs = [triple_to_cfg_attrs(triple) for triple in platform_triples]
@@ -451,6 +505,7 @@ def resolve_cargo_workspace_members(
451505
possible_deps = prepare_possible_deps(
452506
package.get("dependencies", []),
453507
converter = cargo_metadata_dep_to_dep_dict,
508+
skip_internal_rustc_placeholder_crates = skip_internal_rustc_placeholder_crates,
454509
)
455510

456511
package_index = len(resolver_packages)
@@ -497,11 +552,12 @@ def resolve_cargo_workspace_members(
497552
for dep in package["dependencies"]:
498553
source = dep.get("source")
499554
dep_name = dep["name"]
500-
dep_fq = fq_deps.get(dep_name)
555+
dep_package = dep_package_name(dep)
556+
dep_fq = select_package_fq_dep(dep, fq_deps)
501557
dep_version = None
502558
if dep_fq:
503-
dep_version = dep_fq[len(dep_name) + 1:]
504-
is_first_party_dep = not source and dep_version and (dep_name, dep_version) in workspace_member_keys
559+
dep_version = dep_fq[len(dep_package) + 1:]
560+
is_first_party_dep = not source and dep_version and (dep_package, dep_version) in workspace_member_keys
505561

506562
if dep_fq and dep_fq not in feature_resolutions_by_fq_crate and allow_missing_resolved_deps:
507563
continue
@@ -510,13 +566,13 @@ def resolve_cargo_workspace_members(
510566
req = dep["req"]
511567
fq = dep_fq
512568
if req and fq:
513-
locked_version = fq[len(dep_name) + 1:]
569+
locked_version = fq[len(dep_package) + 1:]
514570
if not select_matching_version(req, [locked_version]):
515571
fail(("ERROR: Cargo.lock out of sync: %s requires %s %s but Cargo.lock has %s.\n\n" +
516572
"If this is incorrect, please set `validate_lockfile = False` in `crate.from_cargo`\n" +
517573
"and file a bug at https://github.com/hermeticbuild/rules_rs/issues/new") % (
518574
package["name"],
519-
dep_name,
575+
dep_package,
520576
req,
521577
locked_version,
522578
))

0 commit comments

Comments
 (0)