4 enum apply_ws_error_action {
 
  11 enum apply_ws_ignore {
 
  16 enum apply_verbosity {
 
  17         verbosity_silent = -1,
 
  23  * We need to keep track of how symlinks in the preimage are
 
  24  * manipulated by the patches.  A patch to add a/b/c where a/b
 
  25  * is a symlink should not be allowed to affect the directory
 
  26  * the symlink points at, but if the same patch removes a/b,
 
  27  * it is perfectly fine, as the patch removes a/b to make room
 
  28  * to create a directory a/b so that a/b/c can be created.
 
  30  * See also "struct string_list symlink_changes" in "struct
 
  33 #define APPLY_SYMLINK_GOES_AWAY 01
 
  34 #define APPLY_SYMLINK_IN_RESULT 02
 
  40         struct lock_file lock_file;
 
  42         /* These control what gets looked at and modified */
 
  43         int apply; /* this is not a dry-run */
 
  44         int cached; /* apply to the index only */
 
  45         int check; /* preimage must match working tree, don't actually apply */
 
  46         int check_index; /* preimage must match the indexed version */
 
  47         int update_index; /* check_index && apply */
 
  49         /* These control cosmetic aspect of the output */
 
  50         int diffstat; /* just show a diffstat, and don't actually apply */
 
  51         int numstat; /* just show a numeric diffstat, and don't actually apply */
 
  52         int summary; /* just report creation, deletion, etc, and don't actually apply */
 
  54         /* These boolean parameters control how the apply is done */
 
  57         int apply_with_reject;
 
  63         /* Other non boolean parameters */
 
  64         const char *index_file;
 
  65         enum apply_verbosity apply_verbosity;
 
  66         const char *fake_ancestor;
 
  67         const char *patch_input_file;
 
  72         unsigned int p_context;
 
  74         /* Exclude and include path parameters */
 
  75         struct string_list limit_by_name;
 
  78         /* Various "current state" */
 
  79         int linenr; /* current line number */
 
  80         struct string_list symlink_changes; /* we have to track symlinks */
 
  83          * For "diff-stat" like behaviour, we keep track of the biggest change
 
  84          * we've seen, and the longest filename. That allows us to do simple
 
  91          * Records filenames that have been touched, in order to handle
 
  92          * the case where more than one patches touch the same file.
 
  94         struct string_list fn_table;
 
  97          * This is to save reporting routines before using
 
  98          * set_error_routine() or set_warn_routine() to install muting
 
  99          * routines when in verbosity_silent mode.
 
 101         void (*saved_error_routine)(const char *err, va_list params);
 
 102         void (*saved_warn_routine)(const char *warn, va_list params);
 
 104         /* These control whitespace errors */
 
 105         enum apply_ws_error_action ws_error_action;
 
 106         enum apply_ws_ignore ws_ignore_action;
 
 107         const char *whitespace_option;
 
 108         int whitespace_error;
 
 109         int squelch_whitespace_errors;
 
 110         int applied_after_fixing_ws;
 
 113 extern int apply_parse_options(int argc, const char **argv,
 
 114                                struct apply_state *state,
 
 115                                int *force_apply, int *options,
 
 116                                const char * const *apply_usage);
 
 117 extern int init_apply_state(struct apply_state *state,
 
 119 extern void clear_apply_state(struct apply_state *state);
 
 120 extern int check_apply_state(struct apply_state *state, int force_apply);
 
 123  * Some aspects of the apply behavior are controlled by the following
 
 124  * bits in the "options" parameter passed to apply_all_patches().
 
 126 #define APPLY_OPT_INACCURATE_EOF        (1<<0) /* accept inaccurate eof */
 
 127 #define APPLY_OPT_RECOUNT               (1<<1) /* accept inaccurate line count */
 
 129 extern int apply_all_patches(struct apply_state *state,