projects
/
git.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge branch 'ml/cvsserver' into next
[git.git]
/
apply.c
diff --git
a/apply.c
b/apply.c
index
a5cdd8e
..
9deb206
100644
(file)
--- a/
apply.c
+++ b/
apply.c
@@
-39,7
+39,7
@@
static enum whitespace_eol {
warn_on_whitespace,
error_on_whitespace,
strip_whitespace,
warn_on_whitespace,
error_on_whitespace,
strip_whitespace,
-} new_whitespace =
nowar
n_whitespace;
+} new_whitespace =
warn_o
n_whitespace;
static int whitespace_error = 0;
static int squelch_whitespace_errors = 5;
static int applied_after_stripping = 0;
static int whitespace_error = 0;
static int squelch_whitespace_errors = 5;
static int applied_after_stripping = 0;
@@
-48,13
+48,17
@@
static const char *patch_input_file = NULL;
static void parse_whitespace_option(const char *option)
{
if (!option) {
static void parse_whitespace_option(const char *option)
{
if (!option) {
- new_whitespace =
nowar
n_whitespace;
+ new_whitespace =
warn_o
n_whitespace;
return;
}
if (!strcmp(option, "warn")) {
new_whitespace = warn_on_whitespace;
return;
}
return;
}
if (!strcmp(option, "warn")) {
new_whitespace = warn_on_whitespace;
return;
}
+ if (!strcmp(option, "nowarn")) {
+ new_whitespace = nowarn_whitespace;
+ return;
+ }
if (!strcmp(option, "error")) {
new_whitespace = error_on_whitespace;
return;
if (!strcmp(option, "error")) {
new_whitespace = error_on_whitespace;
return;
@@
-71,6
+75,15
@@
static void parse_whitespace_option(const char *option)
die("unrecognized whitespace option '%s'", option);
}
die("unrecognized whitespace option '%s'", option);
}
+static void set_default_whitespace_mode(const char *whitespace_option)
+{
+ if (!whitespace_option && !apply_default_whitespace) {
+ new_whitespace = (apply
+ ? warn_on_whitespace
+ : nowarn_whitespace);
+ }
+}
+
/*
* For "diff-stat" like behaviour, we keep track of the biggest change
* we've seen, and the longest filename. That allows us to do simple
/*
* For "diff-stat" like behaviour, we keep track of the biggest change
* we've seen, and the longest filename. That allows us to do simple
@@
-1951,9
+1964,11
@@
int main(int argc, char **argv)
if (fd < 0)
usage(apply_usage);
read_stdin = 0;
if (fd < 0)
usage(apply_usage);
read_stdin = 0;
+ set_default_whitespace_mode(whitespace_option);
apply_patch(fd, arg);
close(fd);
}
apply_patch(fd, arg);
close(fd);
}
+ set_default_whitespace_mode(whitespace_option);
if (read_stdin)
apply_patch(0, "<stdin>");
if (whitespace_error) {
if (read_stdin)
apply_patch(0, "<stdin>");
if (whitespace_error) {