Skip to main content

ralph_core/
lib.rs

1//! # ralph-core
2//!
3//! Core orchestration functionality for the Ralph Orchestrator framework.
4//!
5//! This crate provides:
6//! - The main orchestration loop for coordinating multiple agents
7//! - Configuration loading and management
8//! - State management for agent sessions
9//! - Message routing between agents
10//! - Terminal capture for session recording
11//! - Benchmark task definitions and workspace isolation
12
13pub mod chaos_mode;
14mod cli_capture;
15mod config;
16pub mod diagnostics;
17mod event_logger;
18mod event_loop;
19mod event_parser;
20mod event_reader;
21pub mod file_lock;
22mod git_ops;
23mod handoff;
24mod hat_registry;
25mod hatless_ralph;
26mod instructions;
27mod landing;
28pub mod loop_completion;
29pub mod loop_context;
30pub mod loop_history;
31pub mod loop_lock;
32mod loop_name;
33pub mod loop_registry;
34mod memory;
35pub mod memory_parser;
36mod memory_store;
37pub mod merge_queue;
38pub mod planning_session;
39mod session_player;
40mod session_recorder;
41mod summary_writer;
42pub mod task;
43pub mod task_definition;
44pub mod task_store;
45pub mod testing;
46mod text;
47pub mod utils;
48pub mod workspace;
49pub mod worktree;
50
51pub use chaos_mode::{CHAOS_COMPLETION_PROMISE, ChaosModeState};
52pub use cli_capture::{CliCapture, CliCapturePair};
53pub use config::{
54    ChaosModeConfig, ChaosOutput, CliConfig, CoreConfig, EventLoopConfig, EventMetadata,
55    FeaturesConfig, HatBackend, HatConfig, InjectMode, MemoriesConfig, MemoriesFilter, RalphConfig,
56    ResearchFocus,
57};
58// Re-export loop_name types (also available via FeaturesConfig.loop_naming)
59pub use diagnostics::DiagnosticsCollector;
60pub use event_logger::{EventHistory, EventLogger, EventRecord};
61pub use event_loop::{EventLoop, LoopState, TerminationReason, UserPrompt, UserPromptError};
62pub use event_parser::EventParser;
63pub use event_reader::{Event, EventReader, MalformedLine, ParseResult};
64pub use file_lock::{FileLock, LockGuard as FileLockGuard, LockedFile};
65pub use git_ops::{
66    AutoCommitResult, GitOpsError, auto_commit_changes, clean_stashes, get_commit_summary,
67    get_current_branch, get_head_sha, get_recent_files, has_uncommitted_changes,
68    is_working_tree_clean, prune_remote_refs,
69};
70pub use handoff::{HandoffError, HandoffResult, HandoffWriter};
71pub use hat_registry::HatRegistry;
72pub use hatless_ralph::{HatInfo, HatTopology, HatlessRalph};
73pub use instructions::InstructionBuilder;
74pub use landing::{LandingConfig, LandingError, LandingHandler, LandingResult};
75pub use loop_completion::{CompletionAction, CompletionError, LoopCompletionHandler};
76pub use loop_context::LoopContext;
77pub use loop_history::{HistoryError, HistoryEvent, HistoryEventType, HistorySummary, LoopHistory};
78pub use loop_lock::{LockError, LockGuard, LockMetadata, LoopLock};
79pub use loop_name::{LoopNameGenerator, LoopNamingConfig};
80pub use loop_registry::{LoopEntry, LoopRegistry, RegistryError};
81pub use memory::{Memory, MemoryType};
82pub use memory_store::{
83    DEFAULT_MEMORIES_PATH, MarkdownMemoryStore, format_memories_as_markdown, truncate_to_budget,
84};
85pub use merge_queue::{
86    MergeButtonState, MergeEntry, MergeEvent, MergeEventType, MergeOption, MergeQueue,
87    MergeQueueError, MergeState, SteeringDecision, merge_button_state, merge_execution_summary,
88    merge_needs_steering, smart_merge_summary,
89};
90pub use planning_session::{
91    ConversationEntry, ConversationType, PlanningSession, PlanningSessionError, SessionMetadata,
92    SessionStatus,
93};
94pub use session_player::{PlayerConfig, ReplayMode, SessionPlayer, TimestampedRecord};
95pub use session_recorder::{Record, SessionRecorder};
96pub use summary_writer::SummaryWriter;
97pub use task::{Task, TaskStatus};
98pub use task_definition::{
99    TaskDefinition, TaskDefinitionError, TaskSetup, TaskSuite, Verification,
100};
101pub use task_store::TaskStore;
102pub use text::truncate_with_ellipsis;
103pub use workspace::{
104    CleanupPolicy, TaskWorkspace, VerificationResult, WorkspaceError, WorkspaceInfo,
105    WorkspaceManager,
106};
107pub use worktree::{
108    SyncStats, Worktree, WorktreeConfig, WorktreeError, create_worktree, ensure_gitignore,
109    list_ralph_worktrees, list_worktrees, remove_worktree, sync_working_directory_to_worktree,
110    worktree_exists,
111};