Compare commits

..

46 Commits

Author SHA1 Message Date
Connor Olding 6b91f1ae1c meta: remove completed TODO 2022-10-25 20:56:24 -07:00
Connor Olding 47c18a97d5 muon: update version 2022-10-25 19:42:16 -07:00
Connor Olding 74ddf3ee4f kuroko: update version 2022-10-25 19:42:10 -07:00
Connor Olding 11c9578382 bootstrap: update version 2022-10-25 19:42:03 -07:00
Connor Olding 882cb4e80f meta: update installer for new image names 2022-10-25 19:39:52 -07:00
Connor Olding b2f2f13943 all: work around shed not detecting a match 2022-10-25 19:39:28 -07:00
Connor Olding 16ce669c8e use an unambiguous URL for pulling alpine 2022-10-20 12:59:10 -07:00
Connor Olding 1c0dffa857 all: only patch the portion of the ftruncate test that's failing 2022-10-20 12:59:07 -07:00
Connor Olding 4b9b114c89 all: skip more tests 2022-10-19 12:29:27 -07:00
Connor Olding f4f6bc7b84 bootstrap: update version and remove make.com workaround 2022-10-19 12:26:50 -07:00
Connor Olding e09790470e all: properly use the right cosmopolitan libraries 2022-10-18 20:37:27 -07:00
Connor Olding 53bcb46c1c all: don't use cache, save some space 2022-10-18 19:02:19 -07:00
Connor Olding 46feeb23c8 all: skip ftruncate test 2022-10-18 15:03:07 -07:00
Connor Olding d4fcaadc65 meta: check for a file since git leaves behind empty directories 2022-10-18 13:55:24 -07:00
Connor Olding ad9aa9fa70 yices: rewrite comment 2022-10-18 13:47:18 -07:00
Connor Olding efd9608d42 bootstrap: update version 2022-10-18 13:42:12 -07:00
Connor Olding 6147d6a35a perl: workaround strange segfault 2022-10-18 13:42:12 -07:00
Connor Olding 45bdb84af5 yices: don't strip symbols, also reduce build noise 2022-10-18 13:42:12 -07:00
Connor Olding 956e96725a meta: allow passing of flavors by arguments 2022-10-18 13:42:12 -07:00
Connor Olding b5e9017414 meta: superficial whitespace 2022-10-18 13:42:12 -07:00
Connor Olding 9e316d777b meta: remove absurdism (integrated into my local script) 2022-10-18 13:42:11 -07:00
Connor Olding 9c800550d0 meta: prevent asking how to disambiguate a failed build 2022-10-18 13:41:58 -07:00
Connor Olding 97c27ffa16 perl: update version 2022-10-18 13:38:46 -07:00
Connor Olding 9cdf8f9435 muon: update version 2022-10-15 15:51:51 -07:00
Connor Olding d6998f3dcc all: remove object files when make depend fails, as a fallback 2022-10-15 09:43:04 -07:00
Connor Olding c22a02e219 bootstrap: update version 2022-10-15 02:01:46 -07:00
Connor Olding 84695887cf meta: fix auto-update 2022-10-15 02:00:50 -07:00
Connor Olding ec422d6dcd meta: build a couple local things 2022-10-15 01:40:56 -07:00
Connor Olding 174778e8af meta: update readme 2022-10-15 01:39:55 -07:00
Connor Olding d4ee9c0853 meta: add absurdism script for layered insanity 2022-10-15 01:39:55 -07:00
Connor Olding 54f99c91d9 all: add another skipped test 2022-10-15 01:39:55 -07:00
Connor Olding a32a28d7c2 add 'simple' containers and distribute way more programs 2022-10-15 01:39:55 -07:00
Connor Olding 76456e8ea2 kuroko, muon, perl, yices: use rescue container 2022-10-15 01:28:37 -07:00
Connor Olding e4af8b909f add rescue container to simplify runners 2022-10-15 01:24:20 -07:00
Connor Olding a9a883a5b4 split building into phases (superficial) 2022-10-15 01:22:35 -07:00
Connor Olding 019a09689f meta: superficial changes 2022-10-15 01:15:13 -07:00
Connor Olding d44528a346 defer building assimilate, awk, sed, and unbourne to cosmo-all 2022-10-15 01:12:58 -07:00
Connor Olding 5cb78a7eb8 add cosmo-all to make all 2022-10-15 01:02:02 -07:00
Connor Olding 3256db8386 base: split into base and dist
this will make more sense later!
2022-10-15 00:44:43 -07:00
Connor Olding 324c6cabe7 bootstrap: add optional rebuild feature (COSMO_REBUILD=1) 2022-10-15 00:32:45 -07:00
Connor Olding f9d7c4398d bootstrap, base: only copy the necessary utilities 2022-10-15 00:32:00 -07:00
Connor Olding 6d8247bd0e bootstrap: superficial changes 2022-10-15 00:30:32 -07:00
Connor Olding 3dfea15904 meta: add noisy messages to build script 2022-10-15 00:24:06 -07:00
Connor Olding 67ec821336 meta: reduce repetition in build script 2022-10-15 00:21:48 -07:00
Connor Olding 78c1cda400 cosmo: split into cosmo-bootstrap and cosmo-base 2022-10-15 00:21:43 -07:00
Connor Olding 0fa24ccc22 perl: superficial changes 2022-10-14 23:19:57 -07:00
17 changed files with 76 additions and 75 deletions

