Add support for ruby commands
[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
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,
15         WT_STATUS_LOCAL_BRANCH,
16         WT_STATUS_REMOTE_BRANCH,
17         WT_STATUS_ONBRANCH,
18         WT_STATUS_MAXSLOT
19 };
20
21 enum untracked_status_type {
22         SHOW_NO_UNTRACKED_FILES,
23         SHOW_NORMAL_UNTRACKED_FILES,
24         SHOW_ALL_UNTRACKED_FILES
25 };
26
27 /* from where does this commit originate */
28 enum commit_whence {
29         FROM_COMMIT,     /* normal */
30         FROM_MERGE,      /* commit came from merge */
31         FROM_CHERRY_PICK /* commit came from cherry-pick */
32 };
33
34 struct wt_status_change_data {
35         int worktree_status;
36         int index_status;
37         int stagemask;
38         char *head_path;
39         unsigned dirty_submodule       : 2;
40         unsigned new_submodule_commits : 1;
41 };
42
43 struct wt_status {
44         int is_initial;
45         char *branch;
46         const char *reference;
47         struct pathspec pathspec;
48         int verbose;
49         int amend;
50         enum commit_whence whence;
51         int nowarn;
52         int use_color;
53         int no_gettext;
54         int display_comment_prefix;
55         int relative_paths;
56         int submodule_summary;
57         int show_ignored_files;
58         enum untracked_status_type show_untracked_files;
59         const char *ignore_submodule_arg;
60         char color_palette[WT_STATUS_MAXSLOT][COLOR_MAXLEN];
61         unsigned colopts;
62         int null_termination;
63         int show_branch;
64         int hints;
65
66         /* These are computed during processing of the individual sections */
67         int commitable;
68         int workdir_dirty;
69         const char *index_file;
70         FILE *fp;
71         const char *prefix;
72         struct string_list change;
73         struct string_list untracked;
74         struct string_list ignored;
75         uint32_t untracked_in_ms;
76 };
77
78 struct wt_status_state {
79         int merge_in_progress;
80         int am_in_progress;
81         int am_empty_patch;
82         int rebase_in_progress;
83         int rebase_interactive_in_progress;
84         int cherry_pick_in_progress;
85         int bisect_in_progress;
86         int revert_in_progress;
87         int detached_at;
88         char *branch;
89         char *onto;
90         char *detached_from;
91         unsigned char detached_sha1[20];
92         unsigned char revert_head_sha1[20];
93         unsigned char cherry_pick_head_sha1[20];
94 };
95
96 void wt_status_truncate_message_at_cut_line(struct strbuf *);
97 void wt_status_add_cut_line(FILE *fp);
98 void wt_status_prepare(struct wt_status *s);
99 void wt_status_print(struct wt_status *s);
100 void wt_status_collect(struct wt_status *s);
101 void wt_status_get_state(struct wt_status_state *state, int get_detached_from);
102
103 void wt_shortstatus_print(struct wt_status *s);
104 void wt_porcelain_print(struct wt_status *s);
105
106 __attribute__((format (printf, 3, 4)))
107 void status_printf_ln(struct wt_status *s, const char *color, const char *fmt, ...);
108 __attribute__((format (printf, 3, 4)))
109 void status_printf(struct wt_status *s, const char *color, const char *fmt, ...);
110
111 #endif /* STATUS_H */