1use anyhow::Result;
4
5use crate::cli::PushMode;
6use crate::git;
7
8pub const PROVIDER_KEY: &str = "stk.provider";
9pub const REMOTE_KEY: &str = "stk.remote";
10pub const UPDATE_REFS_KEY: &str = "stk.updateRefs";
11pub const PUSH_ON_RESTACK_KEY: &str = "stk.pushOnRestack";
12pub const PUSH_ON_SUBMIT_KEY: &str = "stk.pushOnSubmit";
13pub const SUBMIT_STACK_KEY: &str = "stk.submitStack";
14pub const MERGE_STRATEGY_KEY: &str = "stk.mergeStrategy";
15pub const MERGE_WAIT_KEY: &str = "stk.mergeWait";
16pub const SUBMIT_DRAFT_KEY: &str = "stk.submitDraft";
17pub const NO_UPDATE_CHECK_KEY: &str = "stk.noUpdateCheck";
18pub const DEFAULT_REMOTE: &str = "origin";
19
20pub const SETTINGS: &[(&str, &str)] = &[
23 (PROVIDER_KEY, "auto-detect from the remote URL"),
24 (REMOTE_KEY, DEFAULT_REMOTE),
25 (UPDATE_REFS_KEY, "false"),
26 (PUSH_ON_RESTACK_KEY, "false"),
27 (PUSH_ON_SUBMIT_KEY, "false"),
28 (SUBMIT_STACK_KEY, "false"),
29 (MERGE_STRATEGY_KEY, "squash"),
30 (MERGE_WAIT_KEY, "false"),
31 (SUBMIT_DRAFT_KEY, "false"),
32 (NO_UPDATE_CHECK_KEY, "false"),
33];
34
35pub fn remote() -> Result<String> {
37 Ok(git::config_get(REMOTE_KEY)?.unwrap_or_else(|| DEFAULT_REMOTE.to_owned()))
38}
39
40pub fn merge_strategy() -> Result<String> {
42 let strategy = git::config_get(MERGE_STRATEGY_KEY)?.unwrap_or_else(|| "squash".to_owned());
43 match strategy.as_str() {
44 "squash" | "rebase" | "merge" => Ok(strategy),
45 other => anyhow::bail!(
46 "unsupported stk.mergeStrategy value {other:?}; expected squash, rebase, or merge"
47 ),
48 }
49}
50
51pub fn bool_setting(key: &str) -> Result<bool> {
53 Ok(git::config_get_bool(key)?.unwrap_or(false))
54}
55
56pub fn push_enabled(mode: PushMode, key: &str) -> Result<bool> {
58 match mode {
59 PushMode::Config => Ok(git::config_get_bool(key)?.unwrap_or(false)),
60 PushMode::Enabled => Ok(true),
61 PushMode::Disabled => Ok(false),
62 }
63}