Skip to main content

PipelineExecutor

Struct PipelineExecutor 

Source
pub struct PipelineExecutor<R: CommandRunner> {
    pub runner: Arc<R>,
    pub github: Arc<GhClient<R>>,
    pub issues: Arc<dyn IssueProvider>,
    pub db: Arc<Mutex<Connection>>,
    pub config: Config,
    pub cancel_token: CancellationToken,
    pub repo_dir: PathBuf,
}
Expand description

Runs a single issue through the full pipeline.

Fields§

§runner: Arc<R>§github: Arc<GhClient<R>>§issues: Arc<dyn IssueProvider>§db: Arc<Mutex<Connection>>§config: Config§cancel_token: CancellationToken§repo_dir: PathBuf

Implementations§

Source§

impl<R: CommandRunner + 'static> PipelineExecutor<R>

Source

pub async fn run_issue( &self, issue: &PipelineIssue, auto_merge: bool, ) -> Result<()>

Run the full pipeline for a single issue.

Source

pub async fn run_issue_with_complexity( &self, issue: &PipelineIssue, auto_merge: bool, complexity: Option<Complexity>, ) -> Result<()>

Run the full pipeline for a single issue with an optional complexity classification.

Source

pub async fn run_issue_pipeline( &self, issue: &PipelineIssue, auto_merge: bool, complexity: Option<Complexity>, ) -> Result<PipelineOutcome>

Run the pipeline up to (but not including) finalization.

Returns a PipelineOutcome with the run ID and PR number. The caller is responsible for calling finalize_run or finalize_merge at the appropriate time (e.g., after the PR is actually merged).

Source

pub async fn finalize_merge( &self, outcome: &PipelineOutcome, issue: &PipelineIssue, ) -> Result<()>

Finalize a run after its PR has been merged.

Transitions labels, closes issues, marks the run as complete, cleans up the worktree, and deletes the local branch. The worktree must be removed before the branch because git refuses to delete a branch that is checked out in a worktree.

Source

pub async fn plan_issues( &self, issues: &[PipelineIssue], graph_context: &[GraphContextNode], ) -> Option<PlannerGraphOutput>

Invoke the planner agent to decide dependency ordering for a set of issues.

graph_context describes the current dependency graph state so the planner can avoid scheduling conflicting work alongside in-flight issues.

Returns None if the planner fails or returns unparseable output (fallback to default).

Source

pub async fn reconstruct_outcome( &self, issue: &PipelineIssue, run_id: &str, pr_number: u32, ) -> Result<PipelineOutcome>

Reconstruct a PipelineOutcome from graph node data (for merge polling).

Worktree paths are deterministic, so we can rebuild the outcome from the issue metadata stored on the graph node. The branch name is looked up from the runs table (it was recorded when the worktree was created).

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more