From de3850fb1b7af62d4ab0516801e2ffd11fcfcc83 Mon Sep 17 00:00:00 2001 From: m3tm3re
Date: Tue, 20 Jan 2026 18:32:28 +0100
Subject: [PATCH] feat: replace local opencode with upstream flake input
v1.1.27
- Add `opencode` flake input pinned to v1.1.27 for stability
- Remove local `pkgs/opencode` derivation and overlay
- Add `opencode` and `opencode-desktop` to `pkgs/default.nix` from input
---
flake.lock | 38 +++-
flake.nix | 7 +-
overlays/mods/default.nix | 1 -
overlays/mods/opencode.nix | 16 --
pkgs/default.nix | 7 +-
pkgs/opencode/default.nix | 222 --------------------
pkgs/opencode/relax-bun-version-check.patch | 28 ---
7 files changed, 46 insertions(+), 273 deletions(-)
delete mode 100644 overlays/mods/opencode.nix
delete mode 100644 pkgs/opencode/default.nix
delete mode 100644 pkgs/opencode/relax-bun-version-check.patch
diff --git a/flake.lock b/flake.lock
index 2972d8a..1558215 100644
--- a/flake.lock
+++ b/flake.lock
@@ -16,9 +16,45 @@
"type": "github"
}
},
+ "nixpkgs_2": {
+ "locked": {
+ "lastModified": 1768569498,
+ "narHash": "sha256-bB6Nt99Cj8Nu5nIUq0GLmpiErIT5KFshMQJGMZwgqUo=",
+ "owner": "NixOS",
+ "repo": "nixpkgs",
+ "rev": "be5afa0fcb31f0a96bf9ecba05a516c66fcd8114",
+ "type": "github"
+ },
+ "original": {
+ "owner": "NixOS",
+ "ref": "nixpkgs-unstable",
+ "repo": "nixpkgs",
+ "type": "github"
+ }
+ },
+ "opencode": {
+ "inputs": {
+ "nixpkgs": "nixpkgs_2"
+ },
+ "locked": {
+ "lastModified": 1768911228,
+ "narHash": "sha256-iJ4WLNyP9i8baxp1FJJLv2VBD3XcE8nCruwO3GmSmK4=",
+ "owner": "anomalyco",
+ "repo": "opencode",
+ "rev": "e521fee0023a604bb6d5ef39b4b892cbf1a0f9d4",
+ "type": "github"
+ },
+ "original": {
+ "owner": "anomalyco",
+ "ref": "v1.1.27",
+ "repo": "opencode",
+ "type": "github"
+ }
+ },
"root": {
"inputs": {
- "nixpkgs": "nixpkgs"
+ "nixpkgs": "nixpkgs",
+ "opencode": "opencode"
}
}
},
diff --git a/flake.nix b/flake.nix
index 6715129..cd88c11 100644
--- a/flake.nix
+++ b/flake.nix
@@ -3,6 +3,7 @@
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
+ opencode.url = "github:anomalyco/opencode/v1.1.27";
# Optional: Add stable channel if needed
# nixpkgs-stable.url = "github:NixOS/nixpkgs/nixos-24.05";
@@ -36,18 +37,18 @@
system: let
pkgs = pkgsFor system;
in
- import ./pkgs {inherit pkgs;}
+ import ./pkgs {inherit pkgs inputs;}
);
# Overlays - can be imported in your system configuration
overlays = {
# Default overlay: adds all custom packages
default = final: prev:
- import ./pkgs {pkgs = final;};
+ import ./pkgs {pkgs = final; inputs = inputs;};
# Individual overlays for more granular control
additions = final: prev:
- import ./pkgs {pkgs = final;};
+ import ./pkgs {pkgs = final; inputs = inputs;};
modifications = final: prev:
import ./overlays/mods {inherit prev;};
diff --git a/overlays/mods/default.nix b/overlays/mods/default.nix
index 5314b83..e5aca72 100644
--- a/overlays/mods/default.nix
+++ b/overlays/mods/default.nix
@@ -3,7 +3,6 @@
# This overlay contains package overrides and modifications
# n8n = import ./n8n.nix {inherit prev;};
- # opencode = import ./opencode.nix {inherit prev;};
# beads = import ./beads.nix {inherit prev;};
# Add more modifications here as needed
diff --git a/overlays/mods/opencode.nix b/overlays/mods/opencode.nix
deleted file mode 100644
index 241f63a..0000000
--- a/overlays/mods/opencode.nix
+++ /dev/null
@@ -1,16 +0,0 @@
-{prev}:
-prev.opencode.overrideAttrs (oldAttrs: rec {
- version = "1.1.18";
-
- src = prev.fetchFromGitHub {
- owner = "anomalyco";
- repo = "opencode";
- tag = "v${version}";
- hash = "sha256-3A4s0FpjZuGB0HGMQVBXfWq+0yHmeIvnEQTSX3amV4I=";
- };
-
- node_modules = oldAttrs.node_modules.overrideAttrs (old: {
- inherit version src;
- outputHash = "sha256-zSco4ORQQOqV3vMPuP+M/q/hBa+MJGnTKIlxgngMA3g=";
- });
-})
diff --git a/pkgs/default.nix b/pkgs/default.nix
index d6a729e..fc5db33 100644
--- a/pkgs/default.nix
+++ b/pkgs/default.nix
@@ -1,4 +1,4 @@
-{pkgs, ...}: {
+{pkgs, inputs ? null, ...}: {
# Custom packages registry
# Each package is defined in its own directory under pkgs/
beads = pkgs.callPackage ./beads {};
@@ -8,10 +8,13 @@
mem0 = pkgs.callPackage ./mem0 {};
msty-studio = pkgs.callPackage ./msty-studio {};
n8n = pkgs.callPackage ./n8n {};
- opencode = pkgs.callPackage ./opencode {};
pomodoro-timer = pkgs.callPackage ./pomodoro-timer {};
rofi-project-opener = pkgs.callPackage ./rofi-project-opener {};
stt-ptt = pkgs.callPackage ./stt-ptt {};
tuxedo-backlight = pkgs.callPackage ./tuxedo-backlight {};
zellij-ps = pkgs.callPackage ./zellij-ps {};
+
+ # Imported from flake inputs
+ opencode = inputs.opencode.packages.${pkgs.system}.opencode;
+ opencode-desktop = inputs.opencode.packages.${pkgs.system}.desktop;
}
diff --git a/pkgs/opencode/default.nix b/pkgs/opencode/default.nix
deleted file mode 100644
index af2ffce..0000000
--- a/pkgs/opencode/default.nix
+++ /dev/null
@@ -1,222 +0,0 @@
-{
- lib,
- stdenvNoCC,
- bun,
- fetchFromGitHub,
- fzf,
- makeBinaryWrapper,
- models-dev,
- nix-update-script,
- ripgrep,
- testers,
- installShellFiles,
- writableTmpDirAsHomeHook,
-}: let
- pname = "opencode";
- version = "1.1.25";
- src = fetchFromGitHub {
- owner = "anomalyco";
- repo = "opencode";
- tag = "v${version}";
- hash = "sha256-aF+4LL0x9wU2Ktrv/nJE2VXgUeXFrwJ16pa1sGNhpi4=";
- };
-
- node_modules = stdenvNoCC.mkDerivation {
- pname = "${pname}-node_modules";
- inherit version src;
-
- impureEnvVars =
- lib.fetchers.proxyImpureEnvVars
- ++ ["GIT_PROXY_COMMAND" "SOCKS_SERVER"];
-
- nativeBuildInputs = [bun writableTmpDirAsHomeHook];
-
- dontConfigure = true;
-
- buildPhase = ''
- runHook preBuild
-
- export BUN_INSTALL_CACHE_DIR=$(mktemp -d)
-
- bun install \
- --cpu="*" \
- --filter=./packages/opencode \
- --force \
- --frozen-lockfile \
- --ignore-scripts \
- --no-progress \
- --os="*" \
- --production
-
- bun run ./nix/scripts/canonicalize-node-modules.ts
- bun run ./nix/scripts/normalize-bun-binaries.ts
-
- runHook postBuild
- '';
-
- installPhase = ''
- runHook preInstall
-
- mkdir -p $out
- find . -type d -name node_modules -exec cp -R --parents {} $out \;
-
- runHook postInstall
- '';
-
- # NOTE: Required else we get errors that our fixed-output derivation references store paths
- dontFixup = true;
-
- outputHash = "sha256-qheQCN71VM3M35+j9XhaCdxQNo5ze8mV8sDFaX0WVWM=";
- outputHashAlgo = "sha256";
- outputHashMode = "recursive";
- };
-in
- stdenvNoCC.mkDerivation (finalAttrs: {
- inherit pname version src node_modules;
-
- nativeBuildInputs = [
- bun
- installShellFiles
- makeBinaryWrapper
- models-dev
- writableTmpDirAsHomeHook
- ];
-
- patches = [
- # NOTE: Relax Bun version check to be a warning instead of an error
- ./relax-bun-version-check.patch
- ];
-
- dontConfigure = true;
-
- env.MODELS_DEV_API_JSON = "${models-dev}/dist/_api.json";
- env.OPENCODE_VERSION = finalAttrs.version;
- env.OPENCODE_CHANNEL = "stable";
-
- buildPhase = ''
- runHook preBuild
-
- # Copy all node_modules including the .bun directory with actual packages
- cp -r ${finalAttrs.node_modules}/node_modules .
- cp -r ${finalAttrs.node_modules}/packages .
-
- (
- cd packages/opencode
-
- # Fix symlinks to workspace packages
- chmod -R u+w ./node_modules
- mkdir -p ./node_modules/@opencode-ai
- rm -f ./node_modules/@opencode-ai/{script,sdk,plugin}
- ln -s $(pwd)/../../packages/script ./node_modules/@opencode-ai/script
- ln -s $(pwd)/../../packages/sdk/js ./node_modules/@opencode-ai/sdk
- ln -s $(pwd)/../../packages/plugin ./node_modules/@opencode-ai/plugin
-
- # Use upstream bundle.ts for Nix-compatible bundling
- cp ../../nix/bundle.ts ./bundle.ts
- chmod +x ./bundle.ts
- bun run ./bundle.ts
- )
-
- runHook postBuild
- '';
-
- installPhase = ''
- runHook preInstall
-
- cd packages/opencode
- if [ ! -d dist ]; then
- echo "ERROR: dist directory missing after bundle step"
- exit 1
- fi
-
- mkdir -p $out/lib/opencode
- cp -r dist $out/lib/opencode/
- chmod -R u+w $out/lib/opencode/dist
-
- # Select bundled worker assets deterministically (sorted find output)
- worker_file=$(find "$out/lib/opencode/dist" -type f \( -path '*/tui/worker.*' -o -name 'worker.*' \) | sort | head -n1)
- parser_worker_file=$(find "$out/lib/opencode/dist" -type f -name 'parser.worker.*' | sort | head -n1)
- if [ -z "$worker_file" ]; then
- echo "ERROR: bundled worker not found"
- exit 1
- fi
-
- main_wasm=$(printf '%s\n' "$out"/lib/opencode/dist/tree-sitter-*.wasm | sort | head -n1)
- wasm_list=$(find "$out/lib/opencode/dist" -maxdepth 1 -name 'tree-sitter-*.wasm' -print)
- for patch_file in "$worker_file" "$parser_worker_file"; do
- [ -z "$patch_file" ] && continue
- [ ! -f "$patch_file" ] && continue
- if [ -n "$wasm_list" ] && grep -q 'tree-sitter' "$patch_file"; then
- # Rewrite wasm references to absolute store paths to avoid runtime resolve failures.
- bun --bun ../../nix/scripts/patch-wasm.ts "$patch_file" "$main_wasm" $wasm_list
- fi
- done
-
- mkdir -p $out/lib/opencode/node_modules
- cp -r ../../node_modules/.bun $out/lib/opencode/node_modules/
- mkdir -p $out/lib/opencode/node_modules/@opentui
-
- # Generate and install JSON schema
- mkdir -p $out/share/opencode
- HOME=$TMPDIR bun --bun script/schema.ts $out/share/opencode/schema.json
-
- mkdir -p $out/bin
- makeWrapper ${lib.getExe bun} $out/bin/opencode \
- --add-flags "run" \
- --add-flags "$out/lib/opencode/dist/src/index.js" \
- --prefix PATH : ${lib.makeBinPath [fzf ripgrep]} \
- --argv0 opencode
-
- runHook postInstall
- '';
-
- postInstall = ''
- # Add symlinks for platform-specific native modules
- pkgs=(
- $out/lib/opencode/node_modules/.bun/@opentui+core-*
- $out/lib/opencode/node_modules/.bun/@opentui+solid-*
- $out/lib/opencode/node_modules/.bun/@opentui+core@*
- $out/lib/opencode/node_modules/.bun/@opentui+solid@*
- )
- for pkg in "''${pkgs[@]}"; do
- if [ -d "$pkg" ]; then
- pkgName=$(basename "$pkg" | sed 's/@opentui+\([^@]*\)@.*/\1/')
- ln -sf ../.bun/$(basename "$pkg")/node_modules/@opentui/$pkgName \
- $out/lib/opencode/node_modules/@opentui/$pkgName
- fi
- done
-
- ${lib.optionalString
- ((stdenvNoCC.buildPlatform.canExecute stdenvNoCC.hostPlatform)
- && (stdenvNoCC.hostPlatform.system != "x86_64-darwin")) ''
- installShellCompletion --cmd opencode \
- --bash <($out/bin/opencode completion)
- ''}
- '';
-
- passthru = {
- jsonschema = "${placeholder "out"}/share/opencode/schema.json";
- tests.version = testers.testVersion {
- package = finalAttrs.finalPackage;
- command = "HOME=$(mktemp -d) opencode --version";
- inherit (finalAttrs) version;
- };
- updateScript =
- nix-update-script {extraArgs = ["--subpackage" "node_modules"];};
- };
-
- meta = {
- description = "AI coding agent built for the terminal";
- longDescription = ''
- OpenCode is a terminal-based agent that can build anything.
- It combines a TypeScript/JavaScript core with a Go-based TUI
- to provide an interactive AI coding experience.
- '';
- homepage = "https://github.com/anomalyco/opencode";
- license = lib.licenses.mit;
- maintainers = with lib.maintainers; [delafthi];
- sourceProvenance = with lib.sourceTypes; [fromSource];
- platforms = ["aarch64-linux" "x86_64-linux" "aarch64-darwin" "x86_64-darwin"];
- mainProgram = "opencode";
- };
- })
diff --git a/pkgs/opencode/relax-bun-version-check.patch b/pkgs/opencode/relax-bun-version-check.patch
deleted file mode 100644
index 5d14f16..0000000
--- a/pkgs/opencode/relax-bun-version-check.patch
+++ /dev/null
@@ -1,28 +0,0 @@
-From 0e07ea8225f5667e39c6aa59eea726266f0afab0 Mon Sep 17 00:00:00 2001
-From: =?UTF-8?q?J=C3=B6rg=20Thalheim?=