chore: lock in nph version and add pre-commit hook (#2938)

This commit is contained in:
fryorcraken 2024-08-20 15:14:35 +10:00 committed by GitHub
parent e8bce67d76
commit d63e34304d
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 76 additions and 6 deletions

7
.gitmodules vendored
View File

@ -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

View File

@ -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

View File

@ -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.

View 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

@ -0,0 +1 @@
Subproject commit de5cd4823e63424adb58ef3717524348ae6c4d87