blob: 806d4d4542646d23ee313023af5a3783b23ff2cb [file] [log] [blame] [view]
# Build Instructions
Answering "how do I build Wuffs" depends on what exactly you mean by "Wuffs":
1. The Wuffs library (e.g. image decoders) in C/C++ form.
2. Its example programs (e.g. jsonptr).
3. The Wuffs toolchain (e.g. Wuffs-to-C compiler/proof-checker).
4. The Wuffs library in Wuffs form (converting it to C/C++ code).
5. Everything.
## Quick Start
The rest of this document assumes that you've already checked out and moved
into the Wuffs repository's directory, like this:
```
git clone https://github.com/google/wuffs.git
cd wuffs
```
If you just want to kick the metaphorical tyres:
```
./build-example.sh example/jsonptr
gen/bin/example-jsonptr test/data/rfc-6901-json-pointer.json
```
## Building the Wuffs Library (in C/C++ Form)
There's no build step, in that there's no "configure and make" step needed
before moving on to building the example programs.
To elaborate, transpiling (converting Wuffs-the-library from `*.wuffs` form
into a single `*.c` file) isn't done by whoever *checks out* the Wuffs
repository. It's done by whoever *checks in* code changes.
Wuffs-the-library is provided as [single file C
library](https://github.com/nothings/stb/blob/master/docs/stb_howto.txt). The
example programs just `#include` that file directly.
For your own projects, just copy `release/c/wuffs-$VERSION.c` to your directory
and add that file to your pre-existing build system, or compile an `*.o` object
file directly like below. Remember to define the `WUFFS_IMPLEMENTATION` macro
to compile all of the C code in that single file, not just the "header" part.
```
# Most developers won't have to do this. It just demonstrates how to produce
# wuffs-v0.3.o directly from a C/C++ compiler.
gcc -c -DWUFFS_IMPLEMENTATION -O3 release/c/wuffs-v0.3.c
```
## Building the Example Programs
Just run your favorite C/C++ compiler (e.g. `gcc` or `g++`) on the
`example/foo/*.{c,cc}` file. Pass `-O3` or equivalent for an optimized build:
```
gcc -O3 example/mzcat/mzcat.c -o my-mzcat
./my-mzcat < test/data/romeo.txt.bz2
```
Some example programs require additional libraries:
```
g++ example/imageviewer/imageviewer.cc -lxcb -lxcb-image -lxcb-render -lxcb-render-util
g++ example/sdl-imageviewer/sdl-imageviewer.cc -lSDL2 -lSDL2_image
```
The `build-example.sh` script (an alternative to running your favorite C/C++
compiler directly) takes care of having to remember those additional libraries.
```
./build-example.sh example/sdl-imageviewer
gen/bin/example-sdl-imageviewer test/data/hat.jpeg
```
Building the fuzzers are similar, using `build-fuzz.sh` instead of
`build-example.sh`.
## Building the Wuffs Toolchain
Most developers won't have to do this. See the sections above instead.
But after editing `lang/check/*.go` files, do this:
```
go install ./cmd/wuffs*
```
## Building the Wuffs library (from its Wuffs Form)
Most developers won't have to do this. See the sections above instead.
But after editing `std/jpeg/*.wuffs` files, do this:
```
wuffs gen std/...
```
## Building Everything (All of the Above, Plus Tests, Benchmarks, Etc)
Most developers won't have to do this. See the sections above instead.
But before sending a Pull Request, do this:
```
./build-all.sh
```