summaryrefslogtreecommitdiffhomepage
path: root/install
diff options
context:
space:
mode:
authorDaniel Polito <[email protected]>2026-01-05 14:07:46 -0300
committerGitHub <[email protected]>2026-01-06 01:07:46 +0800
commit8e9a0c4ad014eb54d7ddd8de3b5f321de931f2f7 (patch)
tree6d999aaf07fe3382a6aac28c3c47a03648cdd0cd /install
parentced093e64641de9e4fb7ed100325c3ffe730cc5c (diff)
downloadopencode-8e9a0c4ad014eb54d7ddd8de3b5f321de931f2f7.tar.gz
opencode-8e9a0c4ad014eb54d7ddd8de3b5f321de931f2f7.zip
Desktop: Install CLI (#6526)
Co-authored-by: Brendan Allan <[email protected]>
Diffstat (limited to 'install')
-rwxr-xr-xinstall234
1 files changed, 132 insertions, 102 deletions
diff --git a/install b/install
index f995e2d43..3b9e6d68c 100755
--- a/install
+++ b/install
@@ -16,16 +16,19 @@ Usage: install.sh [options]
Options:
-h, --help Display this help message
-v, --version <version> Install a specific version (e.g., 1.0.180)
+ -b, --binary <path> Install from a local binary instead of downloading
--no-modify-path Don't modify shell config files (.zshrc, .bashrc, etc.)
Examples:
curl -fsSL https://opencode.ai/install | bash
curl -fsSL https://opencode.ai/install | bash -s -- --version 1.0.180
+ ./install --binary /path/to/opencode
EOF
}
requested_version=${VERSION:-}
no_modify_path=false
+binary_path=""
while [[ $# -gt 0 ]]; do
case "$1" in
@@ -42,6 +45,15 @@ while [[ $# -gt 0 ]]; do
exit 1
fi
;;
+ -b|--binary)
+ if [[ -n "${2:-}" ]]; then
+ binary_path="$2"
+ shift 2
+ else
+ echo -e "${RED}Error: --binary requires a path argument${NC}"
+ exit 1
+ fi
+ ;;
--no-modify-path)
no_modify_path=true
shift
@@ -53,119 +65,128 @@ while [[ $# -gt 0 ]]; do
esac
done
-raw_os=$(uname -s)
-os=$(echo "$raw_os" | tr '[:upper:]' '[:lower:]')
-case "$raw_os" in
- Darwin*) os="darwin" ;;
- Linux*) os="linux" ;;
- MINGW*|MSYS*|CYGWIN*) os="windows" ;;
-esac
-
-arch=$(uname -m)
-if [[ "$arch" == "aarch64" ]]; then
- arch="arm64"
-fi
-if [[ "$arch" == "x86_64" ]]; then
- arch="x64"
-fi
+INSTALL_DIR=$HOME/.opencode/bin
+mkdir -p "$INSTALL_DIR"
-if [ "$os" = "darwin" ] && [ "$arch" = "x64" ]; then
- rosetta_flag=$(sysctl -n sysctl.proc_translated 2>/dev/null || echo 0)
- if [ "$rosetta_flag" = "1" ]; then
- arch="arm64"
- fi
-fi
+# If --binary is provided, skip all download/detection logic
+if [ -n "$binary_path" ]; then
+ if [ ! -f "$binary_path" ]; then
+ echo -e "${RED}Error: Binary not found at ${binary_path}${NC}"
+ exit 1
+ fi
+ specific_version="local"
+else
+ raw_os=$(uname -s)
+ os=$(echo "$raw_os" | tr '[:upper:]' '[:lower:]')
+ case "$raw_os" in
+ Darwin*) os="darwin" ;;
+ Linux*) os="linux" ;;
+ MINGW*|MSYS*|CYGWIN*) os="windows" ;;
+ esac
-combo="$os-$arch"
-case "$combo" in
- linux-x64|linux-arm64|darwin-x64|darwin-arm64|windows-x64)
- ;;
- *)
- echo -e "${RED}Unsupported OS/Arch: $os/$arch${NC}"
- exit 1
- ;;
-esac
+ arch=$(uname -m)
+ if [[ "$arch" == "aarch64" ]]; then
+ arch="arm64"
+ fi
+ if [[ "$arch" == "x86_64" ]]; then
+ arch="x64"
+ fi
-archive_ext=".zip"
-if [ "$os" = "linux" ]; then
- archive_ext=".tar.gz"
-fi
+ if [ "$os" = "darwin" ] && [ "$arch" = "x64" ]; then
+ rosetta_flag=$(sysctl -n sysctl.proc_translated 2>/dev/null || echo 0)
+ if [ "$rosetta_flag" = "1" ]; then
+ arch="arm64"
+ fi
+ fi
-is_musl=false
-if [ "$os" = "linux" ]; then
- if [ -f /etc/alpine-release ]; then
- is_musl=true
- fi
+ combo="$os-$arch"
+ case "$combo" in
+ linux-x64|linux-arm64|darwin-x64|darwin-arm64|windows-x64)
+ ;;
+ *)
+ echo -e "${RED}Unsupported OS/Arch: $os/$arch${NC}"
+ exit 1
+ ;;
+ esac
- if command -v ldd >/dev/null 2>&1; then
- if ldd --version 2>&1 | grep -qi musl; then
- is_musl=true
+ archive_ext=".zip"
+ if [ "$os" = "linux" ]; then
+ archive_ext=".tar.gz"
fi
- fi
-fi
-needs_baseline=false
-if [ "$arch" = "x64" ]; then
- if [ "$os" = "linux" ]; then
- if ! grep -qi avx2 /proc/cpuinfo 2>/dev/null; then
- needs_baseline=true
- fi
- fi
+ is_musl=false
+ if [ "$os" = "linux" ]; then
+ if [ -f /etc/alpine-release ]; then
+ is_musl=true
+ fi
- if [ "$os" = "darwin" ]; then
- avx2=$(sysctl -n hw.optional.avx2_0 2>/dev/null || echo 0)
- if [ "$avx2" != "1" ]; then
- needs_baseline=true
+ if command -v ldd >/dev/null 2>&1; then
+ if ldd --version 2>&1 | grep -qi musl; then
+ is_musl=true
+ fi
+ fi
fi
- fi
-fi
-target="$os-$arch"
-if [ "$needs_baseline" = "true" ]; then
- target="$target-baseline"
-fi
-if [ "$is_musl" = "true" ]; then
- target="$target-musl"
-fi
-
-filename="$APP-$target$archive_ext"
+ needs_baseline=false
+ if [ "$arch" = "x64" ]; then
+ if [ "$os" = "linux" ]; then
+ if ! grep -qi avx2 /proc/cpuinfo 2>/dev/null; then
+ needs_baseline=true
+ fi
+ fi
+ if [ "$os" = "darwin" ]; then
+ avx2=$(sysctl -n hw.optional.avx2_0 2>/dev/null || echo 0)
+ if [ "$avx2" != "1" ]; then
+ needs_baseline=true
+ fi
+ fi
+ fi
-if [ "$os" = "linux" ]; then
- if ! command -v tar >/dev/null 2>&1; then
- echo -e "${RED}Error: 'tar' is required but not installed.${NC}"
- exit 1
+ target="$os-$arch"
+ if [ "$needs_baseline" = "true" ]; then
+ target="$target-baseline"
fi
-else
- if ! command -v unzip >/dev/null 2>&1; then
- echo -e "${RED}Error: 'unzip' is required but not installed.${NC}"
- exit 1
+ if [ "$is_musl" = "true" ]; then
+ target="$target-musl"
fi
-fi
-INSTALL_DIR=$HOME/.opencode/bin
-mkdir -p "$INSTALL_DIR"
+ filename="$APP-$target$archive_ext"
-if [ -z "$requested_version" ]; then
- url="https://github.com/anomalyco/opencode/releases/latest/download/$filename"
- specific_version=$(curl -s https://api.github.com/repos/anomalyco/opencode/releases/latest | sed -n 's/.*"tag_name": *"v\([^"]*\)".*/\1/p')
- if [[ $? -ne 0 || -z "$specific_version" ]]; then
- echo -e "${RED}Failed to fetch version information${NC}"
- exit 1
+ if [ "$os" = "linux" ]; then
+ if ! command -v tar >/dev/null 2>&1; then
+ echo -e "${RED}Error: 'tar' is required but not installed.${NC}"
+ exit 1
+ fi
+ else
+ if ! command -v unzip >/dev/null 2>&1; then
+ echo -e "${RED}Error: 'unzip' is required but not installed.${NC}"
+ exit 1
+ fi
fi
-else
- # Strip leading 'v' if present
- requested_version="${requested_version#v}"
- url="https://github.com/anomalyco/opencode/releases/download/v${requested_version}/$filename"
- specific_version=$requested_version
-
- # Verify the release exists before downloading
- http_status=$(curl -sI -o /dev/null -w "%{http_code}" "https://github.com/anomalyco/opencode/releases/tag/v${requested_version}")
- if [ "$http_status" = "404" ]; then
- echo -e "${RED}Error: Release v${requested_version} not found${NC}"
- echo -e "${MUTED}Available releases: https://github.com/anomalyco/opencode/releases${NC}"
- exit 1
+
+ if [ -z "$requested_version" ]; then
+ url="https://github.com/anomalyco/opencode/releases/latest/download/$filename"
+ specific_version=$(curl -s https://api.github.com/repos/anomalyco/opencode/releases/latest | sed -n 's/.*"tag_name": *"v\([^"]*\)".*/\1/p')
+
+ if [[ $? -ne 0 || -z "$specific_version" ]]; then
+ echo -e "${RED}Failed to fetch version information${NC}"
+ exit 1
+ fi
+ else
+ # Strip leading 'v' if present
+ requested_version="${requested_version#v}"
+ url="https://github.com/anomalyco/opencode/releases/download/v${requested_version}/$filename"
+ specific_version=$requested_version
+
+ # Verify the release exists before downloading
+ http_status=$(curl -sI -o /dev/null -w "%{http_code}" "https://github.com/anomalyco/opencode/releases/tag/v${requested_version}")
+ if [ "$http_status" = "404" ]; then
+ echo -e "${RED}Error: Release v${requested_version} not found${NC}"
+ echo -e "${MUTED}Available releases: https://github.com/anomalyco/opencode/releases${NC}"
+ exit 1
+ fi
fi
fi
@@ -267,11 +288,11 @@ download_with_progress() {
{
local length=0
local bytes=0
-
+
while IFS=" " read -r -a line; do
[ "${#line[@]}" -lt 2 ] && continue
local tag="${line[0]} ${line[1]}"
-
+
if [ "$tag" = "0000: content-length:" ]; then
length="${line[2]}"
length=$(echo "$length" | tr -d '\r')
@@ -296,7 +317,7 @@ download_and_install() {
print_message info "\n${MUTED}Installing ${NC}opencode ${MUTED}version: ${NC}$specific_version"
local tmp_dir="${TMPDIR:-/tmp}/opencode_install_$$"
mkdir -p "$tmp_dir"
-
+
if [[ "$os" == "windows" ]] || ! [ -t 2 ] || ! download_with_progress "$url" "$tmp_dir/$filename"; then
# Fallback to standard curl on Windows, non-TTY environments, or if custom progress fails
curl -# -L -o "$tmp_dir/$filename" "$url"
@@ -307,14 +328,24 @@ download_and_install() {
else
unzip -q "$tmp_dir/$filename" -d "$tmp_dir"
fi
-
+
mv "$tmp_dir/opencode" "$INSTALL_DIR"
chmod 755 "${INSTALL_DIR}/opencode"
rm -rf "$tmp_dir"
}
-check_version
-download_and_install
+install_from_binary() {
+ print_message info "\n${MUTED}Installing ${NC}opencode ${MUTED}from: ${NC}$binary_path"
+ cp "$binary_path" "${INSTALL_DIR}/opencode"
+ chmod 755 "${INSTALL_DIR}/opencode"
+}
+
+if [ -n "$binary_path" ]; then
+ install_from_binary
+else
+ check_version
+ download_and_install
+fi
add_to_path() {
@@ -416,4 +447,3 @@ echo -e ""
echo -e "${MUTED}For more information visit ${NC}https://opencode.ai/docs"
echo -e ""
echo -e ""
-