View File

@ -13,7 +13,7 @@ polyfilling missing features across platforms,
but pre-existing software may take a lot of
patching before becoming fully functional.
## procedures
## containers
in order of dependence, then alphabetical order.
@ -26,11 +26,6 @@ in order of dependence, then alphabetical order.
### Phase 2
<!--
the base cosmopolitan library and binaries,
with some minor patches and a custom distrib.
-->
* **cosmo-bootstrap:** builds the basic libraries (i.e.
cosmopolitan libc) and binaries to bootstrap itself
and build other software against.
@ -61,7 +56,7 @@ with some minor patches and a custom distrib.
* **cosmo-base:** used to build other containers in phase 5.
* **cosmo-chibicc:** chibicc (not sure which commit this is forked from)
* **cosmo-chibicc:** chibicc (TODO: version?)
with many extensions.
* **cosmo-lua:** Actually Portable Lua
@ -74,7 +69,7 @@ with some minor patches and a custom distrib.
* **cosmo-sed:** Actually Portable sed (fork of NetBSD sed)
* **cosmo-sqlite:** sqlite3 (3350500) binaries and libraries.
* **cosmo-sqlite:** sqlite3 (3350500)
* **fold:** (TODO)

View File

@ -14,7 +14,6 @@ remove elements from this list as you see fit.
* for source being built
* for exposed containers
* for `install-cosmo` (kinda a subset of the previous point)
* cosmo: allow non-default builds (`rel`, `dbg`, etc.)
* kuroko: test more vigorously
* do tests pass on a Windows host?
* kuroko: use cosmopolitan readline functionality instead of built-in?

View File

@ -1,8 +0,0 @@
#!/usr/bin/env sh
: \
&& [ -s build-all ] \
&& { [ -d out ] || mkdir out || exit ;} \
&& podman run -v="$(readlink -f .)":/stargazing -e="TERM=$TERM" -it --rm \
--privileged --user root quay.io/podman/stable /stargazing/build-all \
|| { e=$?; echo absurdism died; exit $e ;} \
;

View File

