move stuff
This commit is contained in:
96
doc/DEVELOPING.md
Normal file
96
doc/DEVELOPING.md
Normal file
@@ -0,0 +1,96 @@
|
||||
# Being a Hush Developer
|
||||
|
||||
## Compiling Hush
|
||||
|
||||
Normal compiling is as simple as:
|
||||
|
||||
./build.sh
|
||||
|
||||
To make it use as many CPU threads as you have:
|
||||
|
||||
./build.sh -j$(nproc) # assumes linux
|
||||
./build.sh -j8 # use a fixed 8 threads, more portable
|
||||
|
||||
This is dangerous! You need about 2GB of RAM per thread, plus all the
|
||||
other programs and Operating System overhead. A good rule of thumb is:
|
||||
|
||||
Divide how many GBs of RAM you have by 2, subtract one. Use that many jobs.
|
||||
|
||||
|
||||
## Dealing with dependency changes
|
||||
|
||||
Let's say you change a dependency and want the compile to notice. If your
|
||||
change is outside of the main Hush source code, in ./src, simply running
|
||||
`make` will not notice, and sometimes not even `build.sh`. You can always
|
||||
do a fresh clone or `make clean`, but that will take a lot of time. Those
|
||||
methods are actually best for Continuous Integration systems, but to help
|
||||
reduce the time a developer has to wait, here are some PROTIPs.
|
||||
|
||||
|
||||
If you are changing how a dependency is built, you should remove the entire directory like this:
|
||||
|
||||
rm -rf depends/work/build/x86_64-unknown-linux-gnu/wolfssl/
|
||||
|
||||
The above will delete the entire source code of wolfssl dependency on `x86_64`
|
||||
but it will keep the tar.gz and you will not need to download it again. If
|
||||
you are testing a change in URL or SHA256, you will want to force it to download
|
||||
again:
|
||||
|
||||
rm -rf depends/sources/wolfssl*.tar.gz
|
||||
|
||||
Now when you run `build.sh` again, you will be able to test your changes.
|
||||
|
||||
|
||||
## Good Hygiene
|
||||
|
||||
To avoid weird build system issues, it's often good to run:
|
||||
|
||||
make clean
|
||||
|
||||
*before* you switch Git branches. Otherwise, the new branches Makefiles
|
||||
often are incompatible and `make clean` will be impossible, which can
|
||||
sometimes introduce weird bugs or make compiling really annoying.
|
||||
If `make clean` produces a compilation error, you just experienced it.
|
||||
|
||||
## Switching branches
|
||||
|
||||
Switching branches and doing partial compiles in Hush source code
|
||||
can introduce weird bugs, which are fixed by running `build.sh` again.
|
||||
Additionally, it's a good idea to run `make clean` before you switch
|
||||
between branches.
|
||||
|
||||
## Partial compiles
|
||||
|
||||
At any point, you can modify hush source code and then use `make` or `build.sh`
|
||||
to do a partial compile. The first is faster but the latter is more likely to
|
||||
work correctly in all circustances. Sometimes partial compiles break weird
|
||||
build system dependencies, and you must do a `make clean` first, or even
|
||||
`git clean -fdx` (look up what it means first!) to clean things. The nuclear
|
||||
option is to re-clone the repo, which sometimes is the least work to fix
|
||||
the problem.
|
||||
|
||||
Running `make` doesn't understand about dependency changes, such as Rust crates.
|
||||
A simple C/C++ change can be tested with just `make` but if you change the version
|
||||
of a dependency or something inside of Rust, you will need `build.sh` .
|
||||
|
||||
## Generating new unix man pages
|
||||
|
||||
Make sure that you have updated all version numbers in hushd and compiled, then
|
||||
to generate new unix man pages for that version :
|
||||
|
||||
./util/gen-manpages.sh
|
||||
|
||||
## Generating new debian packages
|
||||
|
||||
After successfully compiling Hush, you can generate a debian package of these binaries with:
|
||||
|
||||
./util/build-debian-package.sh
|
||||
|
||||
This command will not work on Mac OS X. Currently you cannot generate a Debian package
|
||||
from operating systems other than Linux. Oh well.
|
||||
|
||||
## Updates to this document
|
||||
|
||||
If you think something else should be in this guide, please send your suggestions!
|
||||
|
||||
Gitea: https://git.hush.is/hush/hush3
|
||||
Reference in New Issue
Block a user