gitweb: Add git_merge sub
[git/gsoc2010-gitweb.git] / wt-status.h
blob4cd74c4b32f51dbe575b0a04a894a520df79e9bf
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,
15 WT_STATUS_LOCAL_BRANCH,
16 WT_STATUS_REMOTE_BRANCH
19 enum untracked_status_type {
20 SHOW_NO_UNTRACKED_FILES,
21 SHOW_NORMAL_UNTRACKED_FILES,
22 SHOW_ALL_UNTRACKED_FILES
25 struct wt_status_change_data {
26 int worktree_status;
27 int index_status;
28 int stagemask;
29 char *head_path;
30 unsigned dirty_submodule : 2;
31 unsigned new_submodule_commits : 1;
34 struct wt_status {
35 int is_initial;
36 char *branch;
37 const char *reference;
38 const char **pathspec;
39 int verbose;
40 int amend;
41 int in_merge;
42 int nowarn;
43 int use_color;
44 int relative_paths;
45 int submodule_summary;
46 int show_ignored_files;
47 enum untracked_status_type show_untracked_files;
48 char color_palette[WT_STATUS_REMOTE_BRANCH+1][COLOR_MAXLEN];
50 /* These are computed during processing of the individual sections */
51 int commitable;
52 int workdir_dirty;
53 const char *index_file;
54 FILE *fp;
55 const char *prefix;
56 struct string_list change;
57 struct string_list untracked;
58 struct string_list ignored;
61 void wt_status_prepare(struct wt_status *s);
62 void wt_status_print(struct wt_status *s);
63 void wt_status_collect(struct wt_status *s);
65 void wt_shortstatus_print(struct wt_status *s, int null_termination, int show_branch);
66 void wt_porcelain_print(struct wt_status *s, int null_termination);
68 #endif /* STATUS_H */