patches and low-level development discussion
 help / color / mirror / code / Atom feed
blob 1166e2153eb8fde48558affb2a59198a0f0ea917 1742 bytes (raw)
name: lib/erofs.mk 	 # note: path name is non-authoritative(*)

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
 
# SPDX-License-Identifier: EUPL-1.2+
# SPDX-FileCopyrightText: 2021-2024 Alyssa Ross <hi@alyssa.is>
# SPDX-FileCopyrightText: 2022 Unikie
# SPDX-FileCopyrightText: 2025 Demi Marie Obenour <demiobenour@gmail.com>

include $(basedir)/lib/common.mk
include file-list.mk
BUILD_FILES += build/etc/s6-rc
dest = build/rootfs.erofs

all:
.PHONY: all
$(dest): $(basedir)/scripts/make-erofs.sh $(PACKAGES_FILE) $(FILES) $(BUILD_FILES) build/empty build/fifo file-list.mk
	set -euo pipefail; ( \
	    cat $(PACKAGES_FILE);\
	    for file in $(FILES) $(LINKS); do printf '%s\n%s\n' "$$file" "$${file#image/}"; done;\
	    for file in $(BUILD_FILES); do printf '%s\n%s\n' "$$file" "$${file#build/}"; done;\
	    for dir in $(DIRS); do printf 'build/empty\n%s\n' "$$dir"; done;\
	    for fifo in $(FIFOS); do printf 'build/fifo\n%s\n' "$$fifo"; done;\
	) | $(basedir)/scripts/make-erofs.sh $@

clean:
	-chmod -Rf +w build
	rm -rf build
.PHONY: clean
	false

build/fifo:
	mkdir -p build
	mkfifo -m 0600 $@

build/empty:
	mkdir -p $@

# s6-rc-compile's input is a directory, but that doesn't play nice
# with Make, because it won't know to update if some file in the
# directory is changed, or a file is created or removed in a
# subdirectory.  Using the whole source directory could also end up
# including files that aren't intended to be part of the input, like
# temporary editor files or .license files.  So for all these reasons,
# only explicitly listed files are made available to s6-rc-compile.
build/etc/s6-rc: $(S6_RC_FILES) file-list.mk
	mkdir -p build/etc
	rm -rf $@
	set -euo pipefail; \
	dir=$$(mktemp -d); \
	{ tar -c $(S6_RC_FILES) | tar -C "$$dir" -x --strip-components 3;}; \
	s6-rc-compile $@ $$dir; \
	exit=$$?; rm -r $$dir; exit $$exit

debug log:

solving 1166e2153eb8fde48558affb2a59198a0f0ea917 ...
found 1166e2153eb8fde48558affb2a59198a0f0ea917 in https://inbox.spectrum-os.org/spectrum-devel/20250910-genfiles-v2-3-37ebe07a3cdc@gmail.com/

applying [1/1] https://inbox.spectrum-os.org/spectrum-devel/20250910-genfiles-v2-3-37ebe07a3cdc@gmail.com/
diff --git a/lib/erofs.mk b/lib/erofs.mk
new file mode 100644
index 0000000000000000000000000000000000000000..1166e2153eb8fde48558affb2a59198a0f0ea917

Checking patch lib/erofs.mk...
Applied patch lib/erofs.mk cleanly.

index at:
100644 1166e2153eb8fde48558affb2a59198a0f0ea917	lib/erofs.mk

(*) Git path names are given by the tree(s) the blob belongs to.
    Blobs themselves have no identifier aside from the hash of its contents.^

Code repositories for project(s) associated with this public inbox

	https://spectrum-os.org/git/crosvm
	https://spectrum-os.org/git/doc
	https://spectrum-os.org/git/mktuntap
	https://spectrum-os.org/git/nixpkgs
	https://spectrum-os.org/git/spectrum
	https://spectrum-os.org/git/ucspi-vsock
	https://spectrum-os.org/git/www

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).