From 3f0ff0a2090d84e52a2a1c594136fc24db6a647f Mon Sep 17 00:00:00 2001 From: EuAndreh Date: Thu, 3 Apr 2025 11:02:10 -0300 Subject: Setup project skeleotn --- Makefile | 88 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ deps.mk | 3 +++ mkdeps.sh | 7 +++++ src/adoc | 0 4 files changed, 98 insertions(+) create mode 100644 Makefile create mode 100644 deps.mk create mode 100755 mkdeps.sh create mode 100755 src/adoc diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..016ff05 --- /dev/null +++ b/Makefile @@ -0,0 +1,88 @@ +.POSIX: +DATE = 1970-01-01 +VERSION = 0.1.0 +NAME = adoc +NAME_UC = $(NAME) +LANGUAGES = en +## Installation prefix. Defaults to "/usr". +PREFIX = /usr +BINDIR = $(PREFIX)/bin +LIBDIR = $(PREFIX)/lib +INCLUDEDIR = $(PREFIX)/include +SRCDIR = $(PREFIX)/src/$(NAME) +SHAREDIR = $(PREFIX)/share +LOCALEDIR = $(SHAREDIR)/locale +MANDIR = $(SHAREDIR)/man +EXEC = ./ +## Where to store the installation. Empty by default. +DESTDIR = +LDLIBS = + + + +.SUFFIXES: + + + +all: +include deps.mk + +sources = \ + $(sources.sh) \ + + +derived-assets = \ + +side-assets = \ + + + +## Default target. Builds all artifacts required for testing +## and installation. +all: $(derived-assets) + + + +check-unit: + + +check-integration: + + +## Run all tests. Each test suite is isolated, so that a parallel +## build can run tests at the same time. The required artifacts +## are created if missing. +check: check-unit check-integration + + + +## Remove *all* derived artifacts produced during the build. +## A dedicated test asserts that this is always true. +clean: + rm -rf $(derived-assets) $(side-assets) + + +## Installs into $(DESTDIR)$(PREFIX). Its dependency target +## ensures that all installable artifacts are crafted beforehand. +install: all + mkdir -p \ + '$(DESTDIR)$(BINDIR)' \ + '$(DESTDIR)$(SRCDIR)' \ + + cp $(sources.sh) '$(DESTDIR)$(BINDIR)' + cp $(sources) '$(DESTDIR)$(SRCDIR)' + + +## Uninstalls from $(DESTDIR)$(PREFIX). This is a perfect mirror +## of the "install" target, and removes *all* that was installed. +## A dedicated test asserts that this is always true. +uninstall: + rm -rf \ + '$(DESTDIR)$(SRCDIR)' \ + + for f in $(sources.sh); do \ + rm -f '$(DESTDIR)$(BINDIR)'/"$${f#src/}"; \ + done + + +ALWAYS: diff --git a/deps.mk b/deps.mk new file mode 100644 index 0000000..64d38be --- /dev/null +++ b/deps.mk @@ -0,0 +1,3 @@ +sources.sh = \ + src/adoc \ + diff --git a/mkdeps.sh b/mkdeps.sh new file mode 100755 index 0000000..72b2857 --- /dev/null +++ b/mkdeps.sh @@ -0,0 +1,7 @@ +#!/bin/sh +set -eu + +export LANG=POSIX.UTF-8 + + +find src/* -type f -perm -111 | varlist 'sources.sh' diff --git a/src/adoc b/src/adoc new file mode 100755 index 0000000..e69de29 -- cgit v1.2.3