wt-status.hon commit read_directory_recursive(): refactor handling of a single path into a separate function (53cc535)
   1#ifndef STATUS_H
   2#define STATUS_H
   3
   4#include <stdio.h>
   5#include "string-list.h"
   6#include "color.h"
   7
   8enum 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};
  16
  17enum untracked_status_type {
  18        SHOW_NO_UNTRACKED_FILES,
  19        SHOW_NORMAL_UNTRACKED_FILES,
  20        SHOW_ALL_UNTRACKED_FILES
  21};
  22
  23struct wt_status_change_data {
  24        int worktree_status;
  25        int index_status;
  26        int stagemask;
  27        char *head_path;
  28};
  29
  30struct wt_status {
  31        int is_initial;
  32        char *branch;
  33        const char *reference;
  34        const char **pathspec;
  35        int verbose;
  36        int amend;
  37        int in_merge;
  38        int nowarn;
  39        int use_color;
  40        int relative_paths;
  41        int submodule_summary;
  42        enum untracked_status_type show_untracked_files;
  43        char color_palette[WT_STATUS_UNMERGED+1][COLOR_MAXLEN];
  44
  45        /* These are computed during processing of the individual sections */
  46        int commitable;
  47        int workdir_dirty;
  48        int workdir_untracked;
  49        const char *index_file;
  50        FILE *fp;
  51        const char *prefix;
  52        struct string_list change;
  53        struct string_list untracked;
  54};
  55
  56void wt_status_prepare(struct wt_status *s);
  57void wt_status_print(struct wt_status *s);
  58void wt_status_collect(struct wt_status *s);
  59
  60void wt_shortstatus_print(struct wt_status *s, int null_termination);
  61void wt_porcelain_print(struct wt_status *s, int null_termination);
  62
  63#endif /* STATUS_H */