docs/pretty-formats: stress that %- removes all preceding line-feeds
[git] / wt-status.h
1 #ifndef STATUS_H
2 #define STATUS_H
3
4 #include <stdio.h>
5 #include "string-list.h"
6 #include "color.h"
7 #include "pathspec.h"
8
9 struct worktree;
10
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
22 };
23
24 enum untracked_status_type {
25         SHOW_NO_UNTRACKED_FILES,
26         SHOW_NORMAL_UNTRACKED_FILES,
27         SHOW_ALL_UNTRACKED_FILES
28 };
29
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 */
35 };
36
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;
47 };
48
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,
55
56         STATUS_FORMAT_UNSPECIFIED
57 };
58
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;
81
82         enum wt_status_format status_format;
83         unsigned char sha1_commit[GIT_SHA1_RAWSZ]; /* when not Initial */
84
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;
95 };
96
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];
113 };
114
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);
125
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, ...);
130
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);
136
137 #endif /* STATUS_H */