From 338915b9ef3827762fcbfa3a1143db3e883c7917 Mon Sep 17 00:00:00 2001 From: Ralph Amissah Date: Mon, 19 Dec 2022 21:08:28 -0500 Subject: nix flake, mostly things nix --- makefile | 905 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 905 insertions(+) create mode 100644 makefile (limited to 'makefile') diff --git a/makefile b/makefile new file mode 100644 index 0000000..70e6929 --- /dev/null +++ b/makefile @@ -0,0 +1,905 @@ +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_DIR_FILES_FOUND = \ +# find data/sisudir/media/text -name *.ss[tm] | sort | xargs +# +Date := `date "+%Y%m%d"` +SpineBIN := "${SpineBIN}" # './result/bin' +SpineOUT := "${SpineOUT}" # '/srv/www/spine' +SpinePOD := "${SpinePOD}" # '~/grotto/repo/git.repo/projects/doc-reform/data/markup/spine-samples/markup/pod' +SpineSearchActionLocal := 'http://localhost/spine_search' +SpineSearchActionRemote := 'https://sisudoc.org/spine_search' +SpineCGIform := 'spine_search' +SpineSQLdb := 'spine.search.db' +hwd := `pwd` +gwd := `pwd` + "/src/ext_depends" +deps := "`ls -gx './src/ext_depends'`" +dirs_loc := "`ls -gx '.'`" +#dirs := "`ls -gx ${gwd}`" + +commands: + rg --color=always -B1 "^[a-z]\w+:" makefile | less + +cmd: + rg --color=always -B1 "^[a-z]\w+:" makefile | page + +# tangle org files +org-tangle: + cd ./org; \ + org-tangle *.org; \ + cd - + +# 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-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 > ./tarballGitHEAD/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 > ./tarballGitHEAD/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 > ./tarballGitHEAD/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" + +# remove test tarball dir +nixGitHEADtarballClean: + if [ -d "./tarballGitHEAD" ]; then \ + rm -rv ./tarballGitHEAD; \ + fi; + +## create test tarball +#nixGitHEADtarballTar: +# if [ ! -d "./tarballGitHEAD" ]; then \ +# mkdir ./tarballGitHEAD; \ +# fi; \ +# git archive -v --format=tar --prefix="spine-${PROG_VER_DECLARED}/" HEAD | \ +# gzip > ./tarballGitHEAD/spine-${PROG_VER_DECLARED}-tag-${PROG_VER_GIT}.tar.gz && \ +# cp -v ./tarballGitHEAD/spine-${PROG_VER_DECLARED}-tag-${PROG_VER_GIT}.tar.gz ./tarballGitHEAD/spine-${PROG_VER_DECLARED}.tar.gz && \ +# echo "to unzip: tar -xzf spine-${PROG_VER_DECLARED}-tag-${PROG_VER_GIT}.tar.gz"; \ +# echo "to unzip: tar -xzf spine-${PROG_VER_DECLARED}.tar.gz" +# +## check test tarball +#nixGitHEADtarballCheck: +# nix flake check file://${hwd}/tarballGitHEAD/spine-${PROG_VER_DECLARED}.tar.gz; \ +# nix flake lock file://${hwd}/tarballGitHEAD/spine-${PROG_VER_DECLARED}.tar.gz; \ +# nix flake show file://${hwd}/tarballGitHEAD/spine-${PROG_VER_DECLARED}.tar.gz; + +## build test tarball +#nixGitHEADtarballBuild: +# echo "nix build file://${hwd}/tarballGitHEAD/spine-${PROG_VER_DECLARED}.tar.gz#spine --print-build-logs" +# nix build file://${hwd}/tarballGitHEAD/spine-${PROG_VER_DECLARED}.tar.gz#spine --print-build-logs +# #nix build "./tarballGitHEAD/spine-${PROG_VER_DECLARED}.tar.gz#spine" --print-build-logs + +# clean create check & build test tarball +nixGitHEADtarball: nixGitHEADtarballClean nixGitHEADtarballTar nixGitHEADtarballCheck nixGitHEADtarballBuild + +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 lock && \ + 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) + +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 + +testrun_find_pod_source: + $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \ + ./bin/spine-ldc -v --source \ + --output-dir=tmp/program_output_pod + +testrun_find_pod_pod: + $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \ + ./bin/spine-ldc -v --pod \ + --output-dir=tmp/program_output_pod + +testrun_find_pod_html: + $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \ + ./bin/spine-ldc -v --html \ + --output-dir=tmp/program_output_pod + +testrun_find_pod_epub: + $(SiSU_MARKUP_SAMPLES_PODS_FOUND) \ + ./bin/spine-ldc -v --epub \ + --output-dir=tmp/program_output_pod + +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 + +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 + +testrun_paths_pod_source: + ./bin/spine-ldc -v --source \ + --output-dir=tmp/program_output_pod \ + ./markup/pod/* + +testrun_paths_pod_pod: + ./bin/spine-ldc -v --pod \ + --output-dir=tmp/program_output_pod \ + ./markup/pod/* + +testrun_paths_pod_html: + ./bin/spine-ldc -v --html \ + --output-dir=tmp/program_output_pod \ + ./markup/pod/* + +testrun_paths_pod_epub: + ./bin/spine-ldc -v --epub \ + --output-dir=tmp/program_output_pod \ + ./markup/pod/* + +testrun_paths_pod_all: + ./bin/spine-ldc -v --source --html --epub --sqlite-discrete \ + --sqlite-create --sqlite-update \ + --output-dir=tmp/program_output_pod \ + ./markup/pod/* + +testrun_find_dir_source: + $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \ + ./bin/spine-ldc -v --source \ + --output-dir=tmp/program_output_dir + +testrun_find_dir_pod: + $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \ + ./bin/spine-ldc -v --pod \ + --output-dir=tmp/program_output_dir + +testrun_find_dir_html: + $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \ + ./bin/spine-ldc -v --html \ + --output-dir=tmp/program_output_dir + +testrun_find_dir_epub: + $(SiSU_MARKUP_SAMPLES_DIR_FILES_FOUND) \ + ./bin/spine-ldc -v --epub \ + --output-dir=tmp/program_output_dir + +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 + +testrun_filelist_dir_source: + ./bin/spine-ldc -v --source \ + --output-dir=tmp/program_output_dir \ + $(SiSU_MARKUP_SAMPLES_DIR) + +testrun_filelist_dir_pod: + ./bin/spine-ldc -v --pod \ + --output-dir=tmp/program_output_dir \ + $(SiSU_MARKUP_SAMPLES_DIR) + +testrun_filelist_dir_html: + ./bin/spine-ldc -v --html \ + --output-dir=tmp/program_output_dir \ + $(SiSU_MARKUP_SAMPLES_DIR) + +testrun_filelist_dir_epub: + ./bin/spine-ldc -v --epub \ + --output-dir=tmp/program_output_dir \ + $(SiSU_MARKUP_SAMPLES_DIR) + +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 -- cgit v1.2.3