run: BoundFn hack

This commit is contained in:
Motiejus Jakštys 2024-11-03 22:20:46 +02:00
parent 25c64789dc
commit aff7e7ee74
2 changed files with 149 additions and 69 deletions

View File

@ -0,0 +1,48 @@
From f4392c034ca6fe003e828b8255c635003d4f6c36 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Motiejus=20Jak=C5=A1tys?= <motiejus@jakstys.lt>
Date: Sun, 3 Nov 2024 22:20:13 +0200
Subject: [PATCH] 0.10.0-675-g9d93b2ccf1 @TypeOf hack
---
lib/std/log.zig | 4 ++--
src/link/strtab.zig | 2 +-
2 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/lib/std/log.zig b/lib/std/log.zig
index 9ebe85c004..f174946565 100644
--- a/lib/std/log.zig
+++ b/lib/std/log.zig
@@ -121,7 +121,7 @@ else
fn log(
comptime message_level: Level,
- comptime scope: @Type(.EnumLiteral),
+ comptime scope: @TypeOf(.EnumLiteral),
comptime format: []const u8,
args: anytype,
) void {
@@ -167,7 +167,7 @@ pub fn defaultLog(
/// Returns a scoped logging namespace that logs all messages using the scope
/// provided here.
-pub fn scoped(comptime scope: @Type(.EnumLiteral)) type {
+pub fn scoped(comptime scope: @TypeOf(.EnumLiteral)) type {
return struct {
/// Log an error message. This log level is intended to be used
/// when something has gone wrong. This might be recoverable or might
diff --git a/src/link/strtab.zig b/src/link/strtab.zig
index abb58defef..2048aa216e 100644
--- a/src/link/strtab.zig
+++ b/src/link/strtab.zig
@@ -5,7 +5,7 @@ const Allocator = mem.Allocator;
const StringIndexAdapter = std.hash_map.StringIndexAdapter;
const StringIndexContext = std.hash_map.StringIndexContext;
-pub fn StringTable(comptime log_scope: @Type(.EnumLiteral)) type {
+pub fn StringTable(comptime log_scope: @TypeOf(.EnumLiteral)) type {
return struct {
const Self = @This();
--
2.44.1

68
run
View File

@ -1,6 +1,9 @@
#!/usr/bin/env bash #!/usr/bin/env bash
set -xeuo pipefail set -xeuo pipefail
HERE=$(cd -- "$(dirname -- "${BASH_SOURCE[0]}")" &>/dev/null && pwd)
step00() {
# commit e7d28344fa3ee81d6ad7ca5ce1f83d50d8502118 # commit e7d28344fa3ee81d6ad7ca5ce1f83d50d8502118
# Merge: 817cf6a82e 20d86d9c63 # Merge: 817cf6a82e 20d86d9c63
# Author: Andrew Kelley <andrew@ziglang.org> # Author: Andrew Kelley <andrew@ziglang.org>
@ -9,7 +12,7 @@ set -xeuo pipefail
# Merge pull request #13560 from ziglang/wasi-bootstrap # Merge pull request #13560 from ziglang/wasi-bootstrap
# #
# Nuke the C++ implementation of Zig from orbit using WASI # Nuke the C++ implementation of Zig from orbit using WASI
MERGE_WASI_BOOTSTRAP=0.10.0-610-ge7d28344fa local MERGE_WASI_BOOTSTRAP=0.10.0-610-ge7d28344fa
git checkout $MERGE_WASI_BOOTSTRAP git checkout $MERGE_WASI_BOOTSTRAP
# commit 3ba916584db5485c38ebf2390e8d22bc6d81bf8e # commit 3ba916584db5485c38ebf2390e8d22bc6d81bf8e
@ -17,7 +20,7 @@ git checkout $MERGE_WASI_BOOTSTRAP
# Date: 2022-11-05T03:47:19+02:00 # Date: 2022-11-05T03:47:19+02:00
# #
# actually remove stage1 # actually remove stage1
REMOVE_STAGE1=0.10.0-542-g3ba916584d local REMOVE_STAGE1=0.10.0-542-g3ba916584d
git revert --no-edit $REMOVE_STAGE1 git revert --no-edit $REMOVE_STAGE1
# commit 28514476ef8c824c3d189d98f23d0f8d23e496ea # commit 28514476ef8c824c3d189d98f23d0f8d23e496ea
@ -28,7 +31,7 @@ git revert --no-edit $REMOVE_STAGE1
# #
# After this commit, the self-hosted compiler does not offer the option to # After this commit, the self-hosted compiler does not offer the option to
# use stage1 as a backend anymore. # use stage1 as a backend anymore.
REMOVE_FSTAGE1=0.10.0-539-g28514476ef local REMOVE_FSTAGE1=0.10.0-539-g28514476ef
git revert --no-edit -X theirs $REMOVE_FSTAGE1 git revert --no-edit -X theirs $REMOVE_FSTAGE1
git mv stage1/config.zig.in src git mv stage1/config.zig.in src
@ -41,10 +44,13 @@ sed -i '/have_stage1/ s/false/true/' src/config.zig.in
git checkout $REMOVE_FSTAGE1~1 build.zig CMakeLists.txt git checkout $REMOVE_FSTAGE1~1 build.zig CMakeLists.txt
echo "Building the C++ (stage1) implementation" echo "Building the C++ (stage1) implementation"
mkdir build; pushd build mkdir build
{
pushd build
CC=clang-15 CXX=clang++-15 cmake .. CC=clang-15 CXX=clang++-15 cmake ..
make -j"$(nproc)" install make -j"$(nproc)" install
popd popd
}
echo "C++ implementation in build/stage3/bin/zig. Will build zig1.wasm.zst." echo "C++ implementation in build/stage3/bin/zig. Will build zig1.wasm.zst."
@ -57,27 +63,53 @@ build/stage3/bin/zig build update-zig1
echo "stage1/zig1.wasm.zst built. Bootstrapping zig with it." echo "stage1/zig1.wasm.zst built. Bootstrapping zig with it."
rm -fr build rm -fr build
mkdir build; pushd build mkdir build
{
pushd build
CC=clang-15 CXX=clang++-15 cmake .. CC=clang-15 CXX=clang++-15 cmake ..
make -j"$(nproc)" install make -j"$(nproc)" install
popd popd
}
echo "Done" echo "Zig bootstrapped from selfhosted."
true && exit }
# commit 89d1ccc477c1dbc8bb8d13ad2598ef0190c25898 step10() {
# Author: Veikka Tuominen <git@vexu.eu> cat <<EOF
# Date: Fri Dec 9 18:40:01 2022 +0200 This commit:
#
# replace zig1.wasm to the removal of BoundFn
REPLACE_ZIG1_WASM=0.10.0-677-g89d1ccc477
git archive --prefix=zig-$REPLACE_ZIG1_WASM/ $REPLACE_ZIG1_WASM | tar -C .. -x --exclude="stage1/zig1.wasm*"
pushd ../zig-$REPLACE_ZIG1_WASM commit 9d93b2ccf11f584320a2c5209dd2d94705167695
../zig/build/stage3/bin/zig update-zig1 Author: Veikka Tuominen <git@vexu.eu>
mkdir build; pushd build Date: 2022-12-08T17:52:05+00:00
Eliminate \$(BoundFn) type from the language
Closes #9484
EOF
local BOUNDFN=0.10.0-675-g9d93b2ccf1
git archive --prefix=zig-$BOUNDFN/ $BOUNDFN | tar -C .. -x --exclude="stage1/zig1.wasm*"
{
pushd "../zig-$REPLACE_ZIG1_WASM"
cp ../zig/stage1/zig1.wasm.zst stage1/
patch -p1 <"$HERE/0.10.0-675-g9d93b2ccf1-TypeOf-hack.patch"
mkdir build
{
pushd build
CC=clang-15 CXX=clang++-15 cmake .. CC=clang-15 CXX=clang++-15 cmake ..
make -j"$(nproc)" install make -j"$(nproc)" install
popd popd
}
build/stage3/bin/zig build update-zig1
popd popd
}
echo "zig1.wasm.zst was built for BoundFn hack"
}
step20() {
true
}
step00
step10
step20