merge-recursive: take advantage of hardcoded empty tree
[git/jrn.git] / wt-status.h
blob1093e65ae00e60c171c740d06628705cfcfb68c2
1 #ifndef STATUS_H
2 #define STATUS_H
4 #include <stdio.h>
5 #include "string-list.h"
6 #include "color.h"
8 enum color_wt_status {
9 WT_STATUS_HEADER = 0,
10 WT_STATUS_UPDATED,
11 WT_STATUS_CHANGED,
12 WT_STATUS_UNTRACKED,
13 WT_STATUS_NOBRANCH,
14 WT_STATUS_UNMERGED,
17 enum untracked_status_type {
18 SHOW_NO_UNTRACKED_FILES,
19 SHOW_NORMAL_UNTRACKED_FILES,
20 SHOW_ALL_UNTRACKED_FILES
23 struct wt_status_change_data {
24 int worktree_status;
25 int index_status;
26 int stagemask;
27 char *head_path;
28 unsigned dirty_submodule : 2;
29 unsigned new_submodule_commits : 1;
32 struct wt_status {
33 int is_initial;
34 char *branch;
35 const char *reference;
36 const char **pathspec;
37 int verbose;
38 int amend;
39 int in_merge;
40 int nowarn;
41 int use_color;
42 int relative_paths;
43 int submodule_summary;
44 int show_ignored_files;
45 enum untracked_status_type show_untracked_files;
46 char color_palette[WT_STATUS_UNMERGED+1][COLOR_MAXLEN];
48 /* These are computed during processing of the individual sections */
49 int commitable;
50 int workdir_dirty;
51 const char *index_file;
52 FILE *fp;
53 const char *prefix;
54 struct string_list change;
55 struct string_list untracked;
56 struct string_list ignored;
59 void wt_status_prepare(struct wt_status *s);
60 void wt_status_print(struct wt_status *s);
61 void wt_status_collect(struct wt_status *s);
63 void wt_shortstatus_print(struct wt_status *s, int null_termination);
64 void wt_porcelain_print(struct wt_status *s, int null_termination);
66 #endif /* STATUS_H */