@ -13,7 +13,7 @@ latest() { : \
any=0 flags="-L --no-progress-meter" n="$(printf '\n.')" n="${n%.}" \
df=Dockerfile gh='https://github.com/' sr='https://git.sr.ht/~' \
&& set -- \
cosmo COSMO_COMMIT ${gh}jart/cosmopolitan \
cosmo-bootstrap COSMO_COMMIT ${gh}jart/cosmopolitan \
cosmo-kuroko KUROKO_COMMIT ${gh}kuroko-lang/kuroko \
cosmo-muon MUON_COMMIT ${sr}lattis/muon \
cosmo-perl PERL_COMMIT ${gh}G4Vi/perl5/tree/cosmo \

View File

@ -13,7 +13,7 @@ yes_retrieve() { : \
;do announce retrieving "$f" \
&& g="out/${f##*/}" && { ! [ -e "$g" ] || mv "$g" "$g~" ;} || return \
;done \
&& podman run -v="$out":/out --rm --entrypoint /bin/busybox "$image" \
&& podman run -v="$out":/out --rm --entrypoint /bin/busybox "localhost/$image" \
cp -- "$@" "/out/" \
&& for f in "$@" \
;do if g="out/${f##*/}" && [ -e "$g" ] \
@ -34,7 +34,7 @@ dbg_retrieve() { : \
build() { : \
&& local t="${1?missing argument}" && shift \
&& announce building "$t" \
&& podman build -t "$t" "$t" "$@" \
&& podman build -t "$t" "./$t" "$@" \
;}
build_simple() { : \
@ -46,45 +46,40 @@ build_simple() { : \
;done \
;}
prep() { : \
&& [ "$(whoami)" != podman ] \
|| { : \
&& [ ! -s ~/.config/containers/storage.conf ] \
&& { [ -d ~/.config ] || mkdir ~/.config ;} \
&& { [ -d ~/.config/containers ] || mkdir ~/.config/containers ;} \
&& { [ -d ~/junk ] || mkdir ~/junk ;} \
&& printf '%s\n' >~/.config/containers/storage.conf \
'[storage]' 'driver = "overlay"' 'runroot = "$HOME/junk"' \
'graphroot = "$HOME/junk"' 'rootless_storage_path = "$HOME/junk"' \
'[storage.options]' 'additionalimagestores = [' ']' \
'[storage.options.overlay]' 'mountopt = "nodev"' \
'[storage.options.thinpool]' \
;} \
build_base() { : \
&& sed 's/\bcosmo-bootstrap\b/cosmo-all/g' \
<cosmo-dist/Dockerfile >cosmo-dist/all.Dockerfile \
&& build cosmo-dist -f cosmo-dist/all.Dockerfile \
&& build cosmo-base \
;}
: \
&& me="$(readlink -f "$0")" && cd "${me%/*}" && { [ -d out ] || mkdir out ;} \
&& prep \
&& : \
\
`# phase 1` \
&& build notwa-util \
\
`# phase 2` \
&& build cosmo-bootstrap \
&& build cosmo-bootstrap --build-arg=COSMO_FLAVOR="${1:-def}" \
\
`# phase 3` \
&& build cosmo-all \
&& build cosmo-all --build-arg=COSMO_FLAVOR="${2:-def}" \
&& build cosmo-dist \
&& build rescue \
\
`# phase 4` \
&& build cosmo-base \
&& build_base \
&& build_simple \
\
`# phase 5` \
&& build cosmo-kuroko \
&& build cosmo-muon \
&& build cosmo-perl \
&& build cosmo-yices \
\
`# other stuff` \
&& { [ ! -e cosmo-mini ] || build cosmo-mini ;} \
&& { [ ! -e cosmo-python311 ] || build cosmo-python311 ;} \
&& { [ ! -s cosmo-mini/Dockerfile ] || build cosmo-mini ;} \
\
&& yes_retrieve cosmo-base /cosmopolitan/bin/ape \
&& dbg_retrieve cosmo-kuroko /bin/kuroko.com \

View File

@ -15,10 +15,13 @@ RUN : \
commit "$commit" \
flavor "$COSMO_FLAVOR" \
mode "$mode" \
COSMO "$PWD" \
COSMO_DIST "$PWD/dist/$COSMO_FLAVOR" \
\
&& shed expand "s_o='o/[^']*'_o='o/$mode' _g" \
;
RUN --mount=type=cache,id=cosmo-build-all,target=/cosmopolitan/o,sharing=locked \
--mount=type=tmpfs,target=/tmp : \
RUN --mount=type=tmpfs,target=/tmp : \
&& . ./env \
&& if [ -e o.old ] \
;then : \
@ -26,15 +29,19 @@ RUN --mount=type=cache,id=cosmo-build-all,target=/cosmopolitan/o,sharing=locked
&& rm -r o.old \
;fi \
\
# skip some checks that are currently failing: \
&& skip() { mkdir -p "${1%/*}" && touch -d @2222222222 "$1" ;} \
# skip some checks that fail under podman: \
&& skip "o/$mode/test/libc/calls/getgroups_test.com.runs" \
&& skip "o/$mode/test/libc/calls/getpriority_test.com.runs" \
# these can fail in nested podman: \
# these can fail when nesting podman: \
&& shed test/libc/calls/ftruncate_test.c '/\.st_blocks/d' \
&& skip "o/$mode/test/libc/stdio/tmpfile_test.com.runs" \
&& skip "o/$mode/test/tool/net/lunix_test.lua.runs" \
&& skip "o/$mode/third_party/python/Lib/test/test_selectors.py.runs" \
# FIXME: SIGSEGV: \
&& skip "o/$mode/third_party/python/Lib/test/test_ioctl.py.runs" \
\
&& { ./makeit MODE="$mode" depend || find o -name '*.o' -delete ;} \
&& ./makeit MODE="$mode" all \
\
# install the binaries somewhere so we can retrieve them without mounting cache: \
@ -42,4 +49,6 @@ RUN --mount=type=cache,id=cosmo-build-all,target=/cosmopolitan/o,sharing=locked
'!' -name '*_test.*' '!' -name 'test_*' -exec \
install -m0755 -t /usr/local/bin {} \
+ \
# save some space: \
&& find o -type f '(' -name '*.com.dbg' -o -name '*_test.*' -o -name 'test_*' ')' -delete \
;

View File

@ -1,4 +1,4 @@
FROM cosmo-dist AS runner
COPY --chmod=0755 --from=localhost/cosmo-assimilate /bin/assimilate.com /cosmopolitan/bin/
COPY --chmod=0755 --from=localhost/cosmo-awk /bin/awk.com /cosmopolitan/bin/
COPY --chmod=0755 --from=localhost/cosmo-sed /bin/sed.com /cosmopolitan/bin/
FROM cosmo-dist
COPY --chmod=0755 --from=localhost/cosmo-all /usr/local/bin/assimilate.com /cosmopolitan/bin/
COPY --chmod=0755 --from=localhost/cosmo-all /usr/local/bin/awk.com /cosmopolitan/bin/
COPY --chmod=0755 --from=localhost/cosmo-all /usr/local/bin/sed.com /cosmopolitan/bin/

View File

@ -1,8 +1,8 @@
# MAIN: https://justine.lol/cosmopolitan/
# REPO: https://github.com/jart/cosmopolitan
ARG COSMO_FLAVOR=def
ARG COSMO_COMMIT=f52f65b2e351085250b743a5319dab418f2d48be
ARG COSMO_SHA256=8a13f4be3d689b8895af6e1178d455db2f82a69e33ce5848e2f2f14f96760d4c
ARG COSMO_COMMIT=ef9776755ee3646029624fe30de5d58a3c03f6f6
ARG COSMO_SHA256=f5efa2daf12f0536a4d57b4da5f7402398bb93ae2d5e602c2401b3a6227af1c4
ARG COSMO_REBUILD=0
FROM localhost/notwa-util AS downloader
@ -12,7 +12,7 @@ RUN --mount=type=cache,id=common,target=/media/common,sharing=locked \
&& acquire from=github repo=jart/cosmopolitan dest=/cosmopolitan env=COSMO \
;
FROM alpine:3.16 AS builder
FROM docker.io/library/alpine:3.16 AS builder
ARG COSMO_FLAVOR COSMO_COMMIT
COPY --from=downloader /cosmopolitan /cosmopolitan
WORKDIR /cosmopolitan
@ -20,7 +20,6 @@ WORKDIR /cosmopolitan
# tell makefiles to be less noisy, also use /tmp:
ENV V=0 COLUMNS=80 TMPDIR=/tmp
COPY --chmod=0755 make.com build/bootstrap/make.com
COPY --chmod=0755 --from=localhost/notwa-util /nu/shed /usr/bin/
RUN : \
# allow optimized builds to be more portable, so the container is too. \

Binary file not shown.

View File

@ -49,7 +49,7 @@ RUN --mount=type=tmpfs,target=/tmp : \
&& cp /cosmopolitan/env /distrib/env \
;
FROM alpine:3.16 AS runner
FROM docker.io/library/alpine:3.16 AS runner
COPY --from=distrib /distrib /cosmopolitan
ENV PATH="/cosmopolitan/bin:/cosmopolitan/gcc/bin/:/cosmopolitan/gcc/x86_64-linux-musl/bin/:$PATH"
# FIXME:

View File

@ -3,8 +3,8 @@
# TODO: add /zip/ support by default and include dist modules.
FROM localhost/notwa-util AS downloader
ARG KUROKO_COMMIT=3f35d89fff2343ddb9f0de5c87bbdefa86ee34f5
ARG KUROKO_SHA256=b1d38c48afdc06633d848dc27cb5d37bebbb7c99c59d3649c155350f06cd93a7
ARG KUROKO_COMMIT=f4b40b1b7015c0d421edb508144b4a22b2321d46
ARG KUROKO_SHA256=d72e1b3bb7400d7c2e47dd97120b64890998c90ccb13cb3f7cd16429a584f41c
RUN --mount=type=cache,id=common,target=/media/common,sharing=locked \
--mount=type=tmpfs,target=/tmp : \
@ -123,9 +123,7 @@ RUN : \
;
RUN make.com test
FROM scratch AS runner
COPY --chmod=0755 --from=localhost/notwa-util /nu/busybox /bin/busybox
COPY --chmod=0755 --from=builder /cosmopolitan/bin/ape /bin/ape
FROM localhost/rescue AS runner
COPY --chmod=0755 --from=builder /kuroko/kuroko.com /kuroko/kuroko.com.dbg /bin/
COPY --from=builder /kuroko.patch /var/local/kuroko.patch
ENTRYPOINT ["/bin/ape", "/bin/kuroko.com"]

View File

@ -1,8 +1,8 @@
# MAIN: https://muon.build/
# REPO: https://git.sr.ht/~lattis/muon
FROM localhost/notwa-util AS downloader
ARG MUON_COMMIT=ab1e044c93c9c87e496ff7c4028ddf4218b91445
ARG MUON_SHA256=006425edf914444b87108ee062c9f56ee57804a2726f757c44c329f213465182
ARG MUON_COMMIT=cdb84257b50ebdeddd1ea696fe433e4a3316c8a9
ARG MUON_SHA256=c8104d857ccaea09ddb6e9a83c73b4a061550c1257f7673c904a137d8a716f04
RUN --mount=type=cache,id=common,target=/media/common,sharing=locked \
--mount=type=tmpfs,target=/tmp : \
&& acquire from=sourcehut repo=lattis/muon dest=/muon env=MUON \
@ -45,8 +45,6 @@ RUN : \
&& objcopy -S -O binary muon.com.dbg muon.com \
;
FROM scratch AS runner
COPY --chmod=0755 --from=localhost/notwa-util /nu/busybox /bin/busybox
COPY --chmod=0755 --from=builder /cosmopolitan/bin/ape /bin/ape
FROM localhost/rescue AS runner
COPY --chmod=0755 --from=builder /muon/build/muon.com /muon/build/muon.com.dbg /bin/
ENTRYPOINT ["/bin/ape", "/bin/muon.com"]

View File

@ -3,8 +3,8 @@ FROM localhost/notwa-util AS downloader
# MAIN: https://www.perl.org/
# REPO: https://github.com/Perl/perl5
# FORK: https://github.com/G4Vi/perl5/tree/cosmo
ARG PERL_COMMIT=66baebd8320a90ddf2c90de14b83f7eee4f6b143
ARG PERL_SHA256=0e6731efb5f25589116340b4e861abd43fb47520669fe903569b1489339dcddb
ARG PERL_COMMIT=2fb034ffb02db2b3ac09706c954704930c620c0b
ARG PERL_SHA256=03bf2d1eefb8610e1ad5594ddf7cc5eb5aa11c25f499f3233ecaa3088d55579a
# MAIN: https://computoid.com/APPerl/
# REPO: https://github.com/G4Vi/Perl-Dist-APPerl
@ -91,6 +91,13 @@ RUN make -j2
RUN make -j2 minitest devtty=/dev/zero | tee minitest_results.txt
# temporary workaround for segfault. oddly enough,
# it's not a segfault in the zip executable! alas, \
RUN : \
&& rm /usr/bin/zip \
&& apk add --no-cache zip \
;
RUN : \
&& mkdir /perl/cosmo \
&& mkdir /perl/cosmo/o \
@ -129,9 +136,7 @@ RUN : \
&& mv ../perl.com ../../perl.com \
;
FROM scratch AS runner
COPY --chmod=0755 --from=localhost/notwa-util /nu/busybox /bin/busybox
COPY --chmod=0755 --from=builder /cosmopolitan/bin/ape /bin/ape
FROM localhost/rescue AS runner
COPY --chmod=0755 --from=builder /perl/cosmo/o/perl.com /bin/perl.com
COPY --chmod=0755 --from=builder /perl/perl.elf /bin/perl.com.dbg
COPY --from=builder /perl/minitest_results.txt /minitest_results.txt

View File

@ -60,6 +60,13 @@ RUN : \
COPY --from=downloader /gmp /gmp
WORKDIR /gmp
RUN : \
# don't build this crap; our printf is fine. \
# (i suppose the missing symbols could cause linking errors further \
# down the line, but this does not seem to be an issue for yices.) \
&& rm -r printf \
&& shed configure 's_ printf/Makefile _ _g' '/printf\/Makefile/d' \
&& shed Makefile.in 's_ printf _ _g' 's/$(PRINTF_OBJECTS) //g' \
\
&& CC=cosmocc CFLAGS="-O2 -g" \
# specify some generic old CPU for best compatibility/reproduciblity. \
# core2 introduced SSSE3, which cosmopolitan depends on, so use that: \
@ -85,6 +92,10 @@ RUN : \
&& shed src/utils/timeout.c '/#include <unistd.h>/i\\#include <time.h>' \
# the static-lib target attempts to build a dynamic library. don't do that. \
&& shed src/Makefile 's/ $(static_libyices_dynamic)//g' \
# don't strip binaries; we'll do it ourselves later. \
&& shed src/Makefile '/^\t$(STRIP)/d' \
# silence this irrelevant error. \
&& shed src/Makefile '/\*\.dll/d' \
\
&& autoconf \
&& CC=cosmocc \
@ -110,9 +121,7 @@ RUN : \
&& objcopy -S -O binary "kissat.com.dbg" "kissat.com" \
;
FROM scratch AS runner
COPY --chmod=0755 --from=localhost/notwa-util /nu/busybox /bin/busybox
COPY --chmod=0755 --from=builder /cosmopolitan/bin/ape /bin/ape
FROM localhost/rescue AS runner
COPY --from=builder /yices/config.cache /yices/config.log /yices/config.status /var/local/
COPY --from=builder /yices/dist/bin /bin
COPY --chmod=0755 --from=builder /kissat/build/kissat.com /kissat/build/kissat.com.dbg /bin/

View File

@ -24,7 +24,7 @@
&& { [ -w . ] || "$super" chown root:wheel . ;} \
&& { [ -w . ] || "$super" chmod 0775 . ;} \
&& now="$(date -u +%s)" \
&& podman run -v="$out":/out --rm localhost/cosmo \
&& podman run -v="$out":/out --rm localhost/cosmo-dist \
tar zcf "/out/cosmopolitan-$now.tar.gz" /cosmopolitan \
&& if [ -L cosmopolitan ] \
;then : \

View File

@ -1,6 +1,6 @@
# MAIN: https://eaguru.guru/git/notwa/stargazing
# REPO: https://eaguru.guru/git/notwa/stargazing
FROM alpine:3.16 as partial
FROM docker.io/library/alpine:3.16 as partial
# need this for acquire (.tar.xz files):
RUN apk add --no-cache xz
COPY --chmod=0755 acquire cosmocc dedupe ofc quickconf shed \
@ -23,7 +23,7 @@ RUN --mount=type=cache,id=common,target=/media/common,sharing=locked \
&& acquire \
;
FROM alpine:3.16 as builder
FROM docker.io/library/alpine:3.16 as builder
RUN apk add --no-cache gcc linux-headers make musl-dev
# configure and build a rescue shell and some utilities,
# i.e. one better suited for images built "FROM scratch".

View File

@ -1,6 +1,8 @@
#!/usr/bin/env sh
cosmo="${COSMO:-"/cosmopolitan"}"
dist="${COSMO_DIST:-"$cosmo/dist/def"}"
unset flavor
[ ! -s "$cosmo/env" ] || . "$cosmo/env"
dist="${COSMO_DIST:-"$cosmo/dist/${flavor:-def}"}"
_CFLAGS="-fno-omit-frame-pointer -fdata-sections -ffunction-sections -fno-pie -pg -mnop-mcount -mno-tls-direct-seg-refs"
_CPPFLAGS="-DNDEBUG -nostdinc -iquote $cosmo -isystem $cosmo/libc/isystem -include $cosmo/libc/integral/normalize.inc"