X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=wt-status.h;h=682b4c8f7da2c58f741a958f6488a48fd7b483b4;hb=d3f2475c01d9e90dbadacbe2c35854f6d11e6409;hp=78add09bd67c727babb61cd1eaa773bcd0c6e55e;hpb=77f143bf3e218857ec8e5244d7e862e8e0c1a041;p=git.git diff --git a/wt-status.h b/wt-status.h index 78add09bd..682b4c8f7 100644 --- a/wt-status.h +++ b/wt-status.h @@ -2,13 +2,20 @@ #define STATUS_H #include +#include "string-list.h" +#include "color.h" enum color_wt_status { - WT_STATUS_HEADER, + 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, + WT_STATUS_ONBRANCH, + WT_STATUS_MAXSLOT }; enum untracked_status_type { @@ -16,29 +23,63 @@ enum untracked_status_type { SHOW_NORMAL_UNTRACKED_FILES, SHOW_ALL_UNTRACKED_FILES }; -extern enum untracked_status_type show_untracked_files; + +/* from where does this commit originate */ +enum commit_whence { + FROM_COMMIT, /* normal */ + FROM_MERGE, /* commit came from merge */ + FROM_CHERRY_PICK /* commit came from cherry-pick */ +}; + +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 untracked; + enum commit_whence whence; 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_MAXSLOT][COLOR_MAXLEN]; + /* These are computed during processing of the individual sections */ int commitable; int workdir_dirty; - int workdir_untracked; const char *index_file; FILE *fp; const char *prefix; + struct string_list change; + struct string_list untracked; + struct string_list ignored; }; -int git_status_config(const char *var, const char *value, void *cb); -extern int wt_status_use_color; -extern int wt_status_relative_paths; 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); + +void status_printf_ln(struct wt_status *s, const char *color, const char *fmt, ...) + ; +void status_printf(struct wt_status *s, const char *color, const char *fmt, ...) + ; +void status_printf_more(struct wt_status *s, const char *color, const char *fmt, ...) + __attribute__((format(printf, 3, 4))); #endif /* STATUS_H */