aboutsummaryrefslogtreecommitdiffhomepage
path: root/makefile
diff options
context:
space:
mode:
authorRalph Amissah <ralph.amissah@gmail.com>2022-06-03 13:17:14 -0400
committerRalph Amissah <ralph.amissah@gmail.com>2022-06-14 19:58:02 -0400
commit14a07cb1ebeef0062355245d7af4193d8537a3fd (patch)
treea2d91ebaaa777a59feecc94abdb1ae4ff7b61719 /makefile
parentbuild related, mostly nix flakes (diff)
makefile, too much, prune!
Diffstat (limited to 'makefile')
-rw-r--r--makefile1212
1 files changed, 1212 insertions, 0 deletions
diff --git a/makefile b/makefile
new file mode 100644
index 0000000..6b76b0a
--- /dev/null
+++ b/makefile
@@ -0,0 +1,1212 @@
+PROG_VER_GIT :=$(shell echo `git describe --long --tags | sed -e "s/^[ a-z_-]\+\([0-9.]\+\)/\1/;s/\([^-]*-g\)/r\1/;s/-/./g"`)
+PROG_VER_DECLARED :=$(shell echo `cat ./views/version.txt | grep --color=never "enum" | sed 's/.\+(\([0-9]\+\),[ \t]\+\([0-9]\+\),[ \t]\+\([0-9]\+\)[ \t]*).\+/\1.\2.\3/g'`)
+DUB=dub
+DUB_FLAGS=-v --force --compiler=
+PRG_NAME=doc-reform
+PRG_NICKAME=spine
+PRG_NAME_DIR=$(shell echo `echo $(PRG_NAME) | sed -e "s/-/_/g"`)
+PRG_SRC=$(PRG_NAME).d
+PRG_SRCDIR=./src
+PRG_BIN=$(PRG_NAME)
+PRG_BINDIR=./bin
+PRG_DOCDIR=./docs
+EMACSLISP=/usr/share/emacs/site-lisp
+ORG_VER_AVAILABLE=$(shell echo `ls -d ~/.emacs.d/elpa/org-???????? | cut -d '-' -f2`)
+EMACSLISP_ORG=~/.emacs.d/elpa/org-$($(shell echo $(ORG_VER_AVAILABLE)))
+ORG_CONTRIB_VER_AVAILABLE=$(shell echo `ls -d ~/.emacs.d/elpa/org-plus-contrib-???????? | cut -d '-' -f2`)
+EMACSLISP_ORG_CONTRIB=~/.emacs.d/elpa/org-plus-contrib-$($(shell echo $(ORG_CONTRIB_VER_AVAILABLE)))
+ORGFILELIST=$(shell echo `ls -1 org/*.org`)
+ORGFILES=""
+ORGDIR :=$(shell echo `pwd`)
+SiSU_MARKUP_SAMPLES_FIND_PODS= \
+find data/pod -maxdepth 2 -name pod.manifest | cut -f 1-3 -d / | sort
+
+SiSU_MARKUP_SAMPLES_PODS_FOUND= \
+$(SiSU_MARKUP_SAMPLES_FIND_PODS) | xargs
+
+SiSU_MARKUP_SAMPLES_POD = \
+data/pod/accelerando.charles_stross \
+data/pod/alices_adventures_in_wonderland.lewis_carroll \
+data/pod/content.cory_doctorow \
+data/pod/democratizing_innovation.eric_von_hippel \
+data/pod/down_and_out_in_the_magic_kingdom.cory_doctorow \
+data/pod/for_the_win.cory_doctorow \
+data/pod/free_as_in_freedom_2.richard_stallman_and_the_free_software_revolution.sam_williams.richard_stallman \
+data/pod/free_culture.lawrence_lessig \
+data/pod/free_for_all.peter_wayner \
+data/pod/gpl2.fsf \
+data/pod/gpl3.fsf \
+data/pod/gullivers_travels.jonathan_swift \
+data/pod/little_brother.cory_doctorow \
+data/pod/live-manual \
+data/pod/sisu-manual \
+data/pod/the_autonomous_contract.ralph_amissah \
+data/pod/the_cathedral_and_the_bazaar.eric_s_raymond \
+data/pod/the_public_domain.james_boyle \
+data/pod/the_wealth_of_networks.yochai_benkler \
+data/pod/through_the_looking_glass.lewis_carroll \
+data/pod/two_bits.christopher_kelty \
+data/pod/un_contracts_international_sale_of_goods_convention_1980 \
+data/pod/viral_spiral.david_bollier
+# SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND = \
+# find data/sisudir/media/text -name *.ss[tm] | sort | xargs
+#
+# SiSU_MARKUP_SAMPLES_DIR = \
+# data/sisudir/media/text/accelerando.charles_stross.sst \
+# data/sisudir/media/text/alices_adventures_in_wonderland.lewis_carroll.sst \
+# data/sisudir/media/text/content.cory_doctorow.sst \
+# data/sisudir/media/text/democratizing_innovation.eric_von_hippel.sst \
+# data/sisudir/media/text/down_and_out_in_the_magic_kingdom.cory_doctorow.sst \
+# data/sisudir/media/text/ffa_tmp.sst \
+# data/sisudir/media/text/for_the_win.cory_doctorow.sst \
+# data/sisudir/media/text/free_as_in_freedom_2.richard_stallman_and_the_free_software_revolution.sam_williams.richard_stallman.sst \
+# data/sisudir/media/text/free_culture.lawrence_lessig.sst \
+# data/sisudir/media/text/free_for_all.peter_wayner.sst \
+# data/sisudir/media/text/gpl2.fsf.sst \
+# data/sisudir/media/text/gpl3.fsf.sst \
+# data/sisudir/media/text/gullivers_travels.jonathan_swift.sst \
+# data/sisudir/media/text/little_brother.cory_doctorow.sst \
+# data/sisudir/media/text/sisu_markup.sst \
+# data/sisudir/media/text/sisu_markup_stress_test.sst \
+# data/sisudir/media/text/sisu_markup_test.sst \
+# data/sisudir/media/text/table_special_markup.sst \
+# data/sisudir/media/text/the_autonomous_contract.ralph_amissah.sst \
+# data/sisudir/media/text/the_cathedral_and_the_bazaar.eric_s_raymond.sst \
+# data/sisudir/media/text/the_public_domain.james_boyle.sst \
+# data/sisudir/media/text/the_wealth_of_networks.yochai_benkler.sst \
+# data/sisudir/media/text/through_the_looking_glass.lewis_carroll.sst \
+# data/sisudir/media/text/two_bits.christopher_kelty.sst \
+# data/sisudir/media/text/un_contracts_international_sale_of_goods_convention_1980.sst \
+# data/sisudir/media/text/viral_spiral.david_bollier.sst
+#
+Date := `date "+%Y%m%d"`
+SpineBIN := "${SpineBIN}" # './result/bin'
+SpineOUT := "${SpineOUT}" # '/srv/www/spine'
+SpinePOD := "${SpinePOD}" # '/grotto-ra/repo/git.repo/projects/project-spine/doc-reform-markup/spine-markup-samples/markup/pod'
+SpineSearchActionLocal := 'http://localhost/spine_search'
+SpineSearchActionRemote := 'https://sisudoc.org/spine_search'
+SpineCGIform := 'spine_search'
+SpineSQLdb := 'spine.search.db'
+PROG_VER_GIT := '''`git describe --long --tags | sed -e "s/^[ a-z_-]\+\([0-9.]\+\)/\1/;s/\([^-]*-g\)/r\1/;s/-/./g"`'''
+PROG_VER_DECLARED := '''`cat ./views/version.txt | grep --color=never "enum" | sed 's/.\+(\([0-9]\+\),[ \t]\+\([0-9]\+\),[ \t]\+\([0-9]\+\)[ \t]*).\+/\1.\2.\3/g'`'''
+hwd := `pwd`
+gwd := `pwd` + "/src/ext_depends"
+deps := "`ls -gx './src/ext_depends'`"
+dirs_loc := "`ls -gx '.'`"
+#dirs := "`ls -gx {{gwd}}`"
+
+buildPhase:
+ HOME=$${PWD}; \
+ for DC_ in dmd ldmd2 gdmd; do \
+ echo "- check for D compiler $${DC_}"; \
+ DC=$$(type -P $${DC_} || echo ""); \
+ if [ ! "$${DC}" == "" ]; then \
+ break; \
+ fi; \
+ done; \
+ echo "D compiler = $${DC}"; \
+ if [ "$${DC}" == "" ]; then \
+ echo "Error: could not find D compiler"; \
+ exit 1; \
+ fi; \
+ echo "$${DC_} used as D compiler to build $${pname}"; \
+ export DFLAGS="-O2 -inline"; \
+ dub build --compiler=$${DC} --build=release --combined --skip-registry=all;
+
+checkPhase:
+ runHook preCheck; \
+ HOME=$${PWD}; \
+ dub test --combined --skip-registry=all; \
+ runHook postCheck
+
+installPhase:
+ runHook preInstall; \
+ mkdir -p $${out}/bin; \
+ install -m755 ./bin/spine $${out}/bin/spine; \
+ runHook postInstall
+#cp -r bin/spine $out/bin/.
+
+postInstall:
+ echo "$${out}/share/cgi-bin"; \
+ echo `ls -la $${out}/bin/spine`
+
+commands:
+ rg --color=always -B1 "^[a-z]\w+:" makefile | less
+
+cmd:
+ rg --color=always -B1 "^[a-z]\w+:" makefile | bat
+
+# tangle org files
+org-tangle:
+ cd ./org; \
+ org-tangle *.org; \
+ cd -
+
+# project vim
+proj-v:
+ nvim ./org/doc-reform.org
+
+# project emacs, cli (single instance open)
+proj-e:
+ emacsclient -F -c -a -f ./org/doc-reform.org
+
+# project emacs, cli (multiple instance, no copy & paste)
+proj:
+ emacsclient -nw -a -f ./org/doc-reform.org
+
+# project emacs, gui
+proj-emacs:
+ emacs ./org/doc-reform.org &
+
+# epub output
+out-epub:
+ {{SpineBIN}}/spine -v \
+ --epub --output={{SpineOUT}} {{SpinePOD}}/*
+
+# html output with local search links
+out-html:
+ {{SpineBIN}}/spine -v --generated-by \
+ --curate \
+ --html --html-link-search --html-link-curate --cgi-url-action="{{SpineSearchActionLocal}}" \
+ --output={{SpineOUT}} {{SpinePOD}}/*
+
+# latex output
+out-latex:
+ {{SpineBIN}}/spine -v \
+ --latex \
+ --output={{SpineOUT}} {{SpinePOD}}/*
+
+# odf output
+out-odf:
+ {{SpineBIN}}/spine -v \
+ --odf \
+ --output={{SpineOUT}} {{SpinePOD}}/*
+
+# sqlite output
+out-sqlite:
+ {{SpineBIN}}/spine -v \
+ --sqlite-update --sqlite-db-filename="{{SpineSQLdb}}" \
+ --output={{SpineOUT}} {{SpinePOD}}/*
+
+# generate markup sample output with local search links
+output-samples-local:
+ {{SpineBIN}}/spine -v \
+ --latex --latex-init \
+ --epub \
+ --html --html-link-search --html-link-pdf --html-link-curate --html-link-markup \
+ --cgi-sqlite-search-filename="{{SpineCGIform}}" --cgi-url-action="{{SpineSearchActionLocal}}" \
+ --curate \
+ --sqlite-update --sqlite-db-filename="{{SpineSQLdb}}" \
+ --output={{SpineOUT}} {{SpinePOD}}/*
+
+# generate markup sample output with remote search links
+output-samples-remote:
+ {{SpineBIN}}/spine -v \
+ --generated-by \
+ --latex --latex-init \
+ --epub \
+ --html --html-link-search --html-link-pdf --html-link-curate \
+ --cgi-sqlite-search-filename="{{SpineCGIform}}" --cgi-url-action="{{SpineSearchActionRemote}}" \
+ --curate \
+ --sqlite-update --sqlite-db-filename="{{SpineSQLdb}}" \
+ --output={{SpineOUT}} {{SpinePOD}}/*
+
+# generate markup sample output with local search links
+output-samples: output-samples-local
+
+# nix build (remote) run
+generate-output-remote: nix-build output-samples-remote
+
+# nix build (local) run
+generate-output-local: nix-build output-samples-local
+
+# preview org files vim
+files-vim:
+ fd --max-depth 6 --type file -g "*" | sort \
+ | fzf \
+ --preview='bat --color "always" {}' \
+ --preview-window=right:66% \
+ --bind="enter:execute(nvim {})"; \
+
+# preview org files emacs
+files-emacs:
+ fd --max-depth 6 --type file -g "*" | sort \
+ | fzf \
+ --preview='bat --color "always" {}' \
+ --preview-window=right:66% \
+ --bind="enter:execute(emacsclient -nw -a -f {})"; \
+
+# preview org files vim
+org-vim:
+ cd ./org; \
+ fd --max-depth 5 --type file -g "*.org" | sort \
+ | fzf \
+ --preview='bat --color "always" {}' \
+ --preview-window=right:66% \
+ --bind="enter:execute(nvim {})"; \
+ cd -
+
+# preview org files emacs
+org-emacs:
+ cd ./org; \
+ fd --max-depth 5 --type file -g "*.org" | sort \
+ | fzf \
+ --preview='bat --color "always" {}' \
+ --preview-window=right:66% \
+ --bind="enter:execute(emacsclient -nw -a -f {})"; \
+ cd -
+
+## search org files (view in vim)
+#org-v find:
+# cd ./org; \
+# rg --files-with-matches --no-messages "{{find}}" | \
+# fzf --multi --ansi --print0 \
+# --preview-window=right:66% \
+# --preview="rg --pretty --after-context 3 --before-context 2 -- \"{{find}}\" {}" \
+# --bind="enter:execute(nvim -c \"silent! /{{find}}\" {1})"; \
+# cd -
+#
+## search org files (view in emacsclient)
+#org-e find:
+# cd ./org; \
+# rg --files-with-matches --no-messages "{{find}}" | \
+# fzf --multi --ansi --print0 \
+# --preview-window=right:66% \
+# --preview="rg --pretty --after-context 3 --before-context 2 -- \"{{find}}\" {}" \
+# --bind="enter:execute(emacsclient -nw -a -f {})"; \
+# cd -
+#
+## search tips.org files (view in emacs)
+#org-E find:
+# cd ./org; \
+# rg --files-with-matches --no-messages "{{find}}" | \
+# fzf --multi --ansi --print0 \
+# --preview-window=right:66% \
+# --preview="rg --pretty --after-context 3 --before-context 2 -- \"{{find}}\" {}" \
+# --bind="enter:execute(emacs {} &)"; \
+# cd -
+#
+## search for in directory specified (view in vim, uses rg & fzf) ["find" for emacs]
+#sDir-v find dir:
+# cd {{dir}}; \
+# rg --files-with-matches --no-messages "{{find}}" | \
+# fzf --multi --ansi --print0 \
+# --preview-window=right:66% \
+# --preview="rg --pretty --after-context 3 --before-context 2 -- \"{{find}}\" {}" \
+# --bind="enter:execute(nvim -c \"silent! /{{find}}\" {1})"; \
+# cd -
+#
+## search for in directory specified (view in emacs, uses rg & fzf) ["search" for emacs]
+#sDir-e find dir:
+# cd {{dir}}; \
+# rg --files-with-matches --no-messages "{{find}}" | \
+# fzf --multi --ansi --print0 \
+# --preview-window=right:66% \
+# --preview="rg --pretty --after-context 3 --before-context 2 -- \"{{find}}\" {}" \
+# --bind="enter:execute(emacsclient -nw -a -f {})"; \
+# cd -
+#
+## search for in directory specified (view in emacs, uses rg & fzf) ["search" for emacs]
+#sDir-E find dir:
+# cd {{dir}}; \
+# rg --files-with-matches --no-messages "{{find}}" | \
+# fzf --multi --ansi --print0 \
+# --preview-window=right:66% \
+# --preview="rg --pretty --after-context 3 --before-context 2 -- \"{{find}}\" {}" \
+# --bind="enter:execute(emacs {} &)"; \
+# cd -
+
+# show markup pod source selections
+markup:
+ ls -1 --color=always {{SpinePOD}}
+ ls -1 -d --color=always {{SpinePOD}}/*/
+
+# show markup pod source tree
+markup-pod-tree:
+ exa -alT --git -I'.git|.dub|*_' --color=always -L5 ${SpinePOD} | less -R
+
+# show markup pod source tree
+tree-src:
+ exa -alT --git -I'*_' --color=always -L5 ${SpineSRC}/doc_reform ${SpinePROJ}/views | less -R
+
+## show markup pod source tree
+#tree-src-omit:
+# exa -alT --git -I'.git|.dub|*_' --color=always -L5 ${SpineSRC} ${SpinePROJ}/views | less -R
+
+# show markup pod source tree
+tree-src-search-cgi:
+ exa -alT --git -I'*_' --color=always -L5 ${SpineSearchCGI}/src ${SpineSearchCGI}/views | less -R
+
+# show markup files
+markup-files:
+ cd {{SpinePOD}}; \
+ find . -type f -iname "*sst"; \
+ cd -; \
+ echo {{SpinePOD}}
+# find {{SpinePOD}}/. -type f -iname "*sst"
+
+# preview markup files vim
+markup-files-vim:
+ cd {{SpinePOD}}; \
+ fd --max-depth 5 --type file -g "*.ss?" | sort \
+ | fzf \
+ --preview='bat --color "always" {}' \
+ --preview-window=right:66% \
+ --bind="enter:execute(nvim {})"; \
+ cd -
+
+# preview markup files emacs
+markup-files-emacs:
+ cd {{SpinePOD}}; \
+ fd --max-depth 5 --type file -g "*.ss?" | sort \
+ | fzf \
+ --preview='bat --color "always" {}' \
+ --preview-window=right:66% \
+ --bind="enter:execute(emacsclient -nw -a -f {})"; \
+ cd -
+
+# markup samples list
+markup-sample: markup-pod-sample
+
+# markup samples list
+markup-pod-sample:
+ find data/pod -name pod.manifest | cut -f 1-3 -d / | sort
+
+# markup samples pod manifests and sst files
+markup-samples: markup-pod-samples markup-file-samples
+
+# markup samples pod manifests
+markup-pod-samples:
+ echo "{{SpinePOD}}"; \
+ find {{SpinePOD}} -name pod.manifest | sort
+
+#find {{SpinePOD}} -name pod.manifest | sed -E 's:.+?(([/][^/]+){2})$:\1:'
+
+# markup samples sst files
+markup-file-samples:
+ echo "{{SpinePOD}}"; \
+ find {{SpinePOD}} -name *.ss[tm] | sort
+
+# markup_dir_samples:
+# find data/sisudir/media/text -name *.ss[tm] | sort
+
+# version_tag:
+# echo "DRV=0.11.3; git tag -f doc-reform_v$$\{DRV} -m\"doc-reform $$\{DRV}\" HEAD" && \
+# echo "git tag -f doc-reform_v0.11.3 -m\"doc-reform spine-0.11.3\" HEAD"
+
+# archive spine output (www)
+spineWWWarchive:
+ cd /srv/www ; \
+ rm spine_output.{{Date}}.tar.bz2 ; \
+ sudo tar --exclude='./spine/latex' --exclude='./spine/pod' --exclude='./spine/*_' -cjf spine_output.{{Date}}.tar.bz2 ./spine ; \
+ cd -
+
+# rsync archived spine output to Linode
+spineWWWrsyncLinode:
+ rsync -v /srv/www/spine_output.{{Date}}.tar.bz2 linode:./stage/. ; \
+ rsync -v /var/www/sqlite/spine.search.db linode:./stage/. ; \
+ echo "tar -xf ../spine_output.{{Date}}.tar.bz2"
+
+# get project external dependencies
+depends_get:
+ dub upgrade; \
+ cd {{gwd}} && \
+ echo "{{dirs_loc}}" && \
+ for dir in {{dirs_loc}}; do \
+ if [[ -d ${dir} ]]; then \
+ echo {{gwd}}/${dir} && \
+ if [[ "imageformats" == ${dir} ]]; then \
+ echo {{gwd}}/${dir} && \
+ rm -rvf {{gwd}}/${dir} && \
+ git clone --depth=1 https://github.com/tjhann/${dir} && \
+ cd ${dir} && \
+ echo $$PWD && \
+ echo "${dir} `git rev-parse HEAD | cut -c 1-8`" > ../${dir}.meta && \
+ echo "https://github.com/tjhann/${dir}" >> ../${dir}.meta && \
+ echo "Boost Software License 1.0 (BSL-1.0)" >> ../${dir}.meta && \
+ cd {{gwd}} && \
+ rm -rf {{gwd}}/${dir}/.git; \
+ elif [[ "d2sqlite3" == ${dir} || "D-YAML" == ${dir} || "tinyendian" == ${dir} ]]; then \
+ echo {{gwd}}/${dir} && \
+ rm -rvf {{gwd}}/${dir} && \
+ git clone --depth=1 https://github.com/dlang-community/${dir} && \
+ cd {{gwd}}/${dir} && \
+ echo "${dir} `git rev-parse HEAD | cut -c 1-8`" > ../${dir}.meta && \
+ echo "https://github.com/dlang-community/${dir}" >> ../${dir}.meta && \
+ echo "Boost Software License 1.0 (BSL-1.0)" >> ../${dir}.meta && \
+ cd {{gwd}} && \
+ rm -rf {{gwd}}/${dir}/.git; \
+ fi; \
+ fi; \
+ done; \
+ cd {{hwd}}
+
+# get and set project external dependencies
+depends_set: depends_get
+ dub describe | sed 's~$(shell echo `pwd | sed 's_/_\\/_g'`)~.~g' > dub_describe.json
+
+# markup_samples:
+# find data/pod -name pod.manifest | cut -f 1-3 -d / | sort; \
+# find data/sisudir/media/text -name *.ss[tm] | sort
+#
+# markup_pod_samples:
+# find data/pod -name pod.manifest | cut -f 1-3 -d / | sort
+#
+# markup_dir_samples:
+# find data/sisudir/media/text -name *.ss[tm] | sort
+#
+version_tag:
+ echo "DRV=0.11.3; git tag -f doc-reform_v$$\{DRV} -m\"doc-reform $$\{DRV}\" HEAD" && \
+ echo "git tag -f doc-reform_v0.11.3 -m\"doc-reform spine-0.11.3\" HEAD"
+
+changelog_:
+ git log --pretty=format:'---%+s %+as %ae%+h%d%+b' --no-merges | sed "/^\\s*$$/d" | sed "s/^---$$//" | sed "s/^\(\*\)\+/-/" | sed "s/ \+$$//" > CHANGELOG_
+
+# git changelog for project
+changelog:
+ git log --pretty=format:'---%+s %+as %ae%+h%d%+b' --no-merges | sed "/^\\s*$$/d" | sed "s/^---$$//" | sed "s/^\(\*\)\+/-/" | sed "s/ \+$$//" | sed "s/ \+$//" > CHANGELOG_
+
+gitZip:
+ git archive -v --format=tar --prefix=`echo spine-$(PROG_VER_DECLARED)-tag-$(PROG_VER_GIT)`/ HEAD | gzip > ../spine-$(PROG_VER_DECLARED)-tag-$(PROG_VER_GIT).tar.gz && \
+ echo "to unzip: tar -xzf spine-$(PROG_VER_DECLARED)-tag-$(PROG_VER_GIT).tar.gz"
+
+# git archive project, produce current state .tar.gz
+gitArchive:
+ git archive -v --format=tar --prefix=spine-$(PROG_VER_DECLARED)-tag-$(PROG_VER_GIT)/ HEAD | gzip > ../spine-$(PROG_VER_DECLARED)-tag-$(PROG_VER_GIT).tar.gz && \
+ echo "to unzip: tar -xzf spine-$(PROG_VER_DECLARED)-tag-$(PROG_VER_GIT).tar.gz"
+
+# git archive project, produce current state .tar.gz
+# gitArchive:
+# git archive -v --format=tar --prefix="spine-{{PROG_VER_DECLARED}}-tag-{{PROG_VER_GIT}}/" HEAD | gzip > ../spine-{{PROG_VER_DECLARED}}-tag-{{PROG_VER_GIT}}.tar.gz && \
+# echo "to unzip: tar -xzf spine-{{PROG_VER_DECLARED}}-tag-{{PROG_VER_GIT}}.tar.gz"
+
+get_depends:
+ hwd=$$(echo `pwd`) && \
+ gwd="$${hwd}/src/ext_depends" && \
+ dirs=$$(echo `ls -gx $${gwd}`) && \
+ license_bsl="Boost Software License 1.0 (BSL-1.0)" && \
+ echo $${hwd} && \
+ echo $${gwd} && \
+ echo $${deps} && \
+ dub upgrade; \
+ cd $${gwd} && \
+ for dir in $${deps}; do \
+ if [ -d $${dir} ]; then \
+ echo $${dir} && \
+ if [ "imageformats" == $${dir} ]; then \
+ echo $${dir} && \
+ rm -rf $${dir} && \
+ git clone --depth=1 https://github.com/tjhann/$${dir} && \
+ cd $${dir} && \
+ echo $$PWD && \
+ echo "$${dir} `git rev-parse HEAD | cut -c 1-8`" > ../$${dir}.meta && \
+ echo "https://github.com/tjhann/$${dir}" >> ../$${dir}.meta && \
+ echo "$${license_bsl}" >> ../$${dir}.meta && \
+ cd $${gwd} && \
+ rm -rf $${dir}/.git; \
+ elif [[ "d2sqlite3" == $${dir} || "D-YAML" == $${dir} || "tinyendian" == $${dir} ]]; then \
+ echo $${dir} && \
+ rm -rf $${dir} && \
+ git clone --depth=1 https://github.com/dlang-community/$${dir} && \
+ cd $${dir} && \
+ echo "$${dir} `git rev-parse HEAD | cut -c 1-8`" > ../$${dir}.meta && \
+ echo "https://github.com/dlang-community/$${dir}" >> ../$${dir}.meta && \
+ echo "$${license_bsl}" >> ../$${dir}.meta && \
+ cd $${gwd} && \
+ rm -rf $${dir}/.git; \
+ fi; \
+ fi; \
+ done; \
+ cd $${hwd}
+
+set_depends: get_depends
+ dub describe | sed 's~$(shell echo `pwd | sed 's_/_\\/_g'`)~.~g' > dub_describe.json
+
+rm_flakelock:
+ git reset HEAD flake.lock && \
+ touch flake.lock \
+ git rm -f flake.lock
+
+flake_update:
+ git add .; \
+ nix flake update && \
+ git reset HEAD flake.lock; \
+ cp flake.lock flake.lock_
+
+flake_update_move_lock: flake_update
+ touch flake.lock \
+ git rm -f flake.lock
+
+set_latest: set_depends flake_update rm_flakelock
+
+dub_upgrade:
+ $(DUB) upgrade
+
+default: ldc
+
+all: dmd ldc gdc
+
+all_ver: dmd_ver ldc_ver gdc_ver
+
+all_debug: dmd_debug gdc_debug ldc_debug
+
+meson_clean_build_dir:
+ rm -r build; mkdir build
+
+meson_build: meson_clean_build_dir
+ meson --buildtype=debugoptimized build
+ ninja -C build
+ notify-send -t 0 'D meson build ldc compiled test release executable ready' 'spine'
+
+meson_redo: meson_clean_build_dir meson_build
+
+meson_project_build_clean: clean skel tangle dub_upgrade meson_build
+
+meson: meson_clean_build_dir dub_upgrade meson_build
+
+all_clean: clean tangle dmd ldc gdc
+
+all_ver_clean: clean tangle dmd_ver ldc_ver gdc_ver
+
+all_debug_ver: dmd_debug_ver gdc_debug_ver ldc_debug_ver
+
+all_debug_clean_ver: clean tangle dmd_debug_ver gdc_debug_ver ldc_debug_ver
+
+dmd: dub_upgrade
+ $(DUB) --compiler=dmd --config=dmd --build=release-nobounds
+ notify-send -t 0 'D dmd compiled test release executable ready' 'spine-dmd'
+
+dmd_debug:
+ $(DUB) --compiler=dmd --config=dmd --build=debug
+
+# assumes git tags with program version
+dmd_ver: dub_upgrade
+ $(DUB) --compiler=dmd --config=dmd-version
+ mv bin/spine-dmd-ver bin-archive/spine-$(PROG_VER_DECLARED)-tag-$(PROG_VER_GIT)-dmd
+ notify-send -t 0 'D dmd compiled test release executable ready' 'spine-$(PROG_VER_DECLARED)-tag-$(PROG_VER_GIT)-dmd'
+
+dmd_clean_ver: clean tangle dmd_ver
+
+dmd_rel: expunge skel tangle
+ $(DUB) --compiler=dmd --config=spine-release
+
+dmd_rel_tangle: tangle
+ $(DUB) --compiler=dmd --config=spine-dmd
+
+dmd_rel_expunge_tangle: expunge skel tangle dmd_rel_tangle
+
+dmd_debug_tangle: tangle
+ $(DUB) --compiler=dmd --config=spine-dmd-debug
+
+gdc: dub_upgrade
+ $(DUB) --compiler=gdc --config=gdc
+ notify-send -t 0 'D gdc compiled test release executable ready' 'spine-gdc'
+
+gdc_debug:
+ $(DUB) --compiler=gdc --config=gdc --build=debug
+
+# assumes git tags with program version
+gdc_ver: dub_upgrade
+ $(DUB) --compiler=gdc --config=gdc-version
+ mv bin/spine-gdc-ver bin-archive/spine-$(PROG_VER_DECLARED)-tag-$(PROG_VER_GIT)-gdc
+ notify-send -t 0 'D gdc compiled test release executable ready' 'spine-$(PROG_VER_DECLARED)-tag-$(PROG_VER_GIT)-gdc'
+
+gdc_clean_ver: clean tangle gdc_ver
+
+gdc_rel: expunge skel tangle
+ $(DUB) --compiler=gdc --config=spine-release
+
+gdc_rel_tangle: tangle
+ $(DUB) --compiler=gdc --config=spine-gdc
+
+gdc_rel_expunge_tangle: expunge skel tangle gdc_rel_tangle
+
+gdc_debug_tangle: tangle
+ $(DUB) --compiler=gdc --config=spine-gdc-debug
+
+ldc: dub_upgrade
+ $(DUB) --compiler=ldc2 --config=ldc --build=release
+ notify-send -t 0 'D ldc compiled test release executable ready' 'spine-ldc'
+
+ldc_debug:
+ $(DUB) --compiler=ldc2 --config=ldc --build=debug
+
+# assumes git tags with program version
+ldc_ver: dub_upgrade
+ $(DUB) --compiler=ldc2 --config=ldc-version
+ mv bin/spine-ldc-ver bin-archive/spine-$(PROG_VER_DECLARED)-tag-$(PROG_VER_GIT)-ldc
+ notify-send -t 0 'D ldc2 compiled test release executable ready' 'spine-$(PROG_VER_DECLARED)-tag-$(PROG_VER_GIT)-ldc'
+
+ldc_clean_ver: clean tangle ldc_ver
+
+ldc_rel: expunge skel tangle
+ $(DUB) --compiler=ldc2 --config=spine-release
+
+ldc_rel_tangle: tangle
+ $(DUB) --compiler=ldc2 --config=spine-ldc
+
+ldc_rel_expunge_tangle: expunge skel tangle ldc_rel_tangle
+
+ldc_debug_tangle: tangle
+ $(DUB) --compiler=ldc2 --config=spine-ldc-debug
+
+reinit: clean skel tangle
+
+skel:
+ mkdir -p $(PRG_BINDIR); \
+ mkdir -p $(PRG_BINDIR)-archive; \
+ mkdir -p build; \
+ mkdir -p views; \
+ mkdir -p data; \
+ mkdir -p sundry/misc/util/d/cgi/search/cgi-bin/src; \
+ mkdir -p sundry/misc/util/d/tools/markup_conversion; \
+ mkdir -p sundry/misc/editor-syntax-etc/emacs; \
+ mkdir -p sundry/misc/editor-syntax-etc/vim/syntax; \
+ mkdir -p sundry/misc/editor-syntax-etc/vim/colors; \
+ mkdir -p sundry/misc/editor-syntax-etc/vim/ftplugin; \
+ mkdir -p sundry/misc/editor-syntax-etc/vim/rc; \
+ mkdir -p sundry/misc/editor-syntax-etc/vim/templates; \
+ mkdir -p $(PRG_SRCDIR)/$(PRG_NAME_DIR)/conf; \
+ mkdir -p $(PRG_SRCDIR)/$(PRG_NAME_DIR)/io_in; \
+ mkdir -p $(PRG_SRCDIR)/$(PRG_NAME_DIR)/io_out; \
+ mkdir -p $(PRG_SRCDIR)/$(PRG_NAME_DIR)/meta; \
+ mkdir -p $(PRG_SRCDIR)/$(PRG_NAME_DIR)/share; \
+ mkdir -p $(PRG_SRCDIR)/$(PRG_NAME_DIR); \
+ mkdir -p $(PRG_BINDIR);
+
+init: skel
+
+clean:
+ rm -rf build; \
+ rm -rf $(PRG_SRCDIR); \
+ rm -rf $(PRG_DOCDIR);
+
+clean_bin:
+ rm $(PRG_BINDIR)/*
+
+clean_src:
+ rm -rf $(PRG_SRCDIR);
+
+clean_docs:
+ rm -rf $(PRG_DOCDIR)
+
+expunge:
+ rm -f dub.selections.json; \
+ rm -rf build; \
+ rm -rf $(PRG_SRCDIR); \
+ rm -rf $(PRG_BINDIR); \
+ rm -rf $(PRG_DOCDIR);
+
+distclean: expunge
+
+distclean_and_init: expunge
+ mkdir -p views; \
+ mkdir -p sundry/misc/util/d/cgi/search/cgi-bin/src; \
+ mkdir -p sundry/misc/util/d/tools/markup_conversion; \
+ mkdir -p sundry/misc/editor-syntax-etc/emacs; \
+ mkdir -p sundry/misc/editor-syntax-etc/vim/syntax; \
+ mkdir -p sundry/misc/editor-syntax-etc/vim/colors; \
+ mkdir -p sundry/misc/editor-syntax-etc/vim/ftplugin; \
+ mkdir -p sundry/misc/editor-syntax-etc/vim/rc; \
+ mkdir -p sundry/misc/editor-syntax-etc/vim/templates; \
+ mkdir -p $(PRG_SRCDIR)/$(PRG_NAME_DIR); \
+ mkdir -p $(PRG_BINDIR);
+
+ver:
+ echo spine-$(PROG_VER_DECLARED)-tag-$(PROG_VER_GIT)
+
+clean_tangle_build: clean tangle build
+
+tangle_build: tangle build
+
+build: $(PRG_SRCDIR)/$(PRG_SRC)
+ $(DC) $(DC_FLAGS) \
+ $(DC_FLAG_BINOF)$(PRG_BINDIR)/$(PRG_BIN) \
+ $(PRG_SRCDIR)/$(PRG_SRC)
+
+rebuild: $(PRG_SRCDIR)/$(PRG_SRC) $(PRG_BINDIR)/$(PRG_BIN).o clean build
+
+makefile_new:
+ make -k tangle_maker
+
+restart: clean tangle
+
+find_pods:
+ $(SiSU_MARKUP_SAMPLES_FIND_PODS)
+
+dmd_testrun_find:
+ ./bin/spine-dmd -v --source --html --epub --sqlite-discrete \
+--sqlite-create --sqlite-update \
+--output-dir=tmp/program_output_pod \
+data/pod/sisu-manual
+
+dmd_testrun_find_pod_source:
+ $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \
+ ./bin/spine-ldc -v --source --html --epub \
+ --output-dir=tmp/program_output_pod
+
+dmd_testrun_find_pod_pod:
+ $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \
+ ./bin/spine-dmd -v --pod \
+ --output-dir=tmp/program_output_pod
+
+dmd_testrun_find_pod_html:
+ $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \
+ ./bin/spine-dmd -v --html \
+ --output-dir=tmp/program_output_pod
+
+dmd_testrun_find_pod_epub:
+ $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \
+ ./bin/spine-dmd -v --epub \
+ --output-dir=tmp/program_output_pod
+
+dmd_testrun_find_pod_all:
+ $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \
+ ./bin/spine-dmd -v --source --html --epub --sqlite-discrete \
+ --sqlite-create --sqlite-update \
+ --output-dir=tmp/program_output_pod
+
+dmd_testrun_paths_pod_source:
+ ./bin/spine-dmd -v --source \
+ --output-dir=tmp/program_output_pod \
+ $(SiSU_MARKUP_SAMPLES_POD)
+
+dmd_testrun_paths_pod_pod:
+ ./bin/spine-dmd -v --pod \
+ --output-dir=tmp/program_output_pod \
+ $(SiSU_MARKUP_SAMPLES_POD)
+
+dmd_testrun_paths_pod_html:
+ ./bin/spine-dmd -v --html \
+ --output-dir=tmp/program_output_pod \
+ $(SiSU_MARKUP_SAMPLES_POD)
+
+dmd_testrun_paths_pod_epub:
+ ./bin/spine-dmd -v --epub \
+ --output-dir=tmp/program_output_pod \
+ $(SiSU_MARKUP_SAMPLES_POD)
+
+dmd_testrun_paths_pod_all:
+ ./bin/spine-dmd -v --source --html --epub --sqlite-discrete \
+ --sqlite-create --sqlite-update \
+ --output-dir=tmp/program_output_pod \
+ $(SiSU_MARKUP_SAMPLES_POD)
+
+gdc_testrun_find:
+ ./bin/spine-gdc -v --source --html --epub --sqlite-discrete \
+ --sqlite-create --sqlite-update \
+ --output-dir=tmp/program_output_pod \
+ data/pod/sisu-manual
+
+gdc_testrun_find_pod_source:
+ $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \
+ ./bin/spine-gdc -v --source \
+ --output-dir=tmp/program_output_pod
+
+gdc_testrun_find_pod_pod:
+ $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \
+ ./bin/spine-gdc -v --pod \
+ --output-dir=tmp/program_output_pod
+
+gdc_testrun_find_pod_html:
+ $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \
+ ./bin/spine-gdc -v --html \
+ --output-dir=tmp/program_output_pod
+
+gdc_testrun_find_pod_epub:
+ $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \
+ ./bin/spine-gdc -v --epub \
+ --output-dir=tmp/program_output_pod
+
+gdc_testrun_find_pod_all:
+ $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \
+ ./bin/spine-gdc -v --source --html --epub --sqlite-discrete \
+ --sqlite-create --sqlite-update \
+ --output-dir=tmp/program_output_pod
+
+gdc_testrun_paths:
+ ./bin/spine-gdc -v --source --html --epub --sqlite-discrete \
+ --sqlite-create --sqlite-update \
+ --output-dir=tmp/program_output_pod \
+ data/pod/sisu-manual
+
+gdc_testrun_paths_pod_source:
+ ./bin/spine-gdc -v --source \
+ --output-dir=tmp/program_output_pod \
+ $(SiSU_MARKUP_SAMPLES_POD)
+
+gdc_testrun_paths_pod_pod:
+ ./bin/spine-gdc -v --pod \
+ --output-dir=tmp/program_output_pod \
+ $(SiSU_MARKUP_SAMPLES_POD)
+
+gdc_testrun_paths_pod_html:
+ ./bin/spine-gdc -v --html \
+ --output-dir=tmp/program_output_pod \
+ $(SiSU_MARKUP_SAMPLES_POD)
+
+gdc_testrun_paths_pod_epub:
+ ./bin/spine-gdc -v --epub \
+ --output-dir=tmp/program_output_pod \
+ $(SiSU_MARKUP_SAMPLES_POD)
+
+gdc_testrun_paths_pod_all:
+ ./bin/spine-gdc -v --source --html --epub --sqlite-discrete \
+ --sqlite-create --sqlite-update \
+ --output-dir=tmp/program_output_pod \
+ $(SiSU_MARKUP_SAMPLES_POD)
+
+ldc_testrun_find:
+ ./bin/spine-ldc -v --source --html --epub --sqlite-discrete \
+ --sqlite-create --sqlite-update \
+ --output-dir=tmp/program_output_pod \
+ data/pod/sisu-manual
+
+ldc_testrun_find_pod_source:
+ $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \
+ ./bin/spine-ldc -v --source \
+ --output-dir=tmp/program_output_pod
+
+ldc_testrun_find_pod_pod:
+ $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \
+ ./bin/spine-ldc -v --pod \
+ --output-dir=tmp/program_output_pod
+
+ldc_testrun_find_pod_html:
+ $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \
+ ./bin/spine-ldc -v --html \
+ --output-dir=tmp/program_output_pod
+
+ldc_testrun_find_pod_epub:
+ $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \
+ ./bin/spine-ldc -v --epub \
+ --output-dir=tmp/program_output_pod
+
+ldc_testrun_find_pod_all:
+ $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \
+ ./bin/spine-ldc -v --source --html --epub --sqlite-discrete \
+ --sqlite-create --sqlite-update \
+ --output-dir=tmp/program_output_pod
+
+ldc_testrun_paths:
+ ./bin/spine-ldc -v --source --html --epub --sqlite-discrete \
+ --sqlite-create --sqlite-update \
+ --output-dir=tmp/program_output_pod \
+ data/pod/sisu-manual
+
+ldc_testrun_paths_pod_source:
+ ./bin/spine-ldc -v --source \
+ --output-dir=tmp/program_output_pod \
+ $(SiSU_MARKUP_SAMPLES_POD)
+
+ldc_testrun_paths_pod_pod:
+ ./bin/spine-ldc -v --pod \
+ --output-dir=tmp/program_output_pod \
+ $(SiSU_MARKUP_SAMPLES_POD)
+
+ldc_testrun_paths_pod_html:
+ ./bin/spine-ldc -v --html \
+ --output-dir=tmp/program_output_pod \
+ $(SiSU_MARKUP_SAMPLES_POD)
+
+ldc_testrun_paths_pod_epub:
+ ./bin/spine-ldc -v --epub \
+ --output-dir=tmp/program_output_pod \
+ $(SiSU_MARKUP_SAMPLES_POD)
+
+ldc_testrun_paths_pod_all:
+ ./bin/spine-ldc -v --source --html --epub --sqlite-discrete \
+ --sqlite-create --sqlite-update \
+ --output-dir=tmp/program_output_pod \
+ $(SiSU_MARKUP_SAMPLES_POD)
+
+dmd_testrun_find_dir_source:
+ $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \
+ ./bin/spine-dmd -v --source \
+ --output-dir=tmp/program_output_dir
+
+dmd_testrun_find_dir_pod:
+ $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \
+ ./bin/spine-dmd -v --pod \
+ --output-dir=tmp/program_output_dir
+
+dmd_testrun_find_dir_html:
+ $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \
+ ./bin/spine-dmd -v --html \
+ --output-dir=tmp/program_output_dir
+
+dmd_testrun_find_dir_epub:
+ $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \
+ ./bin/spine-dmd -v --epub \
+ --output-dir=tmp/program_output_dir
+
+dmd_testrun_find_dir_all:
+ $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \
+ ./bin/spine-dmd -v --source --html --epub --sqlite-discrete \
+ --sqlite-create --sqlite-update \
+ --output-dir=tmp/program_output_dir
+
+dmd_testrun_filelist_dir_source:
+ ./bin/spine-dmd -v --source \
+ --output-dir=tmp/program_output_dir \
+ $(SiSU_MARKUP_SAMPLES_DIR)
+
+dmd_testrun_filelist_dir_pod:
+ ./bin/spine-dmd -v --pod \
+ --output-dir=tmp/program_output_dir \
+ $(SiSU_MARKUP_SAMPLES_DIR)
+
+dmd_testrun_filelist_dir_html:
+ ./bin/spine-dmd -v --html \
+ --output-dir=tmp/program_output_dir \
+ $(SiSU_MARKUP_SAMPLES_DIR)
+
+dmd_testrun_filelist_dir_epub:
+ ./bin/spine-dmd -v --epub \
+ --output-dir=tmp/program_output_dir \
+ $(SiSU_MARKUP_SAMPLES_DIR)
+
+dmd_testrun_filelist_dir_all:
+ ./bin/spine-dmd -v --source --html --epub --sqlite-discrete \
+ --sqlite-create --sqlite-update \
+ --output-dir=tmp/program_output_dir \
+ $(SiSU_MARKUP_SAMPLES_DIR)
+
+gdc_testrun_find_dir_source:
+ ./bin/spine-gdc -v --source \
+ --output-dir=tmp/program_output_dir \
+ $(SiSU_MARKUP_SAMPLES_DIR)
+
+gdc_testrun_find_dir_pod:
+ $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \
+ ./bin/spine-gdc -v --pod \
+ --output-dir=tmp/program_output_dir
+
+gdc_testrun_find_dir_html:
+ $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \
+ ./bin/spine-gdc -v --html \
+ --output-dir=tmp/program_output_dir
+
+gdc_testrun_find_dir_epub:
+ $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \
+ ./bin/spine-gdc -v --epub \
+ --output-dir=tmp/program_output_dir
+
+gdc_testrun_find_dir_all:
+ $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \
+ ./bin/spine-gdc -v --source --html --epub --sqlite-discrete \
+ --sqlite-create --sqlite-update \
+ --output-dir=tmp/program_output_dir
+
+gdc_testrun_filelist_dir_source:
+ ./bin/spine-gdc -v --source \
+ --output-dir=tmp/program_output_dir \
+ $(SiSU_MARKUP_SAMPLES_DIR)
+
+gdc_testrun_filelist_dir_pod:
+ ./bin/spine-gdc -v --pod \
+ --output-dir=tmp/program_output_dir \
+ $(SiSU_MARKUP_SAMPLES_DIR)
+
+gdc_testrun_filelist_dir_html:
+ ./bin/spine-gdc -v --html \
+ --output-dir=tmp/program_output_dir \
+ $(SiSU_MARKUP_SAMPLES_DIR)
+
+gdc_testrun_filelist_dir_epub:
+ ./bin/spine-gdc -v --epub \
+ --output-dir=tmp/program_output_dir \
+ $(SiSU_MARKUP_SAMPLES_DIR)
+
+gdc_testrun_filelist_dir_all:
+ ./bin/spine-gdc -v --source --html --epub --sqlite-discrete \
+ --sqlite-create --sqlite-update \
+ --output-dir=tmp/program_output_dir \
+ $(SiSU_MARKUP_SAMPLES_DIR)
+
+ldc_testrun_find_dir_source:
+ $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \
+ ./bin/spine-ldc -v --source \
+ --output-dir=tmp/program_output_dir
+
+ldc_testrun_find_dir_pod:
+ $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \
+ ./bin/spine-ldc -v --pod \
+ --output-dir=tmp/program_output_dir
+
+ldc_testrun_find_dir_html:
+ $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \
+ ./bin/spine-ldc -v --html \
+ --output-dir=tmp/program_output_dir
+
+ldc_testrun_find_dir_epub:
+ $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \
+ ./bin/spine-ldc -v --epub \
+ --output-dir=tmp/program_output_dir
+
+ldc_testrun_find_dir_all:
+ $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \
+ ./bin/spine-ldc -v --source --html --epub --sqlite-discrete \
+ --sqlite-create --sqlite-update \
+ --output-dir=tmp/program_output_dir
+
+ldc_testrun_filelist_dir_source:
+ ./bin/spine-ldc -v --source \
+ --output-dir=tmp/program_output_dir \
+ $(SiSU_MARKUP_SAMPLES_DIR)
+
+ldc_testrun_filelist_dir_pod:
+ ./bin/spine-ldc -v --pod \
+ --output-dir=tmp/program_output_dir \
+ $(SiSU_MARKUP_SAMPLES_DIR)
+
+ldc_testrun_filelist_dir_html:
+ ./bin/spine-ldc -v --html \
+ --output-dir=tmp/program_output_dir \
+ $(SiSU_MARKUP_SAMPLES_DIR)
+
+ldc_testrun_filelist_dir_epub:
+ ./bin/spine-ldc -v --epub \
+ --output-dir=tmp/program_output_dir \
+ $(SiSU_MARKUP_SAMPLES_DIR)
+
+ldc_testrun_filelist_dir_all:
+ ./bin/spine-ldc -v --source --html --epub --sqlite-discrete \
+ --sqlite-create --sqlite-update \
+ --output-dir=tmp/program_output_dir \
+ $(SiSU_MARKUP_SAMPLES_DIR)
+
+tangle: skel
+ for f in $(ORGFILELIST); do \
+ ORGFILES="$$ORGFILES \"$$f\""; \
+ done; \
+ emacs --batch -Q -q \
+ --eval "(progn \
+ (add-to-list 'load-path \
+ (expand-file-name \"$(EMACSLISP)\")) \
+ (add-to-list 'load-path \
+ (expand-file-name \"$(EMACSLISP_ORG)\" t)) \
+ (add-to-list 'load-path \
+ (expand-file-name \"$(EMACSLISP_ORG_CONTRIB)\" t)) \
+ (require 'org)(require 'ob)(require 'ob-tangle) \
+ (mapc (lambda (file) \
+ (find-file (expand-file-name file \"$(ORGDIR)\")) \
+ (setq-local org-src-preserve-indentation t) \
+ (org-babel-tangle) \
+ (kill-buffer)) '($$ORGFILES)))" 2>&1
+
+tangle_maker:
+ for f in $(ORGFILELIST); do \
+ ORGFILES="\"org/dr_build_scaffold.org\""; \
+ done; \
+ emacs --batch -Q -q \
+ --eval "(progn \
+ (add-to-list 'load-path \
+ (expand-file-name \"$(EMACSLISP)\")) \
+ (add-to-list 'load-path \
+ (expand-file-name \"$(EMACSLISP_ORG)\" t)) \
+ (add-to-list 'load-path \
+ (expand-file-name \"$(EMACSLISP_ORG_CONTRIB)\" t)) \
+ (require 'org)(require 'ob)(require 'ob-tangle) \
+ (mapc (lambda (file) \
+ (find-file (expand-file-name file \".\")) \
+ (setq-local org-src-preserve-indentation t) \
+ (org-babel-tangle) \
+ (kill-buffer)) '($$ORGFILES)))" 2>&1
+
+lorri_shell:
+ lorri shell
+
+# nix-shell
+nix-shell:
+ nix-shell -I .envrc
+
+nix-shell-pure:
+ nix-shell -I .envrc --pure
+
+# nix-shell (with local tools, presumably latest dlang compiler & build tools (ldc & dub))
+nix-shell-updated:
+ nix-shell -I nixpkgs=/nixpkgs-ra/nixpkgs --pure
+
+# shell.nix (with shebang)
+shell:
+ shell.nix
+
+# nix-build spine
+nix-build:
+ nix-build default.nix && ./result/bin/spine -v
+
+# nix-build spine (with local tools, presumably latest dlang compiler & build tools (ldc & dub))
+nix-build-use-tools-new:
+ nix-build -I .envrc
+
+# tangle-build
+tangle-build: org-tangle nix-build
+
+# build-run
+build-run: nix-build output-samples
+
+# tangle-build-run
+tangle-build-run: org-tangle nix-build output-samples
+
+# nix-build spine search
+nix-build-search:
+ cd ./sundry/spine_search_cgi; \
+ nix-build \
+ cd -
+
+_flake-lock-reset:
+ git reset HEAD flake.lock
+
+_flake-show-name:
+ nix search --json 2>/dev/null |jq;
+
+_flake-show-package:
+ nix flake show;
+
+_flake-show-derivation:
+ nix show-derivation |jq;
+
+nix-develop:
+ nix develop -f default.nix -I nixpkgs=/nixpkgs-ra/nixpkgs
+
+# nix flake show
+flake-show: _flake-show-package _flake-show-name _flake-show-derivation
+
+# nix-build flake spine
+flake-build: _flake-show-name
+ nix build --print-build-logs
+
+# nix-build flake spine
+flake-reset-build: _flake-lock-reset _flake-show-name
+ nix build --print-build-logs
+
+# nix-build flake spine debug
+flake-build-debug:
+ nix build --debug
+
+# nix-build spine (with local tools, presumably latest dlang compiler & build tools (ldc & dub))
+flake-build-use-tools-new:
+ nix build --print-build-logs -I nixpkgs=/nixpkgs-ra/nixpkgs
+
+# tangle-build-flake
+flake-tangle-build: org-tangle flake-build
+
+# build-flake-run
+flake-build-run: flake-build output-samples
+
+# tangle-build-run
+flake-tangle-build-run: org-tangle flake-build output-samples
+
+# nix-build spine search
+flake-build-search:
+ cd ./sundry/spine_search_cgi; \
+ nix build --print-build-logs \
+ cd -
+
+gitsnapshot: distclean tangle
+ git commit -a
+
+.PHONY : all build rebuild debug release \
+ distclean init \
+ tangle gitsnapshot