advice.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. #ifndef ADVICE_H
  2. #define ADVICE_H
  3. #include "git-compat-util.h"
  4. extern int advice_fetch_show_forced_updates;
  5. extern int advice_push_update_rejected;
  6. extern int advice_push_non_ff_current;
  7. extern int advice_push_non_ff_matching;
  8. extern int advice_push_already_exists;
  9. extern int advice_push_fetch_first;
  10. extern int advice_push_needs_force;
  11. extern int advice_push_unqualified_ref_name;
  12. extern int advice_status_hints;
  13. extern int advice_status_u_option;
  14. extern int advice_status_ahead_behind_warning;
  15. extern int advice_commit_before_merge;
  16. extern int advice_reset_quiet_warning;
  17. extern int advice_resolve_conflict;
  18. extern int advice_sequencer_in_use;
  19. extern int advice_implicit_identity;
  20. extern int advice_detached_head;
  21. extern int advice_set_upstream_failure;
  22. extern int advice_object_name_warning;
  23. extern int advice_amworkdir;
  24. extern int advice_rm_hints;
  25. extern int advice_add_embedded_repo;
  26. extern int advice_ignored_hook;
  27. extern int advice_waiting_for_editor;
  28. extern int advice_graft_file_deprecated;
  29. extern int advice_checkout_ambiguous_remote_branch_name;
  30. extern int advice_submodule_alternate_error_strategy_die;
  31. extern int advice_add_ignored_file;
  32. extern int advice_add_empty_pathspec;
  33. /*
  34. * To add a new advice, you need to:
  35. * Define a new advice_type.
  36. * Add a new entry to advice_setting array.
  37. * Add the new config variable to Documentation/config/advice.txt.
  38. * Call advise_if_enabled to print your advice.
  39. */
  40. enum advice_type {
  41. ADVICE_ADD_EMBEDDED_REPO,
  42. ADVICE_AM_WORK_DIR,
  43. ADVICE_CHECKOUT_AMBIGUOUS_REMOTE_BRANCH_NAME,
  44. ADVICE_COMMIT_BEFORE_MERGE,
  45. ADVICE_DETACHED_HEAD,
  46. ADVICE_FETCH_SHOW_FORCED_UPDATES,
  47. ADVICE_GRAFT_FILE_DEPRECATED,
  48. ADVICE_IGNORED_HOOK,
  49. ADVICE_IMPLICIT_IDENTITY,
  50. ADVICE_NESTED_TAG,
  51. ADVICE_OBJECT_NAME_WARNING,
  52. ADVICE_PUSH_ALREADY_EXISTS,
  53. ADVICE_PUSH_FETCH_FIRST,
  54. ADVICE_PUSH_NEEDS_FORCE,
  55. ADVICE_PUSH_NON_FF_CURRENT,
  56. ADVICE_PUSH_NON_FF_MATCHING,
  57. ADVICE_PUSH_UNQUALIFIED_REF_NAME,
  58. ADVICE_PUSH_UPDATE_REJECTED_ALIAS,
  59. ADVICE_PUSH_UPDATE_REJECTED,
  60. ADVICE_RESET_QUIET_WARNING,
  61. ADVICE_RESOLVE_CONFLICT,
  62. ADVICE_RM_HINTS,
  63. ADVICE_SEQUENCER_IN_USE,
  64. ADVICE_SET_UPSTREAM_FAILURE,
  65. ADVICE_STATUS_AHEAD_BEHIND_WARNING,
  66. ADVICE_STATUS_HINTS,
  67. ADVICE_STATUS_U_OPTION,
  68. ADVICE_SUBMODULE_ALTERNATE_ERROR_STRATEGY_DIE,
  69. ADVICE_WAITING_FOR_EDITOR,
  70. };
  71. int git_default_advice_config(const char *var, const char *value);
  72. __attribute__((format (printf, 1, 2)))
  73. void advise(const char *advice, ...);
  74. /**
  75. * Checks if advice type is enabled (can be printed to the user).
  76. * Should be called before advise().
  77. */
  78. int advice_enabled(enum advice_type type);
  79. /**
  80. * Checks the visibility of the advice before printing.
  81. */
  82. void advise_if_enabled(enum advice_type type, const char *advice, ...);
  83. int error_resolve_conflict(const char *me);
  84. void NORETURN die_resolve_conflict(const char *me);
  85. void NORETURN die_conclude_merge(void);
  86. void detach_advice(const char *new_name);
  87. #endif /* ADVICE_H */