use super::helpers;
use crate::pipeline;
use anodizer_core::context::{Context, ContextOptions};
use anodizer_core::log::{StageLogger, Verbosity};
use anyhow::Result;
use std::path::PathBuf;
pub struct ContinueOpts {
pub dist: Option<PathBuf>,
pub dry_run: bool,
pub skip: Vec<String>,
pub token: Option<String>,
pub config_override: Option<PathBuf>,
pub verbose: bool,
pub debug: bool,
pub quiet: bool,
pub merge: bool,
}
pub fn run(opts: ContinueOpts) -> Result<()> {
let log = StageLogger::new(
"continue",
Verbosity::from_flags(opts.quiet, opts.verbose, opts.debug),
);
let ctx_opts = ContextOptions {
dry_run: opts.dry_run,
quiet: opts.quiet,
verbose: opts.verbose,
debug: opts.debug,
skip_stages: opts.skip,
token: opts.token,
merge: opts.merge,
..Default::default()
};
if opts.merge {
let config_path =
pipeline::find_config_with_logger(opts.config_override.as_deref(), Some(&log))?;
let mut config = pipeline::load_config(&config_path)?;
helpers::infer_project_name(&mut config, &log);
helpers::auto_detect_github(&mut config, &log);
let mut ctx = Context::new(config.clone(), ctx_opts);
helpers::setup_context(&mut ctx, &config, &log)?;
ctx.populate_metadata_var()?;
return super::release::run_merge(
&mut ctx,
&config,
&log,
opts.dry_run,
opts.dist.as_deref(),
);
}
let (_config, mut ctx, _dist) = helpers::init_publish_stage_ctx(
opts.config_override.as_deref(),
ctx_opts,
opts.dist.as_deref(),
true,
&log,
)?;
ctx.populate_metadata_var()?;
let p = pipeline::build_publish_pipeline();
p.run(&mut ctx, &log)
}