summaryrefslogtreecommitdiff
path: root/makima/src/server/handlers/mesh.rs
diff options
context:
space:
mode:
authorsoryu <soryu@soryu.co>2026-01-22 22:32:46 +0000
committersoryu <soryu@soryu.co>2026-01-23 01:03:04 +0000
commit1ed362424dafec690f919154f5116471951cda9c (patch)
tree19c7ca9231887394a791223fe32a8ad335a687a8 /makima/src/server/handlers/mesh.rs
parent265f8cf14fec9d7116d09af49e4b48b357faceda (diff)
downloadsoryu-1ed362424dafec690f919154f5116471951cda9c.tar.gz
soryu-1ed362424dafec690f919154f5116471951cda9c.zip
Add patch checkpointing
Diffstat (limited to 'makima/src/server/handlers/mesh.rs')
-rw-r--r--makima/src/server/handlers/mesh.rs18
1 files changed, 18 insertions, 0 deletions
diff --git a/makima/src/server/handlers/mesh.rs b/makima/src/server/handlers/mesh.rs
index 53e1587..240e1f7 100644
--- a/makima/src/server/handlers/mesh.rs
+++ b/makima/src/server/handlers/mesh.rs
@@ -685,8 +685,11 @@ pub async fn start_task(
copy_files: task.copy_files.as_ref().and_then(|v| serde_json::from_value(v.clone()).ok()),
contract_id: task.contract_id,
is_supervisor: task.is_supervisor,
+ autonomous_loop: false,
resume_session: false,
conversation_history: None,
+ patch_data: None,
+ patch_base_sha: None,
};
tracing::info!(
@@ -734,8 +737,11 @@ pub async fn start_task(
copy_files: task.copy_files.as_ref().and_then(|v| serde_json::from_value(v.clone()).ok()),
contract_id: task.contract_id,
is_supervisor: task.is_supervisor,
+ autonomous_loop: false,
resume_session: false,
conversation_history: None,
+ patch_data: None,
+ patch_base_sha: None,
};
if state.send_daemon_command(alt_daemon_id, alt_command).await.is_ok() {
@@ -1135,8 +1141,11 @@ pub async fn send_message(
copy_files: updated_task.copy_files.as_ref().and_then(|v| serde_json::from_value(v.clone()).ok()),
contract_id: updated_task.contract_id,
is_supervisor: updated_task.is_supervisor,
+ autonomous_loop: false,
resume_session: false,
conversation_history: None,
+ patch_data: None,
+ patch_base_sha: None,
};
if state.send_daemon_command(new_daemon_id, spawn_cmd).await.is_ok() {
@@ -2273,8 +2282,11 @@ pub async fn reassign_task(
copy_files: None,
contract_id: task.contract_id,
is_supervisor: task.is_supervisor,
+ autonomous_loop: false,
resume_session: false,
conversation_history: None,
+ patch_data: None,
+ patch_base_sha: None,
};
tracing::info!(
@@ -2597,8 +2609,11 @@ pub async fn continue_task(
copy_files: task.copy_files.as_ref().and_then(|v| serde_json::from_value(v.clone()).ok()),
contract_id: task.contract_id,
is_supervisor: task.is_supervisor,
+ autonomous_loop: false,
resume_session: false,
conversation_history: None,
+ patch_data: None,
+ patch_base_sha: None,
};
tracing::info!(
@@ -3490,8 +3505,11 @@ pub async fn branch_task(
copy_files: None,
contract_id: None,
is_supervisor: false,
+ autonomous_loop: false,
resume_session: message_count > 0, // Resume if we have conversation history
conversation_history: updated_task.conversation_state.clone(),
+ patch_data: None,
+ patch_base_sha: None,
};
if let Err(e) = state.send_daemon_command(target_daemon_id, command).await {