merge-recursive: do not look at the index during recursive merge
[git.git] / wt-status.h
blob64f4d33ea183c1a6e700f1f6667b83f0e904773e
1 #ifndef STATUS_H
2 #define STATUS_H
4 #include <stdio.h>
5 #include "string-list.h"
6 #include "color.h"
7 #include "pathspec.h"
9 struct worktree;
11 enum color_wt_status {
12 WT_STATUS_HEADER = 0,
13 WT_STATUS_UPDATED,
14 WT_STATUS_CHANGED,
15 WT_STATUS_UNTRACKED,
16 WT_STATUS_NOBRANCH,
17 WT_STATUS_UNMERGED,
18 WT_STATUS_LOCAL_BRANCH,
19 WT_STATUS_REMOTE_BRANCH,
20 WT_STATUS_ONBRANCH,
21 WT_STATUS_MAXSLOT
24 enum untracked_status_type {
25 SHOW_NO_UNTRACKED_FILES,
26 SHOW_NORMAL_UNTRACKED_FILES,
27 SHOW_ALL_UNTRACKED_FILES
30 /* from where does this commit originate */
31 enum commit_whence {
32 FROM_COMMIT, /* normal */
33 FROM_MERGE, /* commit came from merge */
34 FROM_CHERRY_PICK /* commit came from cherry-pick */
37 struct wt_status_change_data {
38 int worktree_status;
39 int index_status;
40 int stagemask;
41 int score;
42 int mode_head, mode_index, mode_worktree;
43 struct object_id oid_head, oid_index;
44 char *head_path;
45 unsigned dirty_submodule : 2;
46 unsigned new_submodule_commits : 1;
49 enum wt_status_format {
50 STATUS_FORMAT_NONE = 0,
51 STATUS_FORMAT_LONG,
52 STATUS_FORMAT_SHORT,
53 STATUS_FORMAT_PORCELAIN,
54 STATUS_FORMAT_PORCELAIN_V2,
56 STATUS_FORMAT_UNSPECIFIED
59 struct wt_status {
60 int is_initial;
61 char *branch;
62 const char *reference;
63 struct pathspec pathspec;
64 int verbose;
65 int amend;
66 enum commit_whence whence;
67 int nowarn;
68 int use_color;
69 int no_gettext;
70 int display_comment_prefix;
71 int relative_paths;
72 int submodule_summary;
73 int show_ignored_files;
74 enum untracked_status_type show_untracked_files;
75 const char *ignore_submodule_arg;
76 char color_palette[WT_STATUS_MAXSLOT][COLOR_MAXLEN];
77 unsigned colopts;
78 int null_termination;
79 int commit_template;
80 int show_branch;
81 int show_stash;
82 int hints;
84 enum wt_status_format status_format;
85 unsigned char sha1_commit[GIT_MAX_RAWSZ]; /* when not Initial */
87 /* These are computed during processing of the individual sections */
88 int commitable;
89 int workdir_dirty;
90 const char *index_file;
91 FILE *fp;
92 const char *prefix;
93 struct string_list change;
94 struct string_list untracked;
95 struct string_list ignored;
96 uint32_t untracked_in_ms;
99 struct wt_status_state {
100 int merge_in_progress;
101 int am_in_progress;
102 int am_empty_patch;
103 int rebase_in_progress;
104 int rebase_interactive_in_progress;
105 int cherry_pick_in_progress;
106 int bisect_in_progress;
107 int revert_in_progress;
108 int detached_at;
109 char *branch;
110 char *onto;
111 char *detached_from;
112 unsigned char detached_sha1[20];
113 unsigned char revert_head_sha1[20];
114 unsigned char cherry_pick_head_sha1[20];
117 size_t wt_status_locate_end(const char *s, size_t len);
118 void wt_status_add_cut_line(FILE *fp);
119 void wt_status_prepare(struct wt_status *s);
120 void wt_status_print(struct wt_status *s);
121 void wt_status_collect(struct wt_status *s);
122 void wt_status_get_state(struct wt_status_state *state, int get_detached_from);
123 int wt_status_check_rebase(const struct worktree *wt,
124 struct wt_status_state *state);
125 int wt_status_check_bisect(const struct worktree *wt,
126 struct wt_status_state *state);
128 __attribute__((format (printf, 3, 4)))
129 void status_printf_ln(struct wt_status *s, const char *color, const char *fmt, ...);
130 __attribute__((format (printf, 3, 4)))
131 void status_printf(struct wt_status *s, const char *color, const char *fmt, ...);
133 /* The following functions expect that the caller took care of reading the index. */
134 int has_unstaged_changes(int ignore_submodules);
135 int has_uncommitted_changes(int ignore_submodules);
136 int require_clean_work_tree(const char *action, const char *hint,
137 int ignore_submodules, int gently);
139 #endif /* STATUS_H */