Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kubkon/bold
bold: the bold linker
https://github.com/kubkon/bold
linker zig zig-package
Last synced: 4 days ago
JSON representation
bold: the bold linker
- Host: GitHub
- URL: https://github.com/kubkon/bold
- Owner: kubkon
- License: mit
- Created: 2021-01-23T06:25:16.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2024-12-27T13:04:37.000Z (26 days ago)
- Last Synced: 2025-01-12T03:44:33.889Z (10 days ago)
- Topics: linker, zig, zig-package
- Language: Zig
- Homepage:
- Size: 4.36 MB
- Stars: 257
- Watchers: 13
- Forks: 22
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-zig - kubkon/bold - in replacement for Apple’s system linker `ld` (Tools / Linker)
README
# bold - the *bold* linker
> Bold used to be emerald, but due to time constraints and other commitments I am unable to develop and maintain the other drivers.
> Emerald now lives in another repo -> [kubkon/emerald-old](https://github.com/kubkon/emerald-old).`bold` is a drop-in replacement for Apple system linker `ld`, written fully in Zig. It is on par with the LLVM lld linker,
faster than the legacy Apple ld linker, but slower than the rewritten Apple ld linker. Some benchmark results between the linkers
when linking stage3-zig compiler which includes linking LLVM statically:```sh
$ hyperfine ./bold.sh ./ld.sh ./ld_legacy.sh ./lld.sh
Benchmark 1: ./bold.sh
Time (mean ± σ): 1.088 s ± 0.018 s [User: 3.174 s, System: 1.004 s]
Range (min … max): 1.039 s … 1.104 s 10 runsBenchmark 2: ./ld.sh
Time (mean ± σ): 491.8 ms ± 19.5 ms [User: 1891.5 ms, System: 304.7 ms]
Range (min … max): 458.1 ms … 509.9 ms 10 runsBenchmark 3: ./ld_legacy.sh
Time (mean ± σ): 2.132 s ± 0.013 s [User: 3.242 s, System: 0.256 s]
Range (min … max): 2.104 s … 2.150 s 10 runsBenchmark 4: ./lld.sh
Time (mean ± σ): 1.160 s ± 0.021 s [User: 1.329 s, System: 0.247 s]
Range (min … max): 1.133 s … 1.208 s 10 runsSummary
./ld.sh ran
2.21 ± 0.10 times faster than ./bold.sh
2.36 ± 0.10 times faster than ./lld.sh
4.33 ± 0.17 times faster than ./ld_legacy.sh
```In the results
* `bold.sh` calls `bold` with all the required inputs and flags
* `ld.sh` calls the rewritten Apple linker
* `ld_legacy.sh` calls `ld -ld_classic` the legacy Apple linker
* `lld.sh` calls LLVM lld linkertl;dr `bold` is currently directly competing with LLVM lld but behind the Apple ld linker.
## Quick start guide
### Building
You will need Zig 0.13.0 in your path. You can download it from [here](https://ziglang.org/download/).
```
$ zig build -Doptimize=ReleaseFast
```You can then pass it to your system C/C++ compiler with `-B` or `-fuse-ld` flag (note that the latter is supported mainly/only by clang):
```
$ cat < hello.c
#includeint main() {
fprintf(stderr, "Hello, World!\n");
return 0;
}
EOF# Using clang
$ clang hello.c -fuse-ld=bold# Using gcc
$ gcc hello.c -B/path/to/bold
```### Testing
If you'd like to run unit and end-to-end tests, run the tests like you'd normally do for any other Zig project.
```
$ zig build test
```## Contributing
You are welcome to contribute to this repo.