diff options
Diffstat (limited to 'wt-status.h')
-rw-r--r-- | wt-status.h | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/wt-status.h b/wt-status.h new file mode 100644 index 0000000..9df9c9f --- /dev/null +++ b/wt-status.h @@ -0,0 +1,69 @@ +#ifndef STATUS_H +#define STATUS_H + +#include <stdio.h> +#include "string-list.h" +#include "color.h" + +enum color_wt_status { + WT_STATUS_HEADER = 0, + WT_STATUS_UPDATED, + WT_STATUS_CHANGED, + WT_STATUS_UNTRACKED, + WT_STATUS_NOBRANCH, + WT_STATUS_UNMERGED, + WT_STATUS_LOCAL_BRANCH, + WT_STATUS_REMOTE_BRANCH +}; + +enum untracked_status_type { + SHOW_NO_UNTRACKED_FILES, + SHOW_NORMAL_UNTRACKED_FILES, + SHOW_ALL_UNTRACKED_FILES +}; + +struct wt_status_change_data { + int worktree_status; + int index_status; + int stagemask; + char *head_path; + unsigned dirty_submodule : 2; + unsigned new_submodule_commits : 1; +}; + +struct wt_status { + int is_initial; + char *branch; + const char *reference; + const char **pathspec; + int verbose; + int amend; + int in_merge; + int nowarn; + int use_color; + int relative_paths; + int submodule_summary; + int show_ignored_files; + enum untracked_status_type show_untracked_files; + const char *ignore_submodule_arg; + char color_palette[WT_STATUS_REMOTE_BRANCH+1][COLOR_MAXLEN]; + + /* These are computed during processing of the individual sections */ + int commitable; + int workdir_dirty; + const char *index_file; + FILE *fp; + const char *prefix; + struct string_list change; + struct string_list untracked; + struct string_list ignored; +}; + +void wt_status_prepare(struct wt_status *s); +void wt_status_print(struct wt_status *s); +void wt_status_collect(struct wt_status *s); + +void wt_shortstatus_print(struct wt_status *s, int null_termination, int show_branch); +void wt_porcelain_print(struct wt_status *s, int null_termination); + +#endif /* STATUS_H */ |