mirror of
https://github.com/waku-org/nwaku.git
synced 2025-01-13 16:25:00 +00:00
chore: lock in nph version and add pre-commit hook (#2938)
This commit is contained in:
parent
e8bce67d76
commit
d63e34304d
7
.gitmodules
vendored
7
.gitmodules
vendored
@ -173,4 +173,9 @@
|
|||||||
ignore = untracked
|
ignore = untracked
|
||||||
path = vendor/negentropy
|
path = vendor/negentropy
|
||||||
url = https://github.com/waku-org/negentropy.git
|
url = https://github.com/waku-org/negentropy.git
|
||||||
branch = master
|
branch = master
|
||||||
|
[submodule "vendor/nph"]
|
||||||
|
ignore = untracked
|
||||||
|
branch = master
|
||||||
|
path = vendor/nph
|
||||||
|
url = https://github.com/arnetheduck/nph.git
|
||||||
|
35
Makefile
35
Makefile
@ -8,7 +8,8 @@ BUILD_SYSTEM_DIR := vendor/nimbus-build-system
|
|||||||
EXCLUDED_NIM_PACKAGES := vendor/nim-dnsdisc/vendor
|
EXCLUDED_NIM_PACKAGES := vendor/nim-dnsdisc/vendor
|
||||||
LINK_PCRE := 0
|
LINK_PCRE := 0
|
||||||
LOG_LEVEL := TRACE
|
LOG_LEVEL := TRACE
|
||||||
|
NPH := vendor/nph/src/nph
|
||||||
|
FORMAT_MSG := "\\x1B[95mFormatting:\\x1B[39m"
|
||||||
# we don't want an error here, so we can handle things later, in the ".DEFAULT" target
|
# we don't want an error here, so we can handle things later, in the ".DEFAULT" target
|
||||||
-include $(BUILD_SYSTEM_DIR)/makefiles/variables.mk
|
-include $(BUILD_SYSTEM_DIR)/makefiles/variables.mk
|
||||||
|
|
||||||
@ -98,7 +99,7 @@ ifeq (, $(shell which cargo))
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
anvil: rustup
|
anvil: rustup
|
||||||
ifeq (, $(shell which anvil))
|
ifeq (, $(shell which anvil 2> /dev/null))
|
||||||
# Install Anvil if it's not installed
|
# Install Anvil if it's not installed
|
||||||
./scripts/install_anvil.sh
|
./scripts/install_anvil.sh
|
||||||
endif
|
endif
|
||||||
@ -241,6 +242,34 @@ networkmonitor: | build deps librln
|
|||||||
echo -e $(BUILD_MSG) "build/$@" && \
|
echo -e $(BUILD_MSG) "build/$@" && \
|
||||||
$(ENV_SCRIPT) nim networkmonitor $(NIM_PARAMS) waku.nims
|
$(ENV_SCRIPT) nim networkmonitor $(NIM_PARAMS) waku.nims
|
||||||
|
|
||||||
|
############
|
||||||
|
## Format ##
|
||||||
|
############
|
||||||
|
.PHONY: build-nph clean-nph install-nph
|
||||||
|
|
||||||
|
build-nph:
|
||||||
|
ifeq ("$(wildcard $(NPH))","")
|
||||||
|
$(ENV_SCRIPT) nim c vendor/nph/src/nph.nim
|
||||||
|
endif
|
||||||
|
|
||||||
|
GIT_PRE_COMMIT_HOOK := .git/hooks/pre-commit
|
||||||
|
|
||||||
|
install-nph: build-nph
|
||||||
|
ifeq ("$(wildcard $(GIT_PRE_COMMIT_HOOK))","")
|
||||||
|
cp ./scripts/git_pre_commit_format.sh $(GIT_PRE_COMMIT_HOOK)
|
||||||
|
else
|
||||||
|
echo "$(GIT_PRE_COMMIT_HOOK) already present, will NOT override"
|
||||||
|
exit 1
|
||||||
|
endif
|
||||||
|
|
||||||
|
nph/%: build-nph
|
||||||
|
echo -e $(FORMAT_MSG) "nph/$*" && \
|
||||||
|
$(NPH) $*
|
||||||
|
|
||||||
|
clean-nph:
|
||||||
|
rm -f $(NPH)
|
||||||
|
|
||||||
|
clean: | clean-nph
|
||||||
|
|
||||||
###################
|
###################
|
||||||
## Documentation ##
|
## Documentation ##
|
||||||
@ -429,4 +458,4 @@ negentropy:
|
|||||||
cp vendor/negentropy/cpp/libnegentropy.so ./
|
cp vendor/negentropy/cpp/libnegentropy.so ./
|
||||||
negentropy-clean:
|
negentropy-clean:
|
||||||
$(MAKE) -C vendor/negentropy/cpp clean && \
|
$(MAKE) -C vendor/negentropy/cpp clean && \
|
||||||
rm libnegentropy.so
|
rm libnegentropy.so
|
||||||
|
23
README.md
23
README.md
@ -9,7 +9,7 @@ The nwaku repository implements Waku, and provides tools related to it.
|
|||||||
- Examples of Waku usage.
|
- Examples of Waku usage.
|
||||||
- Various tests of above.
|
- Various tests of above.
|
||||||
|
|
||||||
For more details see the [source code](waku/v2/README.md)
|
For more details see the [source code](waku/README.md)
|
||||||
|
|
||||||
## How to Build & Run
|
## How to Build & Run
|
||||||
|
|
||||||
@ -53,7 +53,8 @@ If you encounter difficulties building the project on WSL, consider placing the
|
|||||||
#### Nim Runtime
|
#### Nim Runtime
|
||||||
This repository is bundled with a Nim runtime that includes the necessary dependencies for the project.
|
This repository is bundled with a Nim runtime that includes the necessary dependencies for the project.
|
||||||
|
|
||||||
Before you can utilise the runtime you'll need to build the project, as detailed in a previous section. This will generate a `vendor` directory containing various dependencies, including the `nimbus-build-system` which has the bundled nim runtime.
|
Before you can utilise the runtime you'll need to build the project, as detailed in a previous section.
|
||||||
|
This will generate a `vendor` directory containing various dependencies, including the `nimbus-build-system` which has the bundled nim runtime.
|
||||||
|
|
||||||
After successfully building the project, you may bring the bundled runtime into scope by running:
|
After successfully building the project, you may bring the bundled runtime into scope by running:
|
||||||
```bash
|
```bash
|
||||||
@ -84,6 +85,24 @@ Binary will be created as `<path to your test file.nim>.bin` under the `build` d
|
|||||||
make test/tests/common/test_enr_builder.nim
|
make test/tests/common/test_enr_builder.nim
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## Formatting
|
||||||
|
|
||||||
|
Nim files are expected to be formatted using the [`nph`](https://github.com/arnetheduck/nph) version present in `vendor/nph`.
|
||||||
|
|
||||||
|
You can easily format file with the `make nph/<relative path to nim> file` command.
|
||||||
|
For example:
|
||||||
|
|
||||||
|
```
|
||||||
|
make nph/waku/waku_core.nim
|
||||||
|
```
|
||||||
|
|
||||||
|
A convenient git hook is provided to automatically format file at commit time.
|
||||||
|
Run the following command to install it:
|
||||||
|
|
||||||
|
```shell
|
||||||
|
make install-nph
|
||||||
|
```
|
||||||
|
|
||||||
### Examples
|
### Examples
|
||||||
|
|
||||||
Examples can be found in the examples folder.
|
Examples can be found in the examples folder.
|
||||||
|
16
scripts/git_pre_commit_format.sh
Normal file
16
scripts/git_pre_commit_format.sh
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
echo "Running pre-commit hook"
|
||||||
|
|
||||||
|
# Regexp for grep to only choose some file extensions for formatting
|
||||||
|
exts="\.\(nim\|nims\)$"
|
||||||
|
|
||||||
|
# Build nph lazily
|
||||||
|
make build-nph || (1>&2 echo "failed to build nph. Pre-commit formatting will not be done."; exit 0)
|
||||||
|
|
||||||
|
# Format staged files
|
||||||
|
git diff --cached --name-only --diff-filter=ACMR | grep "$exts" | while read file; do
|
||||||
|
echo "Formatting $file"
|
||||||
|
make nph/"$file"
|
||||||
|
git add "$file"
|
||||||
|
done
|
1
vendor/nph
vendored
Submodule
1
vendor/nph
vendored
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit de5cd4823e63424adb58ef3717524348ae6c4d87
|
Loading…
x
Reference in New Issue
Block a user