#!/usr/bin/env bash HERE=$(cd -- "$(dirname -- "${BASH_SOURCE[0]}")" &>/dev/null && pwd) fullbuild() { rm -fr build mkdir build pushd build CC=clang-$1 CXX=clang++-$1 cmake .. make -j"$(nproc)" install popd } # zig2 halfbuild() { sed -i '/^add_custom_target(stage3/,/^)$/d' CMakeLists.txt rm -fr build mkdir build pushd build CC=clang-$1 CXX=clang++-$1 cmake .. make -j"$(nproc)" popd } # commit e7d28344fa3ee81d6ad7ca5ce1f83d50d8502118 # Merge: 817cf6a82e 20d86d9c63 # Author: Andrew Kelley # Date: 2022-12-07T01:52:39+02:00 # # Merge pull request #13560 from ziglang/wasi-bootstrap # # Nuke the C++ implementation of Zig from orbit using WASI # STEP00_A=e7d28344fa3ee81d6ad7ca5ce1f83d50d8502118 # commit 3ba916584db5485c38ebf2390e8d22bc6d81bf8e # Author: Andrew Kelley # Date: 2022-11-05T03:47:19+02:00 # # actually remove stage1 # STEP00_B=3ba916584db5485c38ebf2390e8d22bc6d81bf8e # commit 28514476ef8c824c3d189d98f23d0f8d23e496ea # Author: Andrew Kelley # Date: 2022-11-01T05:29:55+02:00 # # remove `-fstage1` option # # After this commit, the self-hosted compiler does not offer the option to # use stage1 as a backend anymore. # STEP00_C=28514476ef8c824c3d189d98f23d0f8d23e496ea step00() { git checkout $STEP00_A git revert --no-edit $STEP00_B git revert --no-edit -X theirs $STEP00_C git mv stage1/config.zig.in src sed -i '/have_stage1/ s/false/true/' src/config.zig.in git checkout $STEP00_C~1 build.zig CMakeLists.txt echo "Building the C++ (stage1) implementation" fullbuild 15 echo "C++ implementation in build/stage3/bin/zig. Will build zig1.wasm.zst." git reset --hard git checkout $STEP00_A build/stage3/bin/zig build update-zig1 echo "stage1/zig1.wasm.zst built. Bootstrapping zig with it." fullbuild 15 echo "Zig bootstrapped from selfhosted." } # commit 9d93b2ccf11f584320a2c5209dd2d94705167695 # Author: Veikka Tuominen # Date: 2022-12-08T19:52:05+02:00 # # Eliminate `BoundFn` type from the language # # Closes #9484 # STEP01=9d93b2ccf11f584320a2c5209dd2d94705167695 STEP01_=0.10.0-675-g9d93b2ccf1 step01() { rm -fr "../zig-$STEP01_" git archive --prefix=zig-$STEP01_/ $STEP01 | tar -C .. -x { pushd "../zig-$STEP01_" cp "$OLDPWD/stage1/zig1.wasm.zst" stage1/ patch -p1 <"$HERE/0.10.0-675-g9d93b2ccf1-TypeOf-hack.patch" fullbuild 15 build/stage3/bin/zig build update-zig1 popd } } # commit d10fd78d4615f329141f5c19f893039d56aff425 # Author: Andrew Kelley # Date: 2022-12-10T21:54:24+02:00 # # update zig1.wasm # # This includes the latest changes from master branch with fixes to the C # backend that affect aarch64-windows which are necessary to build from # source on this target. # STEP02=d10fd78d4615f329141f5c19f893039d56aff425 STEP02_=0.10.0-722-gd10fd78d46 step02() { rm -fr "../zig-$STEP02_" git archive --prefix=zig-$STEP02_/ $STEP02 | tar -C .. -x { pushd "../zig-$STEP02_" zstd -cd ../zig-$STEP01_/stage1/zig1.wasm.zst >stage1/zig1.wasm fullbuild 15 build/stage3/bin/zig build update-zig1 popd } } # commit 7b2a936173165002105ba5e76bed69654e132fea # Author: Veikka Tuominen # Date: 2022-12-12T15:32:37+02:00 # # remove `stack` option from `@call` # STEP03=7b2a936173165002105ba5e76bed69654e132fea STEP03_=0.10.0-747-g7b2a936173 step03() { rm -fr "../zig-$STEP03_" git archive --prefix=zig-$STEP03_/ $STEP03 | tar -C .. -x { pushd "../zig-$STEP03_" patch -p1 <"$HERE/0.10.0-747-g7b2a936173-CallOptions.patch" "../zig-$STEP02_/build/stage3/bin/zig" build --zig-lib-dir lib update-zig1 popd } } # commit 08b2d491bcd8c79c68495267cc71967661caea1e # Author: Veikka Tuominen # Date: 2022-12-12T15:32:37+02:00 # # update usages of `@call` # STEP04=08b2d491bcd8c79c68495267cc71967661caea1e STEP04_=0.10.0-748-g08b2d491bc step04() { rm -fr "../zig-$STEP04_" git archive --prefix=zig-$STEP04_/ $STEP04 | tar -C .. -x { pushd "../zig-$STEP04_" cp ../zig-$STEP03_/stage1/zig1.wasm stage1/zig1.wasm fullbuild 15 build/stage3/bin/zig build update-zig1 popd } } # commit 35184bff75420f405cb703c9cf86b196843b9a94 (HEAD) # Author: r00ster91 # Date: 2022-12-13T23:30:06+02:00 # # std.builtin: rename Type.UnionField and Type.StructField's field_type to type # STEP05=aac2d6b56f32134ea32fb3d984e3fcdfddd8aaf6 STEP05_=0.10.0-851-gaac2d6b56f step05() { rm -fr "../zig-$STEP05_" git archive --prefix=zig-$STEP05_/ $STEP05 | tar -C .. -x { pushd "../zig-$STEP05_" cp ../zig-$STEP04_/stage1/zig1.wasm stage1/zig1.wasm fullbuild 15 popd } } # commit 2a5e1426aa9469fadb78e837d0100d689213b034 # Author: Veikka Tuominen # Date: 2022-12-16T19:44:25+02:00 # # update zig1.wasm to builtin.Type field changes # STEP06=2a5e1426aa9469fadb78e837d0100d689213b034 STEP06_=0.10.0-853-g2a5e1426aa step06() { rm -fr "../zig-$STEP06_" git archive --prefix=zig-$STEP06_/ $STEP06 | tar -C .. -x { pushd "../zig-$STEP06_" "../zig-$STEP05_/build/stage3/bin/zig" build update-zig1 popd } } # commit 54160e7f6aecb4628df633ceaef4c6d956429a3d # Author: Veikka Tuominen # Date: 2022-12-21T14:33:02+02:00 # # Sema: make overflow arithmetic builtins return tuples # STEP07=54160e7f6aecb4628df633ceaef4c6d956429a3d STEP07_=0.10.0-961-g54160e7f6a step07() { rm -fr "../zig-$STEP07_" git archive --prefix=zig-$STEP07_/ $STEP07 | tar -C .. -x { pushd "../zig-$STEP07_" cp ../zig-$STEP06_/stage1/zig1.wasm stage1/zig1.wasm halfbuild 15 popd } } # commit 622311fb9ac7ee6d93dcb8cda4b608751f7e092a # Author: Veikka Tuominen # Date: 2022-12-21T16:40:30+02:00 # # update uses of overflow arithmetic builtins # STEP08=622311fb9ac7ee6d93dcb8cda4b608751f7e092a STEP08_=0.10.0-962-g622311fb9a step08() { rm -fr "../zig-$STEP08_" git archive --prefix=zig-$STEP08_/ $STEP08 | tar -C .. -x { pushd "../zig-$STEP08_" ../zig-$STEP07_/build/zig2 build --zig-lib-dir lib update-zig1 popd } } # commit a43fdc1620fa24c8c606f748505766bfd53d1049 # Author: kcbanner # Date: 2022-12-09T02:50:08+02:00 # # cbe: first set of changes for msvc compatibility # STEP09=a43fdc1620fa24c8c606f748505766bfd53d1049 STEP09_=0.10.0-1027-ga43fdc1620 step09() { rm -fr "../zig-$STEP09_" git archive --prefix=zig-$STEP09_/ $STEP09 | tar -C .. -x { pushd "../zig-$STEP09_" cp ../zig-$STEP08_/stage1/zig1.wasm stage1/zig1.wasm fullbuild 15 popd } } # commit 4c1007fc044689b8cbc20634d73debb43df8efe1 # Merge: 4172c29166 23b1544f6c # Author: Andrew Kelley # Date: 2023-01-02T23:11:17+02:00 # # Merge pull request #14002 from kcbanner/cbe_msvc_compatibility # STEP10=4c1007fc044689b8cbc20634d73debb43df8efe1 STEP10_=0.10.0-1073-g4c1007fc04 step10() { rm -fr "../zig-$STEP10" git archive --prefix=zig-$STEP10_/ $STEP10 | tar -C .. -x { pushd "../zig-$STEP10_" ../zig-$STEP09_/build/stage3/bin/zig build --zig-lib-dir lib update-zig1 fullbuild 15 popd } } #commit a9b68308b9eeb494524e2b7ab0d63cfa6b623cd0 #Author: Casey Banner #Date: 2023-01-26T07:45:40+02:00 # # cbe: fixes for tls, support for not linking libc, and enabling tests # STEP11=a9b68308b9eeb494524e2b7ab0d63cfa6b623cd0 STEP11_=0.10.0-1497-ga9b68308b9 step11() { rm -fr "../zig-$STEP11" git archive --prefix=zig-$STEP11_/ $STEP11 | tar -C .. -x { pushd "../zig-$STEP11_" ../zig-$STEP10_/build/stage3/bin/zig build --zig-lib-dir lib update-zig1 fullbuild 15 popd } } # commit f16c10a86b7183e99e54a70344f4681211cd52bb # Author: Veikka Tuominen # Date: 2023-01-27T20:25:48+02:00 # # implement `@qualCast` # STEP12=f16c10a86b7183e99e54a70344f4681211cd52bb STEP12_=0.10.0-1506-gf16c10a86b step12() { rm -fr "../zig-$STEP12" # use the @qualCast implementation in src/, but remove usages in lib/ git archive --prefix=zig-$STEP12_/ $STEP12 | tar -C .. -x git archive --prefix=zig-$STEP12_/ $STEP12~1 lib | tar -C .. -x { pushd "../zig-$STEP12_" cp ../zig-$STEP11_/stage1/zig1.wasm stage1/zig1.wasm fullbuild 15 build/stage3/bin/zig build --zig-lib-dir lib update-zig1 popd } } # commit 7199d7c77715fe06606c5c89595e6852b3fa8c20 # Author: Veikka Tuominen # Date: 2023-02-13T16:19:17+02:00 # # split `@qualCast` into `@constCast` and `@volatileCast` # STEP13=7199d7c77715fe06606c5c89595e6852b3fa8c20 STEP13_=0.10.0-1638-g7199d7c777 step13() { rm -fr "../zig-$STEP13" # ditto as previous step: implementation here, usages from HEAD~1 git archive --prefix=zig-$STEP13_/ $STEP13 | tar -C .. -x git archive --prefix=zig-$STEP13_/ $STEP13~1 lib | tar -C .. -x { pushd "../zig-$STEP13_" patch -p1 <"$HERE/0.10.0-1638-g7199d7c777-re-add-qualCast.patch" ../zig-$STEP12_/build/stage3/bin/zig build --zig-lib-dir lib update-zig1 fullbuild 15 popd } } # commit 321ccbdc525ab0f5862e42378b962c10ec54e4a1 # Author: Andrew Kelley # Date: 2023-02-18T04:54:26+02:00 # # Sema: implement for_len # STEP14=321ccbdc525ab0f5862e42378b962c10ec54e4a1 STEP14_=0.10.0-1657-g321ccbdc52 step14() { rm -fr "../zig-$STEP14_" git archive --prefix=zig-$STEP14_/ $STEP14 | tar -C .. -x { pushd "../zig-$STEP14_" cp ../zig-$STEP13_/stage1/zig1.wasm stage1/zig1.wasm halfbuild 15 popd } } # commit 0bb178bbb2451238a326c6e916ecf38fbc34cab1 # Merge: 346ec15c50 5fc6bbe71e # Author: Andrew Kelley # Date: 2023-02-19T17:10:59+02:00 # # Merge pull request #14671 from ziglang/multi-object-for # STEP15=0bb178bbb2451238a326c6e916ecf38fbc34cab1 STEP15_=0.10.0-1681-g0bb178bbb2 step15() { rm -fr "../zig-$STEP15_" git archive --prefix=zig-$STEP15_/ $STEP15 | tar -C .. -x { pushd "../zig-$STEP15_" ../zig-$STEP14_/build/zig2 build --zig-lib-dir lib update-zig1 popd } } # commit 705d2a3c2cd94faf8e16c660b3b342d6fe900e55 # Author: mlugg # Date: 2023-02-17T03:44:08+02:00 # # Implement new module CLI # STEP16=705d2a3c2cd94faf8e16c660b3b342d6fe900e55 STEP16_=0.10.0-1712-g705d2a3c2c step16() { rm -fr "../zig-$STEP16" git archive --prefix=zig-$STEP16_/ $STEP16 | tar -C .. -x { pushd "../zig-$STEP16_" cp ../zig-$STEP15_/stage1/zig1.wasm stage1/zig1.wasm halfbuild 15 popd } } # commit 09a84c8384dffc7884528947b879f32d93c1bd90 # Author: mlugg # Date: 2023-02-17T08:20:52+02:00 # # Update std.Build to new module CLI, update zig1 and CMakeLists # STEP17=09a84c8384dffc7884528947b879f32d93c1bd90 STEP17_=0.10.0-1713-g09a84c8384 step17() { rm -fr "../zig-$STEP17" git archive --prefix=zig-$STEP17_/ $STEP17 | tar -C .. -x { pushd "../zig-$STEP17_" ../zig-$STEP16_/build/zig2 build --zig-lib-dir lib update-zig1 popd } } # commit c839c180ef1686794c039fc6d3c20a8716e87357 # Author: Andrew Kelley # Date: 2023-03-05T21:46:12+02:00 # # stage2: add zig_backend to ZIR cache namespace # STEP18=c839c180ef1686794c039fc6d3c20a8716e87357 STEP18_=0.10.0-1888-gc839c180ef step18() { rm -fr "../zig-$STEP18_" git archive --prefix=zig-$STEP18_/ $STEP18 | tar -C .. -x { pushd "../zig-$STEP18_" cp ../zig-$STEP17_/stage1/zig1.wasm stage1/zig1.wasm halfbuild 15 popd } } # commit ac1b0e832b4b9d151098050e1d29e28a568e215c # Merge: 2641feb9b9 8558983c86 # Author: Andrew Kelley # Date: 2023-03-06T08:29:56+02:00 # # Merge pull request #14799 from ziglang/update-zig1 # # `@trap` fixups # STEP19=ac1b0e832b4b9d151098050e1d29e28a568e215c STEP19_=0.10.0-1891-gac1b0e832b step19() { rm -fr "../zig-$STEP19_" git archive --prefix=zig-$STEP19_/ $STEP19 | tar -C .. -x { pushd "../zig-$STEP19_" ../zig-$STEP18_/build/zig2 build --zig-lib-dir lib update-zig1 popd } } # commit fc9ab4144cc577e5293e685af2d53ac1cb3415ce # Author: Andrew Kelley # Date: 2023-04-06T09:22:29+03:00 # # update libcxx to LLVM 16.0.1 # STEP20=fc9ab4144cc577e5293e685af2d53ac1cb3415ce STEP20_=0.10.0-2440-gfc9ab4144c step20() { rm -fr "../zig-$STEP20_" git archive --prefix=zig-$STEP20_/ $STEP20 | tar -C .. -x { pushd "../zig-$STEP20_" cp ../zig-$STEP19_/stage1/zig1.wasm stage1/zig1.wasm halfbuild 16 popd } } # commit d3a237a98c5a2ccf72a774b5f93425c02fea4bea # Merge: 1728d92f60 3c3cee2cfa # Author: Andrew Kelley # Date: 2023-04-11T18:54:43+03:00 # # Merge pull request #15234 from ziglang/remove-legacy-build-api # # remove --enable-cache option; std.Build.CompileStep: remove output_dir # STEP21=d3a237a98c5a2ccf72a774b5f93425c02fea4bea STEP21_=0.10.0-2558-gd3a237a98c step21() { rm -fr "../zig-$STEP21_" git archive --prefix=zig-$STEP21_/ $STEP21 | tar -C .. -x { pushd "../zig-$STEP21_" cp ../zig-$STEP20_/stage1/zig1.wasm stage1/zig1.wasm halfbuild 16 popd } } # commit e2fe1907ecac075e4d4a37776359144318b6055a # Author: Andrew Kelley # Date: 2023-04-13T07:03:36+03:00 # # add c_char type # STEP22=e2fe1907ecac075e4d4a37776359144318b6055a STEP22_=0.10.0-2566-ge2fe1907ec step22() { rm -fr "../zig-$STEP22_" git archive --prefix=zig-$STEP22_/ $STEP22 | tar -C .. -x git archive --prefix=zig-$STEP22_/ $STEP22~1 lib/std/start.zig | tar -C .. -x { pushd "../zig-$STEP22_" ../zig-$STEP21_/build/zig2 build --zig-lib-dir lib update-zig1 popd } } # commit 31738de2817f7932fa9237492f20fb736bc07dd3 (HEAD, replaced) # Merge: 335a6bb0b2 4f3ce7411e # Author: Jakub Konka # Date: Thu Apr 13 13:53:01 2023 +0200 # # Merge pull request #15184 from jacobly0/x86_64 # STEP23=31738de2817f7932fa9237492f20fb736bc07dd3 STEP23_=0.10.0-2571-g31738de281 step23() { rm -fr "../zig-$STEP23_" git archive --prefix=zig-$STEP23_/ $STEP23 | tar -C .. -x { pushd "../zig-$STEP23_" cp ../zig-$STEP22_/stage1/zig1.wasm stage1/zig1.wasm halfbuild 16 build/zig2 build update-zig1 popd } } # commit 35d82d31be3d2f2611049f41dc2616f898d70871 # Author: Matthew Lugg # Date: 2023-04-15T00:32:31+03:00 # # Add `@inComptime` builtin # STEP24=35d82d31be3d2f2611049f41dc2616f898d70871 STEP24_=0.10.0-2797-g35d82d31be step24() { rm -fr "../zig-$STEP24_" git archive --prefix=zig-$STEP24_/ $STEP24 | tar -C .. -x git archive --prefix=zig-$STEP24_/ $STEP24~1 lib | tar -C .. -x { pushd "../zig-$STEP24_" cp ../zig-$STEP23_/stage1/zig1.wasm stage1/zig1.wasm halfbuild 16 build/zig2 build update-zig1 popd } } # commit a5c910adb610ae530db99f10aa77aaed3e85e830 # Author: Andrew Kelley # Date: Thu Apr 13 21:44:40 2023 -0700 # # change semantics of `@memcpy` and `@memset` # STEP25=a5c910adb610ae530db99f10aa77aaed3e85e830 STEP25_=0.10.0-2825-ga5c910adb6 step25() { rm -fr "../zig-$STEP25_" git archive --prefix=zig-$STEP25_/ $STEP25 | tar -C .. -x git archive --prefix=zig-$STEP25_/ $STEP25~1 lib | tar -C .. -x { pushd "../zig-$STEP25_" cp ../zig-$STEP24_/stage1/zig1.wasm stage1/zig1.wasm halfbuild 16 popd } } if [[ "${BASH_SOURCE[0]}" == "${0}" ]]; then set -xeuo pipefail step=${1:-step00} step=${step#step} step=${step#0} if [[ "$step" -le 0 ]]; then step00; fi if [[ "$step" -le 1 ]]; then step01; fi if [[ "$step" -le 2 ]]; then step02; fi if [[ "$step" -le 3 ]]; then step03; fi if [[ "$step" -le 4 ]]; then step04; fi if [[ "$step" -le 5 ]]; then step05; fi if [[ "$step" -le 6 ]]; then step06; fi if [[ "$step" -le 7 ]]; then step07; fi if [[ "$step" -le 8 ]]; then step08; fi if [[ "$step" -le 9 ]]; then step09; fi if [[ "$step" -le 10 ]]; then step10; fi if [[ "$step" -le 11 ]]; then step11; fi if [[ "$step" -le 12 ]]; then step12; fi if [[ "$step" -le 13 ]]; then step13; fi if [[ "$step" -le 14 ]]; then step14; fi if [[ "$step" -le 15 ]]; then step15; fi if [[ "$step" -le 16 ]]; then step16; fi if [[ "$step" -le 17 ]]; then step17; fi if [[ "$step" -le 18 ]]; then step18; fi if [[ "$step" -le 19 ]]; then step19; fi if [[ "$step" -le 20 ]]; then step20; fi if [[ "$step" -le 21 ]]; then step21; fi if [[ "$step" -le 22 ]]; then step22; fi if [[ "$step" -le 23 ]]; then step23; fi if [[ "$step" -le 24 ]]; then step24; fi if [[ "$step" -le 25 ]]; then step25; fi fi