blob: c8d29f97f39bef84062d541009a27bd35a47f9dd [file] [log] [blame]
Jeff King75194432009-09-09 07:38:58 -04001#ifndef ADVICE_H
2#define ADVICE_H
3
Matheus Tavaresa20f7042021-04-08 17:41:27 -03004struct string_list;
5
Heba Walyb3b18d12020-03-02 20:01:59 +00006/*
7 * To add a new advice, you need to:
8 * Define a new advice_type.
9 * Add a new entry to advice_setting array.
10 * Add the new config variable to Documentation/config/advice.txt.
11 * Call advise_if_enabled to print your advice.
12 */
Rubén Justoeddd1342024-01-11 13:40:17 +010013enum advice_type {
Heba Walyb3b18d12020-03-02 20:01:59 +000014 ADVICE_ADD_EMBEDDED_REPO,
Ben Boeckel69290552021-08-23 12:43:59 +020015 ADVICE_ADD_EMPTY_PATHSPEC,
16 ADVICE_ADD_IGNORED_FILE,
Tao Klerkse4921d82022-04-01 06:05:13 +000017 ADVICE_AMBIGUOUS_FETCH_REFSPEC,
Rubén Justo31960292024-01-11 13:40:01 +010018 ADVICE_AM_WORK_DIR,
Heba Walyb3b18d12020-03-02 20:01:59 +000019 ADVICE_CHECKOUT_AMBIGUOUS_REMOTE_BRANCH_NAME,
20 ADVICE_COMMIT_BEFORE_MERGE,
21 ADVICE_DETACHED_HEAD,
Felipe Contreras765071a2023-03-07 20:48:33 -060022 ADVICE_DIVERGING,
Heba Walyb3b18d12020-03-02 20:01:59 +000023 ADVICE_FETCH_SHOW_FORCED_UPDATES,
Rubén Justobec9bb42024-01-11 13:40:34 +010024 ADVICE_FORCE_DELETE_BRANCH,
Heba Walyb3b18d12020-03-02 20:01:59 +000025 ADVICE_GRAFT_FILE_DEPRECATED,
26 ADVICE_IGNORED_HOOK,
27 ADVICE_IMPLICIT_IDENTITY,
Philippe Blainec030092024-03-16 21:16:29 +000028 ADVICE_MERGE_CONFLICT,
Heba Walyb3b18d12020-03-02 20:01:59 +000029 ADVICE_NESTED_TAG,
30 ADVICE_OBJECT_NAME_WARNING,
31 ADVICE_PUSH_ALREADY_EXISTS,
32 ADVICE_PUSH_FETCH_FIRST,
33 ADVICE_PUSH_NEEDS_FORCE,
34 ADVICE_PUSH_NON_FF_CURRENT,
35 ADVICE_PUSH_NON_FF_MATCHING,
Srinidhi Kaushik3b990aa2020-10-03 17:40:45 +053036 ADVICE_PUSH_REF_NEEDS_UPDATE,
Rubén Justo31960292024-01-11 13:40:01 +010037 ADVICE_PUSH_UNQUALIFIED_REF_NAME,
38 ADVICE_PUSH_UPDATE_REJECTED,
39 ADVICE_PUSH_UPDATE_REJECTED_ALIAS,
Kristoffer Haugsbakk8fbd9032024-03-05 21:29:43 +010040 ADVICE_REF_SYNTAX,
Victoria Dye93962512022-03-15 01:49:40 +000041 ADVICE_RESET_NO_REFRESH_WARNING,
Heba Walyb3b18d12020-03-02 20:01:59 +000042 ADVICE_RESOLVE_CONFLICT,
43 ADVICE_RM_HINTS,
44 ADVICE_SEQUENCER_IN_USE,
45 ADVICE_SET_UPSTREAM_FAILURE,
Rubén Justo31960292024-01-11 13:40:01 +010046 ADVICE_SKIPPED_CHERRY_PICKS,
Heba Walyb3b18d12020-03-02 20:01:59 +000047 ADVICE_STATUS_AHEAD_BEHIND_WARNING,
48 ADVICE_STATUS_HINTS,
49 ADVICE_STATUS_U_OPTION,
Glen Choo961b1302022-01-28 16:04:45 -080050 ADVICE_SUBMODULES_NOT_UPDATED,
Rubén Justo31960292024-01-11 13:40:01 +010051 ADVICE_SUBMODULE_ALTERNATE_ERROR_STRATEGY_DIE,
Philippe Blainb9e55be2024-02-26 13:27:28 +000052 ADVICE_SUBMODULE_MERGE_CONFLICT,
Rubén Justo31960292024-01-11 13:40:01 +010053 ADVICE_SUGGEST_DETACHING_HEAD,
Matheus Tavaresa20f7042021-04-08 17:41:27 -030054 ADVICE_UPDATE_SPARSE_PATH,
Heba Walyb3b18d12020-03-02 20:01:59 +000055 ADVICE_WAITING_FOR_EDITOR,
Jacob Abel35f03832023-05-17 21:48:52 +000056 ADVICE_WORKTREE_ADD_ORPHAN,
Heba Walyb3b18d12020-03-02 20:01:59 +000057};
58
Jeff King75194432009-09-09 07:38:58 -040059int git_default_advice_config(const char *var, const char *value);
Jeff King46210852013-07-09 20:18:40 -040060__attribute__((format (printf, 1, 2)))
Ramkumar Ramachandra38ef61c2011-08-04 16:08:59 +053061void advise(const char *advice, ...);
Heba Walyb3b18d12020-03-02 20:01:59 +000062
63/**
64 * Checks if advice type is enabled (can be printed to the user).
65 * Should be called before advise().
66 */
67int advice_enabled(enum advice_type type);
68
69/**
70 * Checks the visibility of the advice before printing.
71 */
Ævar Arnfjörð Bjarmason927dc332021-07-13 10:05:20 +020072__attribute__((format (printf, 2, 3)))
Heba Walyb3b18d12020-03-02 20:01:59 +000073void advise_if_enabled(enum advice_type type, const char *advice, ...);
74
Ramkumar Ramachandra38ef61c2011-08-04 16:08:59 +053075int error_resolve_conflict(const char *me);
Denton Liu55454422019-04-29 04:28:14 -040076void NORETURN die_resolve_conflict(const char *me);
Paul Tan4a4cf9e2015-06-18 18:54:04 +080077void NORETURN die_conclude_merge(void);
Alex Henrie3d5fc242021-07-21 01:42:19 +000078void NORETURN die_ff_impossible(void);
Matheus Tavaresa20f7042021-04-08 17:41:27 -030079void advise_on_updating_sparse_paths(struct string_list *pathspec_list);
Nguyễn Thái Ngọc Duy28570932012-01-16 16:46:16 +070080void detach_advice(const char *new_name);
Shaoxuan Yuan5efd5332022-08-09 20:09:09 +080081void advise_on_moving_dirty_path(struct string_list *pathspec_list);
Matthieu Moyd38a30d2010-01-12 10:54:44 +010082
Jeff King75194432009-09-09 07:38:58 -040083#endif /* ADVICE_H */