jotdown/tests/bench/Makefile
Noah Hellman bee3d5d747 bench/suite_bench: use snake case for input files
rust identifiers may not contain -

use _ for files also to avoid confusion of having two names
2023-04-10 11:49:03 +02:00

41 lines
1 KiB
Makefile

.POSIX:
TEST_DJ=$(shell find . -name '*.dj' | sort)
TEST=${TEST_DJ:.dj=}
DJOT_JS=../../modules/djot.js
DJOT_JS_SRC=$(shell find ${DJOT_JS}/src -name '.ts')
mod.rs: ${TEST_DJ} html
echo "use crate::suite_test;" > $@
for name in ${TEST}; do \
name_snake=$$(basename -a $$name); \
skip_reason=$$(grep -E "^$${name_snake}:" skip | cut -d: -f2); \
[ -n "$$skip_reason" ] && echo "#[ignore = \"$${skip_reason}\"]"; \
echo "#[test]"; \
echo "fn $$name_snake() {"; \
printf ' let src = r###"'; \
cat $$name.dj; \
echo '"###;'; \
printf ' let expected = r###"'; \
cat $$name.html; \
echo '"###;'; \
echo " suite_test!(src, expected);"; \
echo "}"; \
done >> $@
html: djot-js ${TEST_DJ}
echo ${TEST}
for name in ${TEST}; do cat $$name.dj | ./djot-js > $$name.html; done
touch $@
djot-js: ${DJOT_JS_SRC}
(cd "${DJOT_JS}" && npm install && npm run build)
echo "#!/bin/sh" > $@
echo 'node ${DJOT_JS}/lib/cli.js "$$@"' >> $@
chmod +x $@
clean:
rm -f *.rs *.html
rm -f html
rm -f djot-js