From 66fe431416ec2406645b3ff358ebe0f96b97fffe Mon Sep 17 00:00:00 2001 From: Neil McPhail Date: Mon, 22 Sep 2025 16:50:52 +0100 Subject: [PATCH] First numbered release --- .devcontainer/Dockerfile | 11 ++++++----- .devcontainer/devcontainer.json | 2 +- README.md | 30 ++++++++++++++++++------------ 3 files changed, 25 insertions(+), 18 deletions(-) diff --git a/.devcontainer/Dockerfile b/.devcontainer/Dockerfile index c99ff94..3e63ff9 100644 --- a/.devcontainer/Dockerfile +++ b/.devcontainer/Dockerfile @@ -24,10 +24,11 @@ RUN cd /inpaws/ \ && make -j8 RUN python3 -m pip install --break-system-packages skoolkit -FROM build AS z88dk +FROM ubuntu:24.04 AS z88dk RUN apt-get update \ && apt-get install -y --no-install-recommends \ bison \ + build-essential \ ca-certificates \ ccache \ cpanminus \ @@ -50,6 +51,7 @@ RUN apt-get update \ libxml2-dev \ libyaml-perl \ m4 \ + make \ perl \ pkg-config \ ragel \ @@ -60,12 +62,11 @@ RUN apt-get update \ && rm -rf /var/lib/apt/lists/* ENV Z88DK_PATH="/opt/z88dk" RUN cpanm -l $HOME/perl5 --no-wget local::lib Template::Plugin::YAML \ - && git clone --depth 1 --recursive https://github.com/z88dk/z88dk.git ${Z88DK_PATH} \ + && git clone --depth 1 --branch v2.3 --recursive https://github.com/z88dk/z88dk.git ${Z88DK_PATH} \ && cd ${Z88DK_PATH} \ && eval "$(perl -I$HOME/perl5/lib/perl5 -Mlocal::lib)" \ && chmod 777 build.sh \ - && sed -i -e "s/make/make -j8/g" build.sh \ - && BUILD_SDCC=1 BUILD_SDCC_HTTP=1 ./build.sh \ + && BUILD_SDCC=1 BUILD_SDCC_HTTP=1 MAKE_CONCURRENCY=-j8 ./build.sh \ && make install-clean bins-clean FROM ubuntu:24.04 @@ -99,4 +100,4 @@ COPY --from=z88dk /opt/z88dk/lib /opt/z88dk/lib COPY --from=z88dk /opt/z88dk/include /opt/z88dk/include ENV PATH="${PATH}:/opt/z88dk/bin:/opt/zxbasic:/opt/zxbasic/tools" ENV ZCCCFG="/opt/z88dk/lib/config" -USER ubuntu \ No newline at end of file +USER ubuntu diff --git a/.devcontainer/devcontainer.json b/.devcontainer/devcontainer.json index be348c2..4ded02a 100644 --- a/.devcontainer/devcontainer.json +++ b/.devcontainer/devcontainer.json @@ -2,7 +2,7 @@ "name": "ZX Spectrum dev tools", //"build": { "dockerfile": "Dockerfile" }, // The Dockerfile takes an age to build due to z88dk, so pull from prebuilt: - "image": "boarstone.mcphail.uk/mcphail/speccydev:stable", + "image": "boarstone.mcphail.uk/mcphail/speccydev:v1.0", "remoteUser": "ubuntu", "runArgs": [ "--network=host" diff --git a/README.md b/README.md index 3b9804d..7486e87 100644 --- a/README.md +++ b/README.md @@ -1,15 +1,15 @@ -# Development tools for the ZX Spectrum +# Development tools for the ZX Spectrum v1.0 The Dockerfile is the basis of the devcontainer and can be changed to add or remove tools. It will take a long time to build locally, so by default the devcontainer will pull a prebuilt version. Edit `.devcontainer/devcontainer.json` if you would rather build your own. The devcontainer contains: -- pasmo (assembler) -- sjasmplus (assembler) -- z80asm (assembler) -- z80dasm (disassembler) -- zmakebas (creates BASIC programs) -- z88dk (C compiler and other utilities including assembler) -- utilities from the FUSE emulator: +- pasmo version 0.5.3 (assembler) +- sjasmplus version 1.21.0 (assembler) +- z80asm version 1.8 (assembler) +- z80dasm version 1.1.6 (disassembler) +- zmakebas version 1.2b (creates BASIC programs) +- z88dk version 2.3 (C compiler and other utilities including assembler) +- utilities from the FUSE emulator version 1.4.3: - audio2tape - createhdf - fmfconv @@ -29,14 +29,14 @@ The devcontainer contains: - tzxlist - zx0 (binary compressor) - dzx0 (binary decompressor) -- ZX BASIC (aka Boriel BASIC) +- ZX BASIC (aka Boriel BASIC) version 1.18.2 - zxbc (BASIC compiler) - zxbasm (assembler) - zxbpp (preprocessor) - various tools including nextcreator.py to build .nex files - ttttt (converts binaries into .tap blocks) -- inpaws (interactive fiction compiler/extractor for Gilsoft's PAW) -- skoolkit (tools for creating browseable disassemblies of Spectrum games) +- inpaws version 1.0.2 (interactive fiction compiler/extractor for Gilsoft's PAW) +- skoolkit version 9.6 (tools for creating browseable disassemblies of Spectrum games) - sna2ctl.py - sna2skool.py - skool2html.py @@ -83,6 +83,12 @@ Open the bottom bar in vscode to expose the terminal or select "Terminal -> New When you are ready to start your own project, run `make start_new_project` to wipe out the example code and start afresh. +## Versions + +This `main` branch of this repository will always point to the latest numbered release of the devcontainer image. This image will contain specific, numbered releases of the various tools as documented above. If the devcontainer is updated with non-breaking changes, the minor version number will be incremented. This gives reassurance that, say, a v1.7 devcontainer will contain tools which can compile programs made with a v1.2 devcontainer without issue. + +If there is a breaking change in the tools, the major version number will be incremented. So a v2.0 devcontainer may not build projects made in a v1.7 devcontainer correctly. Please ensure all your collaborators are using appropriate devcontainer versions. + ## Debugging Debug in the built in simulator or in CSpect externally (example CSpect invocation on Windows would be `CSpect.exe -w2 -debug -remote`). The simulator is set up to expect a binary called `myprog.sna` and a map file called `myprog.sld` but this can be configured in the `.vscode/launch.json` file. @@ -113,4 +119,4 @@ ttttt - placed under Public Domain by Neil McPhail inpaws - copyright "Mastodon" and released under GPL v3 -skoolkit - copyright Richard Dymond and Philip M Anderson and released under GPL v3 or later \ No newline at end of file +skoolkit - copyright Richard Dymond and Philip M Anderson and released under GPL v3 or later