fix: Remove exec from bootstrapper and robustify tangle loop

This commit is contained in:
2026-04-16 14:22:45 -04:00
parent bdce5a11ee
commit 0272ed3f61
2 changed files with 44 additions and 119 deletions

View File

@@ -16,18 +16,11 @@ command_exists() { command -v "$1" >/dev/null 2>&1; }
bootstrap_opencortex() {
echo -e "${BLUE}=== OpenCortex: Zero-to-One Bootstrapper ===${NC}"
if [ -d ".git" ]; then
echo "Detected existing repository. Switching to local mode..."
return
fi
TARGET_DIR="opencortex"
if [ -d "$TARGET_DIR" ]; then
if [ -d "$TARGET_DIR/.git" ]; then
echo -e "${YELLOW}! Using existing repository in '$TARGET_DIR'...${NC}"
else
echo -e "${RED}! Directory '$TARGET_DIR' exists. Using it as-is...${NC}"
fi
else
if [ ! -d "$TARGET_DIR" ]; then
echo -e "${BLUE}Cloning repository into $TARGET_DIR...${NC}"
git clone http://10.10.10.201:3001/amr/opencortex.git "$TARGET_DIR"
fi
@@ -35,46 +28,26 @@ bootstrap_opencortex() {
cd "$TARGET_DIR"
git submodule update --init --recursive
echo -e "${GREEN}✓ Repository prepared. Handing off to local setup...${NC}"
# Reconnect stdin to the TTY for the next script, or use /dev/null to avoid hang
echo -e "${GREEN}✓ Repository prepared.${NC}"
# Run the setup script. We don't use exec here so we can stay in control.
# We try to give it a TTY, but fallback to /dev/null if that causes a hang.
if [ -t 0 ]; then
exec ./scripts/onboard-baremetal.sh
./scripts/onboard-baremetal.sh
else
exec ./scripts/onboard-baremetal.sh < /dev/tty 2>/dev/null || exec ./scripts/onboard-baremetal.sh < /dev/null
./scripts/onboard-baremetal.sh < /dev/tty 2>/dev/null || ./scripts/onboard-baremetal.sh < /dev/null
fi
echo -e "${GREEN}✓ Setup phase complete.${NC}"
exit 0
}
if [ ! -d ".git" ]; then
bootstrap_opencortex
fi
update_opencortex() {
echo -e "${BLUE}Updating OpenCortex...${NC}"
if [ -d ".git" ]; then
git pull origin main
fi
echo -e "${GREEN}✓ Update complete.${NC}"
exit 0
}
if [[ "$1" == "--update" ]]; then update_opencortex; fi
# 1. Try to drop straight into the CLI chat
if command_exists socat && socat - TCP:$HOST:$PORT,connect-timeout=1 2>/dev/null; then
echo -e "${BLUE}Connected to autonomous brain at $HOST:$PORT...${NC}"
socat READLINE,history=$HOME/.org_agent_history TCP:$HOST:$PORT
exit 0
fi
# 2. Local repository detection and launch
# ... (rest of local mode)
if [ -f "opencortex.asd" ] || [ -d "literate" ]; then
if [ ! -f .env ]; then
./scripts/onboard-baremetal.sh
fi
echo -e "${BLUE}Starting OpenCortex via SBCL...${NC}"
sbcl --non-interactive \
--eval "(load \"~/quicklisp/setup.lisp\")" \
--eval "(ql:quickload :opencortex)" \
--eval "(opencortex:main)"
if [ ! -f .env ]; then ./scripts/onboard-baremetal.sh; fi
sbcl --non-interactive --eval "(load \"~/quicklisp/setup.lisp\")" --eval "(ql:quickload :opencortex)" --eval "(opencortex:main)"
fi

View File

@@ -1,5 +1,4 @@
#!/bin/bash
# OpenCortex Final-Mile Installer (Debug Edition)
RED='\033[0;31m'; GREEN='\033[0;32m'; BLUE='\033[0;34m'; YELLOW='\033[0;33m'; NC='\033[0m'
echo -e "${BLUE}=== OpenCortex: Baremetal Power-User Setup ===${NC}"
@@ -13,108 +12,61 @@ prompt_user() {
echo -n -e "${YELLOW}$prompt (default: $default): ${NC}" >&2
# Check if we have a real terminal
if [ -t 0 ]; then
if read -t 10 result; then
:
else
result="$default"
echo -e "${BLUE} [Timeout: Using $default]${NC}" >&2
fi
# Try reading from stdin with a 2-second timeout
if read -t 2 result; then
:
else
# If no terminal, try /dev/tty but don't hang
if read -t 2 result < /dev/tty 2>/dev/null; then
:
else
result="$default"
echo -e "${BLUE} [Auto-Selected Default: $default]${NC}" >&2
fi
result="$default"
echo -e "${BLUE} [Defaulting to $default]${NC}" >&2
fi
val=${result:-$default}
eval "$var_name=\"$val\""
}
echo "DEBUG: Checking dependencies..."
# 1. Dependency Management
if ! command -v sbcl >/dev/null 2>&1 || ! command -v emacs >/dev/null 2>&1; then
echo -e "${YELLOW}! Missing dependencies (SBCL/Emacs).${NC}"
# Just auto-install if we are in a non-interactive pipe
if [ ! -t 0 ]; then
DO_INSTALL="y"
echo -e "${BLUE}[Auto-Pilot: Installing dependencies]${NC}"
else
prompt_user "Should I attempt to install them for you? [Y/n]" "y" "DO_INSTALL"
fi
if [[ "$DO_INSTALL" =~ ^[Yy]$ ]]; then
if command -v apt-get >/dev/null; then
sudo apt-get update && sudo apt-get install -y sbcl emacs git curl socat
elif command -v pacman >/dev/null; then
sudo pacman -S --noconfirm sbcl emacs git curl socat
fi
echo -e "${BLUE}Installing dependencies...${NC}"
if command -v apt-get >/dev/null; then
sudo apt-get update && sudo apt-get install -y sbcl emacs git curl socat
fi
fi
echo "DEBUG: Checking Quicklisp..."
if [ ! -d "$HOME/quicklisp" ] && [ ! -d "$HOME/.quicklisp" ]; then
echo -e "${YELLOW}! Quicklisp not found.${NC}"
if [ ! -t 0 ]; then
DO_QL="y"
echo -e "${BLUE}[Auto-Pilot: Installing Quicklisp]${NC}"
else
prompt_user "Install Quicklisp now? [Y/n]" "y" "DO_QL"
fi
if [[ "$DO_QL" =~ ^[Yy]$ ]]; then
curl -O https://beta.quicklisp.org/quicklisp.lisp
sbcl --non-interactive --load quicklisp.lisp \
--eval "(quicklisp-quickstart:install)" \
--eval "(ql-util:without-prompting (ql:add-to-init-file))"
rm quicklisp.lisp
fi
# 2. Quicklisp
if [ ! -d "$HOME/quicklisp" ]; then
echo -e "${BLUE}Installing Quicklisp...${NC}"
curl -O https://beta.quicklisp.org/quicklisp.lisp
sbcl --non-interactive --load quicklisp.lisp --eval "(quicklisp-quickstart:install)" --eval "(ql-util:without-prompting (ql:add-to-init-file))"
rm quicklisp.lisp
fi
echo "DEBUG: Starting Tangle..."
# 3. Tangling
echo -e "${BLUE}Tangling source files...${NC}"
mkdir -p src
for f in literate/*.org; do
echo " - DEBUG: Tangling $f"
emacs --batch --eval "(require 'org)" --eval "(org-babel-tangle-file \"$f\")" >/dev/null 2>&1 || true
echo " - $f"
emacs --batch --eval "(require 'org)" --eval "(org-babel-tangle-file \"$f\")" >/dev/null 2>&1
done
echo "DEBUG: Tangle Loop Finished."
if [ ! -f "src/package.lisp" ]; then
echo -e "${RED}✗ Tangling failed. Essential files missing in src/.${NC}"
if [ -f "src/package.lisp" ]; then
echo -e "${GREEN}✓ Core tangled successfully.${NC}"
else
echo -e "${RED}✗ Tangle failed!${NC}"
exit 1
fi
echo -e "${GREEN}✓ Core tangled successfully.${NC}"
echo "DEBUG: Configuring Env..."
# 4. Configuration
if [ ! -f .env ]; then cp .env.example .env; fi
# For environment variables, just use defaults if no terminal
if [ ! -t 0 ]; then
USER_NAME="User"
AGENT_NAME="OpenCortex"
LLM_CHOICE="1"
echo -e "${BLUE}[Auto-Pilot: Using default configuration]${NC}"
else
prompt_user "What is your name?" "User" "USER_NAME"
prompt_user "What shall we name your Assistant?" "OpenCortex" "AGENT_NAME"
echo -e "\nSelect neural provider (1:Gemini, 2:OpenRouter, 3:Anthropic, 4:OpenAI)"
prompt_user "Choice" "1" "LLM_CHOICE"
fi
prompt_user "What is your name?" "User" "USER_NAME"
prompt_user "What shall we name your Assistant?" "OpenCortex" "AGENT_NAME"
prompt_user "Select provider (1:Gemini, 2:OpenRouter)" "1" "LLM_CHOICE"
sed -i "s/MEMEX_USER=.*/MEMEX_USER=\"$USER_NAME\"/g" .env
sed -i "s/MEMEX_ASSISTANT=.*/MEMEX_ASSISTANT=\"$AGENT_NAME\"/g" .env
# Path Alignment (Automated)
PROJECT_ROOT=$(pwd)
PARENT_DIR=$(dirname "$PROJECT_ROOT")
sed -i "s|MEMEX_DIR=.*|MEMEX_DIR=\"$PARENT_DIR\"|g" .env
sed -i "s|ZETTELKASTEN_DIR=.*|ZETTELKASTEN_DIR=\"$PARENT_DIR/notes\"|g" .env
sed -i "s|SKILLS_DIR=.*|SKILLS_DIR=\"$PROJECT_ROOT/skills\"|g" .env
# Path Alignment
sed -i "s|MEMEX_DIR=.*|MEMEX_DIR=\"$(dirname $(pwd))\"|g" .env
sed -i "s|SKILLS_DIR=.*|SKILLS_DIR=\"$(pwd)/skills\"|g" .env
echo -e "\n${GREEN}==============================================${NC}"
echo -e "${GREEN} OpenCortex Installation Complete! ${NC}"
echo -e "${GREEN}==============================================${NC}"
echo -e "To start the brain: ./opencortex.sh"
echo -e "\n${GREEN}=== OpenCortex Ready ===${NC}"