doc: rewrite description for rev-parse --short
[git/git-svn.git] / wt-status.h
blob6018c627b1e40e5c36d0c0c12eff1f262cb439b4
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 show_branch;
80 int hints;
82 enum wt_status_format status_format;
83 unsigned char sha1_commit[GIT_MAX_RAWSZ]; /* when not Initial */
85 /* These are computed during processing of the individual sections */
86 int commitable;
87 int workdir_dirty;
88 const char *index_file;
89 FILE *fp;
90 const char *prefix;
91 struct string_list change;
92 struct string_list untracked;
93 struct string_list ignored;
94 uint32_t untracked_in_ms;
97 struct wt_status_state {
98 int merge_in_progress;
99 int am_in_progress;
100 int am_empty_patch;
101 int rebase_in_progress;
102 int rebase_interactive_in_progress;
103 int cherry_pick_in_progress;
104 int bisect_in_progress;
105 int revert_in_progress;
106 int detached_at;
107 char *branch;
108 char *onto;
109 char *detached_from;
110 unsigned char detached_sha1[20];
111 unsigned char revert_head_sha1[20];
112 unsigned char cherry_pick_head_sha1[20];
115 void wt_status_truncate_message_at_cut_line(struct strbuf *);
116 void wt_status_add_cut_line(FILE *fp);
117 void wt_status_prepare(struct wt_status *s);
118 void wt_status_print(struct wt_status *s);
119 void wt_status_collect(struct wt_status *s);
120 void wt_status_get_state(struct wt_status_state *state, int get_detached_from);
121 int wt_status_check_rebase(const struct worktree *wt,
122 struct wt_status_state *state);
123 int wt_status_check_bisect(const struct worktree *wt,
124 struct wt_status_state *state);
126 __attribute__((format (printf, 3, 4)))
127 void status_printf_ln(struct wt_status *s, const char *color, const char *fmt, ...);
128 __attribute__((format (printf, 3, 4)))
129 void status_printf(struct wt_status *s, const char *color, const char *fmt, ...);
131 /* The following functions expect that the caller took care of reading the index. */
132 int has_unstaged_changes(int ignore_submodules);
133 int has_uncommitted_changes(int ignore_submodules);
134 int require_clean_work_tree(const char *action, const char *hint,
135 int ignore_submodules, int gently);
137 #endif /* STATUS_H */