mirror of
https://github.com/autc04/Retro68.git
synced 2024-06-19 19:29:54 +00:00
Compare commits
4 Commits
9d542ac1c2
...
4ff2d7d902
Author | SHA1 | Date | |
---|---|---|---|
|
4ff2d7d902 | ||
|
9facdaf3c1 | ||
|
e187bd21c2 | ||
|
e43fee2701 |
|
@ -1,12 +1,12 @@
|
|||
# vim:ft=dockerfile
|
||||
|
||||
# Base image
|
||||
FROM ubuntu:20.04 AS base
|
||||
FROM ubuntu:22.04 AS base
|
||||
|
||||
RUN apt-get update && \
|
||||
DEBIAN_FRONTEND=noninteractive apt-get install -y \
|
||||
cmake libgmp-dev libmpfr-dev libmpc-dev \
|
||||
libboost-all-dev bison texinfo \
|
||||
libboost-all-dev bison texinfo bzip2 \
|
||||
ruby flex curl g++ git macutils
|
||||
|
||||
# Add toolchain to default PATH
|
||||
|
|
|
@ -75,6 +75,19 @@ static void writeMacBinary(std::ostream& out, std::string filename,
|
|||
|
||||
const std::string& rsrcBytes = resstream.str();
|
||||
|
||||
// MacBinary files contain mandatory timestamps (creation date and modification date)
|
||||
// We set both of them, but to make reproducible builds possible, this optionally
|
||||
// takes the time from the $SOURCE_DATE_EPOCH environment variable instead of the system clock.
|
||||
// When building under `nix`, this is automatically set to the modification date of the newest source
|
||||
// file.
|
||||
auto timestamp = std::invoke([&] -> std::chrono::system_clock::time_point {
|
||||
const char *sourceDateEpochEnvVar = getenv("SOURCE_DATE_EPOCH");
|
||||
if (sourceDateEpochEnvVar && *sourceDateEpochEnvVar)
|
||||
return std::chrono::system_clock::from_time_t((time_t)std::atoll(sourceDateEpochEnvVar));
|
||||
else
|
||||
return std::chrono::system_clock::now();
|
||||
});
|
||||
|
||||
// Calculate Mac-style timestamp (seconds since 1 January 1904 00:00:00)
|
||||
std::tm mac_epoch_tm = {
|
||||
0, 0, 0, // 00:00:00
|
||||
|
|
23
flake.nix
23
flake.nix
|
@ -10,6 +10,9 @@
|
|||
|
||||
outputs = inputs@{ flake-parts, nixpkgs, multiversal, ... }:
|
||||
flake-parts.lib.mkFlake { inherit inputs; } ({ self, lib, retroPlatforms, ... }: {
|
||||
imports = [
|
||||
./nix/standalone.nix
|
||||
];
|
||||
_module.args.lib = import (nixpkgs + "/lib");
|
||||
_module.args.retroPlatforms = import ./nix/platforms.nix;
|
||||
|
||||
|
@ -55,26 +58,6 @@
|
|||
tools = pkgs.retro68.tools;
|
||||
hfsutils = pkgs.retro68.hfsutils;
|
||||
|
||||
default = pkgs.runCommand "Retro68" { } ''
|
||||
mkdir $out
|
||||
mkdir $out/m68k-apple-macos
|
||||
mkdir $out/powerpc-apple-macos
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${self'.legacyPackages.pkgsCross.m68k.retro68.libretro}/. $out/m68k-apple-macos
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${self'.legacyPackages.pkgsCross.m68k.retro68.multiversal}/. $out/m68k-apple-macos
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${self'.legacyPackages.pkgsCross.powerpc.retro68.libretro}/. $out/powerpc-apple-macos
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${self'.legacyPackages.pkgsCross.powerpc.retro68.multiversal}/. $out/powerpc-apple-macos
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${self'.legacyPackages.pkgsCross.carbon.retro68.libretro}/. $out/powerpc-apple-macos
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${self'.legacyPackages.pkgsCross.carbon.retro68.multiversal}/. $out/powerpc-apple-macos
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${pkgs.retro68.tools}/. $out
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${pkgs.retro68.hfsutils}/. $out
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${pkgs.cmake}/. $out
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${pkgs.gnumake}/. $out
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${pkgs.ninja}/. $out
|
||||
|
||||
${pkgs.rsync}/bin/rsync -a ${self'.legacyPackages.pkgsCross.m68k.buildPackages.retro68.gcc_unwrapped}/. $out
|
||||
${pkgs.rsync}/bin/rsync -a ${self'.legacyPackages.pkgsCross.powerpc.buildPackages.retro68.gcc_unwrapped}/. $out
|
||||
${pkgs.rsync}/bin/rsync -a ${self'.legacyPackages.pkgsCross.carbon.buildPackages.retro68.gcc_unwrapped}/. $out
|
||||
'';
|
||||
|
||||
samples = pkgs.linkFarm "Retro68-Samples" [
|
||||
{ name = "m68k"; path = self'.legacyPackages.pkgsCross.m68k.retro68.samples; }
|
||||
|
|
36
nix/standalone.nix
Normal file
36
nix/standalone.nix
Normal file
|
@ -0,0 +1,36 @@
|
|||
# flake part to add a 'standalone' build of retro68 for all archs,
|
||||
# i.e. a build that does not rely on nixpkgs's wrapper setup.
|
||||
# this might be what should be put into a docker image.
|
||||
|
||||
# Warning: does not yet work.
|
||||
|
||||
{ ... }: {
|
||||
perSystem = { self', pkgs, ... }: {
|
||||
packages.standalone = pkgs.runCommand "Retro68" { } ''
|
||||
mkdir -p $out/m68k-apple-macos/cmake
|
||||
mkdir -p $out/powerpc-apple-macos/cmake
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${self'.legacyPackages.pkgsCross.m68k.retro68.libretro}/. $out/m68k-apple-macos
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${self'.legacyPackages.pkgsCross.m68k.retro68.multiversal}/. $out/m68k-apple-macos
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${self'.legacyPackages.pkgsCross.powerpc.retro68.libretro}/. $out/powerpc-apple-macos
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${self'.legacyPackages.pkgsCross.powerpc.retro68.multiversal}/. $out/powerpc-apple-macos
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${self'.legacyPackages.pkgsCross.carbon.retro68.libretro}/. $out/powerpc-apple-macos
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${self'.legacyPackages.pkgsCross.carbon.retro68.multiversal}/. $out/powerpc-apple-macos
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${pkgs.retro68.tools}/. $out
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${pkgs.retro68.hfsutils}/. $out
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${pkgs.cmake}/. $out
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${pkgs.gnumake}/. $out
|
||||
${pkgs.xorg.lndir}/bin/lndir -silent ${pkgs.ninja}/. $out
|
||||
|
||||
${pkgs.rsync}/bin/rsync -a ${self'.legacyPackages.pkgsCross.m68k.buildPackages.retro68.gcc_unwrapped}/. $out
|
||||
${pkgs.rsync}/bin/rsync -a ${self'.legacyPackages.pkgsCross.powerpc.buildPackages.retro68.gcc_unwrapped}/. $out
|
||||
${pkgs.rsync}/bin/rsync -a ${self'.legacyPackages.pkgsCross.carbon.buildPackages.retro68.gcc_unwrapped}/. $out
|
||||
|
||||
substitute ${../cmake/retro68.toolchain.cmake.in} $out/m68k-apple-macos/cmake/retro68.toolchain.cmake --subst-var-by RETRO68_ROOT $out
|
||||
substitute ${../cmake/retroppc.toolchain.cmake.in} $out/powerpc-apple-macos/cmake/retroppc.toolchain.cmake --subst-var-by RETRO68_ROOT $out
|
||||
substitute ${../cmake/retrocarbon.toolchain.cmake.in} $out/powerpc-apple-macos/cmake/retrocarbon.toolchain.cmake --subst-var-by RETRO68_ROOT $out
|
||||
cp ${../cmake/add_application.cmake} $out/m68k-apple-macos/cmake/add_application.cmake
|
||||
cp -r ${../cmake/Platform} $out/m68k-apple-macos/cmake/Platform
|
||||
cp -r ${../cmake/Platform} $out/powerpc-apple-macos/cmake/Platform
|
||||
'';
|
||||
};
|
||||
}
|
Loading…
Reference in New Issue
Block a user