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