diff --git a/literate/setup.org b/literate/setup.org index 85f499c..83663da 100644 --- a/literate/setup.org +++ b/literate/setup.org @@ -48,17 +48,17 @@ setup_system() { cd "$SCRIPT_DIR" if [ ! -f .env ]; then cp .env.example .env - + echo -e "\n${YELLOW}--- Identity Configuration ---${NC}" echo "Let's personalize your OpenCortex experience." read -p "Your Name [User]: " user_name < /dev/tty user_name=${user_name:-User} sed -i "s|MEMEX_USER=.*|MEMEX_USER=\"$user_name\"|" .env - + read -p "Agent Name [OpenCortex]: " agent_name < /dev/tty agent_name=${agent_name:-OpenCortex} sed -i "s|MEMEX_ASSISTANT=.*|MEMEX_ASSISTANT=\"$agent_name\"|" .env - + echo -e "\n${YELLOW}--- LLM Configuration ---${NC}" echo "You can enter your LLM API keys now, or press Enter to skip and configure them later." read -p "Gemini API Key: " gemini_key < /dev/tty @@ -79,15 +79,15 @@ setup_system() { sed -i "s|SKILLS_DIR=.*|SKILLS_DIR=\"$SCRIPT_DIR/skills\"|" .env sed -i "s|ZETTELKASTEN_DIR=.*|ZETTELKASTEN_DIR=\"$memex_dir/notes\"|" .env - + read -p "Inbox Directory [$memex_dir/inbox]: " inbox_dir < /dev/tty inbox_dir=${inbox_dir:-$memex_dir/inbox} sed -i "s|INBOX_DIR=.*|INBOX_DIR=\"$inbox_dir\"|" .env - + read -p "Daily Directory [$memex_dir/daily]: " daily_dir < /dev/tty daily_dir=${daily_dir:-$memex_dir/daily} sed -i "s|DAILY_DIR=.*|DAILY_DIR=\"$daily_dir\"|" .env - + read -p "Projects Directory [$memex_dir/projects]: " proj_dir < /dev/tty proj_dir=${proj_dir:-$memex_dir/projects} sed -i "s|PROJECTS_DIR=.*|PROJECTS_DIR=\"$proj_dir\"|" .env @@ -120,13 +120,13 @@ setup_system() { done export PATH="$HOME/.local/bin:$PATH" - + echo -e "${YELLOW}--- Compiling and Loading OpenCortex (this may take a minute) ---${NC}" sbcl --non-interactive \ --eval "(load (merge-pathnames \"quicklisp/setup.lisp\" (user-homedir-pathname)))" \ --eval "(push (truename \"$SCRIPT_DIR/\") asdf:*central-registry*)" \ --eval "(ql:quickload '(:opencortex :croatoan))" - + if [ $? -ne 0 ]; then echo -e "${RED}✗ Compilation or Loading failed.${NC}" exit 1 @@ -136,7 +136,7 @@ setup_system() { # Nuke any existing brain logs > "$SCRIPT_DIR/brain.log" "$SCRIPT_DIR/opencortex.sh" --boot > "$SCRIPT_DIR/brain.log" 2>&1 & - + local success=false for i in {1..30}; do if nc -z localhost $PORT 2>/dev/null; then @@ -146,7 +146,7 @@ setup_system() { sleep 2 echo -n "." done - + if [ "$success" = true ]; then echo -e "\n${GREEN}✓ Brain is alive and responsive on port $PORT.${NC}" echo -e "${GREEN}✓ Setup complete. You can now run 'opencortex tui'.${NC}" @@ -198,7 +198,7 @@ if [[ "$1" == "tui" ]]; then done echo "" fi - + # Launch TUI echo -e "${BLUE}Launching Croatoan TUI...${NC}" exec sbcl --non-interactive \ diff --git a/opencortex.sh b/opencortex.sh index e2b5742..28724e9 100755 --- a/opencortex.sh +++ b/opencortex.sh @@ -179,7 +179,11 @@ if [[ "$1" == "--boot" ]]; then fi done < "$SCRIPT_DIR/.env" fi - exec sbcl \ + +# Force absolute paths for core system directories +export SKILLS_DIR="${SCRIPT_DIR}/skills" +[ -z "$MEMEX_DIR" ] && export MEMEX_DIR="$HOME/memex" +exec sbcl \ --eval "(load (merge-pathnames \"quicklisp/setup.lisp\" (user-homedir-pathname)))" \ --eval "(setf *debugger-hook* (lambda (c h) (declare (ignore h)) (format *error-output* \"FATAL LISP ERROR: ~a~%\" c) (uiop:print-backtrace :stream *error-output*) (uiop:quit 1)))" \ --eval "(push (truename \"$SCRIPT_DIR/\") asdf:*central-registry*)" \ @@ -204,7 +208,11 @@ if [[ "$1" == "tui" ]]; then # Launch TUI echo -e "${BLUE}Launching Croatoan TUI...${NC}" - exec sbcl \ + +# Force absolute paths for core system directories +export SKILLS_DIR="${SCRIPT_DIR}/skills" +[ -z "$MEMEX_DIR" ] && export MEMEX_DIR="$HOME/memex" +exec sbcl \ --eval "(load (merge-pathnames \"quicklisp/setup.lisp\" (user-homedir-pathname)))" \ --eval "(push (truename \"$SCRIPT_DIR/\") asdf:*central-registry*)" \ --eval "(ql:quickload :opencortex/tui)" \