2018-05-13 06:07:55 +01:00
![ZIG ](https://ziglang.org/zig-logo.svg )
2015-08-06 01:44:05 +01:00
2019-12-30 23:16:40 +00:00
A general-purpose programming language and toolchain for maintaining
**robust**, **optimal** , and **reusable** software.
2015-08-06 01:44:05 +01:00
2019-05-03 19:48:56 +01:00
## Resources
2016-02-10 05:31:49 +00:00
2019-05-03 19:48:56 +01:00
* [Introduction ](https://ziglang.org/#Introduction )
* [Download & Documentation ](https://ziglang.org/download )
2020-10-09 06:48:16 +01:00
* [Chapter 0 - Getting Started | ZigLearn.org ](https://ziglearn.org/ )
2019-05-03 19:48:56 +01:00
* [Community ](https://github.com/ziglang/zig/wiki/Community )
2019-05-28 19:53:01 +01:00
* [Contributing ](https://github.com/ziglang/zig/blob/master/CONTRIBUTING.md )
2020-10-09 06:48:16 +01:00
* [Code of Conduct ](https://github.com/ziglang/zig/blob/master/CODE_OF_CONDUCT.md )
2019-07-02 20:21:03 +01:00
* [Frequently Asked Questions ](https://github.com/ziglang/zig/wiki/FAQ )
2019-08-11 21:09:23 +01:00
* [Community Projects ](https://github.com/ziglang/zig/wiki/Community-Projects )
2016-11-24 07:44:03 +00:00
2019-04-29 23:25:27 +01:00
## Building from Source
2015-12-07 04:55:28 +00:00
2018-11-06 14:55:54 +00:00
[![Build Status ](https://dev.azure.com/ziglang/zig/_apis/build/status/ziglang.zig?branchName=master )](https://dev.azure.com/ziglang/zig/_build/latest?definitionId=1& branchName=master)
2017-04-21 16:06:15 +01:00
2018-11-01 19:21:41 +00:00
Note that you can
2020-10-26 13:38:36 +00:00
[download a binary of the master branch ](https://ziglang.org/download/#release-master ) or
2020-08-31 22:41:01 +01:00
[install Zig from a package manager ](https://github.com/ziglang/zig/wiki/Install-Zig-from-a-Package-Manager ).
2018-11-01 19:21:41 +00:00
2017-12-23 05:29:39 +00:00
### Stage 1: Build Zig from C++ Source Code
2016-01-26 04:56:29 +00:00
delete all stage1 c++ code not directly related to compiling stage2
Deleted 16,000+ lines of c++ code, including:
* an implementation of blake hashing
* the cache hash system
* compiler.cpp
* all the linking code, and everything having to do with building
glibc, musl, and mingw-w64
* much of the stage1 compiler internals got slimmed down since it
now assumes it is always outputting an object file.
More stuff:
* stage1 is now built with a different strategy: we have a tiny
zig0.cpp which is a slimmed down version of what stage1 main.cpp used
to be. Its only purpose is to build stage2 zig code into an object
file, which is then linked by the host build system (cmake) into
stage1. zig0.cpp uses the same C API that stage2 now has access to,
so that stage2 zig code can call into stage1 c++ code.
- stage1.h is
- stage2.h is
- stage1.zig is the main entry point for the Zig/C++
hybrid compiler. It has the functions exported from Zig, called
in C++, and bindings for the functions exported from C++, called
from Zig.
* removed the memory profiling instrumentation from stage1.
Abandon ship!
* Re-added the sections to the README about how to build stage2 and
stage3.
* stage2 now knows as a comptime boolean whether it is being compiled
as part of stage1 or as stage2.
- TODO use this flag to call into stage1 for compiling zig code.
* introduce -fdll-export-fns and -fno-dll-export-fns and clarify
its relationship to link_mode (static/dynamic)
* implement depending on LLVM to detect native target cpu features when
LLVM extensions are enabled and zig lacks CPU feature detection for
that target architecture.
* C importing is broken, will need some stage2 support to function
again.
2020-09-18 02:29:38 +01:00
This step must be repeated when you make changes to any of the C++ source code.
2017-12-23 05:29:39 +00:00
#### Dependencies
2016-09-05 21:36:21 +01:00
2017-09-25 17:51:26 +01:00
##### POSIX
2016-02-12 21:07:12 +00:00
* cmake >= 2.8.5
2018-01-16 03:17:22 +00:00
* gcc >= 5.0.0 or clang >= 3.6.0
2020-07-25 00:49:43 +01:00
* LLVM, Clang, LLD development libraries == 11.x, compiled with the same gcc or clang version above
2019-04-29 23:25:27 +01:00
- Use the system package manager, or [build from source ](https://github.com/ziglang/zig/wiki/How-to-build-LLVM,-libclang,-and-liblld-from-source#posix ).
2016-09-05 21:36:21 +01:00
2017-09-25 17:51:26 +01:00
##### Windows
2019-09-20 17:54:21 +01:00
* cmake >= 3.15.3
* Microsoft Visual Studio. Supported versions:
- 2017 (version 15.8)
- 2019 (version 16)
2020-07-25 00:49:43 +01:00
* LLVM, Clang, LLD development libraries == 11.x
2019-09-20 17:54:21 +01:00
- Use the [pre-built binaries ](https://github.com/ziglang/zig/wiki/Building-Zig-on-Windows ) or [build from source ](https://github.com/ziglang/zig/wiki/How-to-build-LLVM,-libclang,-and-liblld-from-source#windows ).
2017-09-25 17:51:26 +01:00
2017-12-23 05:29:39 +00:00
#### Instructions
2015-12-10 22:34:38 +00:00
2018-01-16 03:17:22 +00:00
##### POSIX
2015-12-07 04:55:28 +00:00
```
mkdir build
cd build
2018-04-11 01:57:37 +01:00
cmake ..
2015-12-10 22:34:38 +00:00
make install
2015-12-07 04:55:28 +00:00
```
2015-12-10 22:34:38 +00:00
2020-06-26 20:10:30 +01:00
Need help? [Troubleshooting Build Issues ](https://github.com/ziglang/zig/wiki/Troubleshooting-Build-Issues )
2017-12-23 05:29:39 +00:00
##### MacOS
2017-09-18 15:47:37 +01:00
```
2020-03-31 02:59:43 +01:00
brew install cmake llvm
brew outdated llvm || brew upgrade llvm
2017-09-18 15:47:37 +01:00
mkdir build
cd build
2020-04-17 23:41:21 +01:00
cmake .. -DCMAKE_PREFIX_PATH=$(brew --prefix llvm)
2020-07-03 05:43:05 +01:00
make install
2017-09-18 15:47:37 +01:00
```
2017-12-23 05:29:39 +00:00
##### Windows
2017-10-10 23:04:02 +01:00
2018-05-25 02:27:44 +01:00
See https://github.com/ziglang/zig/wiki/Building-Zig-on-Windows
2020-09-11 19:30:21 +01:00
delete all stage1 c++ code not directly related to compiling stage2
Deleted 16,000+ lines of c++ code, including:
* an implementation of blake hashing
* the cache hash system
* compiler.cpp
* all the linking code, and everything having to do with building
glibc, musl, and mingw-w64
* much of the stage1 compiler internals got slimmed down since it
now assumes it is always outputting an object file.
More stuff:
* stage1 is now built with a different strategy: we have a tiny
zig0.cpp which is a slimmed down version of what stage1 main.cpp used
to be. Its only purpose is to build stage2 zig code into an object
file, which is then linked by the host build system (cmake) into
stage1. zig0.cpp uses the same C API that stage2 now has access to,
so that stage2 zig code can call into stage1 c++ code.
- stage1.h is
- stage2.h is
- stage1.zig is the main entry point for the Zig/C++
hybrid compiler. It has the functions exported from Zig, called
in C++, and bindings for the functions exported from C++, called
from Zig.
* removed the memory profiling instrumentation from stage1.
Abandon ship!
* Re-added the sections to the README about how to build stage2 and
stage3.
* stage2 now knows as a comptime boolean whether it is being compiled
as part of stage1 or as stage2.
- TODO use this flag to call into stage1 for compiling zig code.
* introduce -fdll-export-fns and -fno-dll-export-fns and clarify
its relationship to link_mode (static/dynamic)
* implement depending on LLVM to detect native target cpu features when
LLVM extensions are enabled and zig lacks CPU feature detection for
that target architecture.
* C importing is broken, will need some stage2 support to function
again.
2020-09-18 02:29:38 +01:00
### Stage 2: Build Self-Hosted Zig from Zig Source Code
Now we use the stage1 binary:
```
zig build --prefix $(pwd)/stage2 -Denable-llvm
```
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
```
This produces `zig-cache/bin/zig` .
#### Release / Install Build
```
stage2/bin/zig build install -Drelease
```
2020-09-11 19:30:21 +01:00
## License
The ultimate goal of the Zig project is to serve users. As a first-order
effect, this means users of the compiler, helping programmers to write better
2020-10-26 13:38:36 +00:00
software. Even more important, however, are the end-users.
2020-09-11 19:30:21 +01:00
2020-10-26 13:38:36 +00:00
Zig is intended to be used to help **end-users** accomplish their goals. Zig
should be used to empower end-users, never to exploit them financially, or to
2020-10-22 03:55:35 +01:00
limit their freedom to interact with hardware or software in any way.
2020-09-11 19:30:21 +01:00
However, such problems are best solved with social norms, not with software
licenses. Any attempt to complicate the software license of Zig would risk
2020-10-22 03:55:35 +01:00
compromising the value Zig provides.
2020-09-11 19:30:21 +01:00
Therefore, Zig is available under the MIT (Expat) License, and comes with a
2020-10-26 13:38:36 +00:00
humble request: use it to make software better serve the needs of end-users.
2020-10-22 03:55:35 +01:00
This project redistributes code from other projects, some of which have other
licenses besides MIT. Such licenses are generally similar to the MIT license
for practical purposes. See the subdirectories and files inside lib/ for more
details.