summary refs log tree commit diff
path: root/pkgs/misc
diff options
context:
space:
mode:
authorAnderson Torres <torres.anderson.85@protonmail.com>2021-01-28 20:10:38 -0300
committerGitHub <noreply@github.com>2021-01-28 20:10:38 -0300
commit2520b036d12240cfaa2244dbc466b749f472ea17 (patch)
treeb8504adec5fcef25710b4b4cd5d11e62831fdfab /pkgs/misc
parente29bef4b9c817f21276e7b3ed0d3a34f64fdbc78 (diff)
parentc20c774ce0f33670fbabac47ffcb028baafde3fc (diff)
downloadnixpkgs-2520b036d12240cfaa2244dbc466b749f472ea17.tar
nixpkgs-2520b036d12240cfaa2244dbc466b749f472ea17.tar.gz
nixpkgs-2520b036d12240cfaa2244dbc466b749f472ea17.tar.bz2
nixpkgs-2520b036d12240cfaa2244dbc466b749f472ea17.tar.lz
nixpkgs-2520b036d12240cfaa2244dbc466b749f472ea17.tar.xz
nixpkgs-2520b036d12240cfaa2244dbc466b749f472ea17.tar.zst
nixpkgs-2520b036d12240cfaa2244dbc466b749f472ea17.zip
Merge pull request #111000 from AndersonTorres/new-commander-x16
Commander X16 emulator
Diffstat (limited to 'pkgs/misc')
-rw-r--r--pkgs/misc/emulators/commander-x16/emulator.nix42
-rw-r--r--pkgs/misc/emulators/commander-x16/rom.nix46
2 files changed, 88 insertions, 0 deletions
diff --git a/pkgs/misc/emulators/commander-x16/emulator.nix b/pkgs/misc/emulators/commander-x16/emulator.nix
new file mode 100644
index 00000000000..73442215ff1
--- /dev/null
+++ b/pkgs/misc/emulators/commander-x16/emulator.nix
@@ -0,0 +1,42 @@
+{ stdenv
+, lib
+, fetchFromGitHub
+, SDL2
+}:
+
+stdenv.mkDerivation rec {
+  pname = "x16-emulator";
+  version = "38";
+
+  src = fetchFromGitHub {
+    owner = "commanderx16";
+    repo = pname;
+    rev = "r${version}";
+    sha256 = "WNRq/m97NpOBWIk6mtxBAKmkxCGWacWjXeOvIhBrkYE=";
+  };
+
+  dontConfigure = true;
+
+  buildInputs = [ SDL2 ];
+
+  installPhase = ''
+    runHook preInstall
+    install -D --mode 755 --target-directory $out/bin/ x16emu
+    install -D --mode 444 --target-directory $out/share/doc/${pname} README.md
+    runHook postInstall
+  '';
+
+  meta = with lib; {
+    homepage = "https://www.commanderx16.com/forum/index.php?/home/";
+    description = "The official emulator of CommanderX16 8-bit computer";
+    license = licenses.bsd2;
+    maintainers = with maintainers; [ AndersonTorres ];
+    platforms = SDL2.meta.platforms;
+  };
+
+  passthru = {
+    # upstream project recommends emulator and rom synchronized;
+    # passing through the version is useful to ensure this
+    inherit version;
+  };
+}
diff --git a/pkgs/misc/emulators/commander-x16/rom.nix b/pkgs/misc/emulators/commander-x16/rom.nix
new file mode 100644
index 00000000000..5da77ebceef
--- /dev/null
+++ b/pkgs/misc/emulators/commander-x16/rom.nix
@@ -0,0 +1,46 @@
+{ stdenv
+, lib
+, fetchFromGitHub
+, cc65
+}:
+
+stdenv.mkDerivation rec {
+  pname = "x16-rom";
+  version = "38";
+
+  src = fetchFromGitHub {
+    owner = "commanderx16";
+    repo = pname;
+    rev = "r${version}";
+    sha256 = "xaqF0ppB7I7ST8Uh3jPbC14uRAb/WH21tHlNeTvYpoI=";
+  };
+
+  nativeBuildInputs = [ cc65 ];
+
+  postPatch = ''
+    patchShebangs scripts/
+  '';
+
+  dontConfigure = true;
+
+  installPhase = ''
+    runHook preInstall
+    install -D --mode 444 --target-directory $out/share/${pname} build/x16/rom.bin
+    install -D --mode 444 --target-directory $out/share/doc/${pname} README.md
+    runHook postInstall
+  '';
+
+  meta = with lib; {
+    homepage = "https://www.commanderx16.com/forum/index.php?/home/";
+    description = "ROM file for CommanderX16 8-bit computer";
+    license = licenses.bsd2;
+    maintainers = with maintainers; [ AndersonTorres ];
+    platforms = cc65.meta.platforms;
+  };
+
+  passthru = {
+    # upstream project recommends emulator and rom synchronized;
+    # passing through the version is useful to ensure this
+    inherit version;
+  };
+}