Go to file
Sahnvour 54255ee32e autohash: force inlining of integer hashing so that the optimizer can see the fast path based on key's size which is known at comptime
otherwise it will always outline the call to hasher.update, resulting in much worse performance
2019-08-04 12:34:37 +02:00
.builds
.github funding: I've been accepted into the GitHub Sponsors program 2019-07-11 13:00:39 -04:00
ci ci: let's try a new build of llvm+clang on 10.14 2019-06-07 12:07:23 -04:00
cmake cmake: allow user to select static vs dynamic LLVM 2019-07-16 12:33:13 -04:00
deps
doc docs: add atomicrmw operations list 2019-08-02 18:54:15 -04:00
lib update bundled musl source to 1.1.23 2019-07-16 19:54:14 -04:00
src fix regressions regarding writing through const pointers 2019-08-02 16:09:40 -04:00
src-self-hosted fixed size of ZigClangAPValue on mingw-w64 2019-07-16 09:34:02 -04:00
std autohash: force inlining of integer hashing so that the optimizer can see the fast path based on key's size which is known at comptime 2019-08-04 12:34:37 +02:00
test fix regressions regarding writing through const pointers 2019-08-02 16:09:40 -04:00
tools update musl headers to musl v1.1.23 2019-07-16 19:02:51 -04:00
.gitattributes fix gitattributes 2019-07-16 00:05:12 -04:00
.gitignore
build.zig compiler-rt: add __muldi3 2019-07-22 12:49:26 -04:00
CMakeLists.txt avoid passing -static to msvc when static linking 2019-07-27 17:54:20 -05:00
CONTRIBUTING.md
LICENSE
README.md zig build: search upwards for build.zig file 2019-07-04 17:44:33 -04:00

ZIG

Zig is an open-source programming language designed for robustness, optimality, and maintainability.

Resources

Building from Source

Build Status

Note that you can download a binary of master branch.

Stage 1: Build Zig from C++ Source Code

Dependencies

POSIX
  • cmake >= 2.8.5
  • gcc >= 5.0.0 or clang >= 3.6.0
  • LLVM, Clang, LLD development libraries == 8.x, compiled with the same gcc or clang version above
Windows
  • cmake >= 2.8.5
  • Microsoft Visual Studio 2017 (version 15.8)
  • LLVM, Clang, LLD development libraries == 8.x, compiled with the same MSVC version above

Instructions

POSIX
mkdir build
cd build
cmake ..
make install
MacOS
brew install cmake llvm@8
brew outdated llvm@8 || brew upgrade llvm@8
mkdir build
cd build
cmake .. -DCMAKE_PREFIX_PATH=/usr/local/Cellar/llvm/8.0.0_1
make install
Windows

See https://github.com/ziglang/zig/wiki/Building-Zig-on-Windows

Stage 2: Build Self-Hosted Zig from Zig Source Code

Note: Stage 2 compiler is not complete. Beta users of Zig should use the Stage 1 compiler for now.

Dependencies are the same as Stage 1, except now you can use stage 1 to compile Zig code.

bin/zig build --prefix $(pwd)/stage2

This produces ./stage2/bin/zig which can be used for testing and development. Once it is feature complete, it will be used to build stage 3 - the final compiler binary.

Stage 3: Rebuild Self-Hosted Zig Using the Self-Hosted Compiler

Note: Stage 2 compiler is not yet able to build Stage 3. Building Stage 3 is not yet supported.

Once the self-hosted compiler can build itself, this will be the actual compiler binary that we will install to the system. Until then, users should use stage 1.

Debug / Development Build

./stage2/bin/zig build --prefix $(pwd)/stage3

Release / Install Build

./stage2/bin/zig build install -Drelease