claude-evolve 1.6.26 → 1.6.28

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -145,7 +145,7 @@ fi
145
145
  if [[ -n $WORKING_DIR ]]; then
146
146
  # Remove trailing slash if present
147
147
  WORKING_DIR="${WORKING_DIR%/}"
148
- export CLAUDE_EVOLVE_CONFIG="$WORKING_DIR/config.yaml"
148
+ export CLAUDE_EVOLVE_WORKING_DIR="$WORKING_DIR"
149
149
  fi
150
150
 
151
151
  # Check for updates (quick, non-blocking)
@@ -7,25 +7,16 @@ SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
7
7
  # shellcheck source=../lib/config.sh
8
8
  source "$SCRIPT_DIR/../lib/config.sh"
9
9
 
10
- # Use CLAUDE_EVOLVE_CONFIG if set, otherwise default
11
- if [[ -n ${CLAUDE_EVOLVE_CONFIG:-} ]]; then
12
- load_config "$CLAUDE_EVOLVE_CONFIG"
10
+ # Use CLAUDE_EVOLVE_WORKING_DIR if set, otherwise default
11
+ if [[ -n ${CLAUDE_EVOLVE_WORKING_DIR:-} ]]; then
12
+ load_config "$CLAUDE_EVOLVE_WORKING_DIR"
13
13
  else
14
- # Check if config.yaml exists in current directory
15
- if [[ -f "config.yaml" ]]; then
16
- # Don't export to avoid collision with parallel runs
17
- CONFIG_FILE="$(pwd)/config.yaml"
18
- load_config "$CONFIG_FILE"
19
- else
20
- load_config
21
- fi
14
+ load_config
22
15
  fi
23
16
 
24
17
  # Store the config path for workers (don't export to avoid collision)
25
- if [[ -n ${CLAUDE_EVOLVE_CONFIG:-} ]]; then
26
- WORKER_CONFIG_PATH="$CLAUDE_EVOLVE_CONFIG"
27
- elif [[ -n ${CONFIG_FILE:-} ]]; then
28
- WORKER_CONFIG_PATH="$CONFIG_FILE"
18
+ if [[ -n ${CLAUDE_EVOLVE_WORKING_DIR:-} ]]; then
19
+ WORKER_CONFIG_PATH="$CLAUDE_EVOLVE_WORKING_DIR/config.yaml"
29
20
  elif [[ -f "config.yaml" ]]; then
30
21
  WORKER_CONFIG_PATH="$(pwd)/config.yaml"
31
22
  else
@@ -590,6 +590,8 @@ from lib.evolution_csv import EvolutionCSV
590
590
  with EvolutionCSV('$FULL_CSV_PATH') as csv:
591
591
  csv.update_candidate_status('$candidate_id', 'failed-parent-missing')
592
592
  " 2>/dev/null || true
593
+ # Clear current candidate to avoid cleanup resetting it
594
+ CURRENT_CANDIDATE_ID=""
593
595
  # Stop looping so we don't keep retrying for missing dependency
594
596
  break
595
597
  else
package/lib/config.py CHANGED
@@ -49,6 +49,8 @@ class Config:
49
49
  # Determine self.working_dir (EVOLUTION_DIR equivalent) based on specified logic
50
50
  if working_dir:
51
51
  self.working_dir = Path(working_dir)
52
+ elif os.environ.get('CLAUDE_EVOLVE_WORKING_DIR'):
53
+ self.working_dir = Path(os.environ.get('CLAUDE_EVOLVE_WORKING_DIR'))
52
54
  elif (Path('evolution') / 'evolution.csv').exists():
53
55
  self.working_dir = Path('evolution')
54
56
  elif Path('./evolution.csv').exists():
package/lib/config.sh CHANGED
@@ -170,8 +170,9 @@ _load_yaml_config() {
170
170
  LAST_CONFIG_FILE_LOADED="$config_file"
171
171
  }
172
172
 
173
- # Load configuration from config file
174
173
  load_config() {
174
+ echo "[DEBUG] $1 at start of load_config: '$1'" >&2
175
+ echo "[DEBUG] DEFAULT_EVOLUTION_DIR: $DEFAULT_EVOLUTION_DIR" >&2
175
176
  # Set defaults first
176
177
  EVOLUTION_DIR="$DEFAULT_EVOLUTION_DIR" # Initialize with default
177
178
  ALGORITHM_FILE="$DEFAULT_ALGORITHM_FILE"
@@ -183,15 +184,20 @@ load_config() {
183
184
  PYTHON_CMD="$DEFAULT_PYTHON_CMD"
184
185
 
185
186
  # Determine EVOLUTION_DIR based on specified logic, overriding default if found
186
- local user_working_dir="$1"
187
- if [[ -n "$user_working_dir" ]]; then
188
- EVOLUTION_DIR="$user_working_dir"
187
+ if [[ -n "$CLAUDE_EVOLVE_WORKING_DIR" ]]; then
188
+ echo "[DEBUG] EVOLUTION_DIR set by CLAUDE_EVOLVE_WORKING_DIR: $CLAUDE_EVOLVE_WORKING_DIR" >&2
189
+ EVOLUTION_DIR="$CLAUDE_EVOLVE_WORKING_DIR"
189
190
  elif [[ -f "evolution/evolution.csv" ]]; then
191
+ echo "[DEBUG] EVOLUTION_DIR set by evolution/evolution.csv: evolution" >&2
190
192
  EVOLUTION_DIR="evolution"
191
193
  elif [[ -f "./evolution.csv" ]]; then
194
+ echo "[DEBUG] EVOLUTION_DIR set by ./evolution.csv: ." >&2
192
195
  EVOLUTION_DIR="."
196
+ else
197
+ echo "[DEBUG] EVOLUTION_DIR defaulting to: $DEFAULT_EVOLUTION_DIR" >&2
193
198
  fi
194
-
199
+ echo "[DEBUG] EVOLUTION_DIR after initial determination: $EVOLUTION_DIR" >&2
200
+
195
201
  TOTAL_IDEAS="$DEFAULT_TOTAL_IDEAS"
196
202
  NOVEL_EXPLORATION="$DEFAULT_NOVEL_EXPLORATION"
197
203
  HILL_CLIMBING="$DEFAULT_HILL_CLIMBING"
@@ -233,11 +239,11 @@ load_config() {
233
239
  # Load global config (overrides local config)
234
240
  local global_config_file="$HOME/.config/claude-evolve/config.yaml"
235
241
  _load_yaml_config "$global_config_file"
236
-
242
+
237
243
  echo "[DEBUG] EVOLUTION_DIR before FULL_EVOLUTION_DIR calculation: $EVOLUTION_DIR" >&2
238
244
 
239
245
  # Create full paths - ALL paths are relative to EVOLUTION_DIR
240
- # Make EVOLUTION_DIR absolute if it's relative
246
+ # Make EVOLUTION_DIR absolute if it\'s relative
241
247
  if [[ "$EVOLUTION_DIR" = /* ]]; then
242
248
  FULL_EVOLUTION_DIR="$EVOLUTION_DIR"
243
249
  else
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "claude-evolve",
3
- "version": "1.6.26",
3
+ "version": "1.6.28",
4
4
  "bin": {
5
5
  "claude-evolve": "./bin/claude-evolve",
6
6
  "claude-evolve-main": "./bin/claude-evolve-main",