diff options
Diffstat (limited to 'builtin/add.c')
| -rw-r--r-- | builtin/add.c | 8 | 
1 files changed, 6 insertions, 2 deletions
| diff --git a/builtin/add.c b/builtin/add.c index b79336d712..89dce56a24 100644 --- a/builtin/add.c +++ b/builtin/add.c @@ -281,7 +281,7 @@ static int edit_patch(int argc, const char **argv, const char *prefix)  	argc = setup_revisions(argc, argv, &rev, NULL);  	rev.diffopt.output_format = DIFF_FORMAT_PATCH;  	DIFF_OPT_SET(&rev.diffopt, IGNORE_DIRTY_SUBMODULES); -	out = open(file, O_CREAT | O_WRONLY, 0644); +	out = open(file, O_CREAT | O_WRONLY, 0666);  	if (out < 0)  		die (_("Could not open '%s' for writing."), file);  	rev.diffopt.file = xfdopen(out, "w"); @@ -443,6 +443,9 @@ int cmd_add(int argc, const char **argv, const char *prefix)  	if (pathspec) {  		int i; +		struct path_exclude_check check; + +		path_exclude_check_init(&check, &dir);  		if (!seen)  			seen = find_used_pathspec(pathspec);  		for (i = 0; pathspec[i]; i++) { @@ -450,7 +453,7 @@ int cmd_add(int argc, const char **argv, const char *prefix)  			    && !file_exists(pathspec[i])) {  				if (ignore_missing) {  					int dtype = DT_UNKNOWN; -					if (excluded(&dir, pathspec[i], &dtype)) +					if (path_excluded(&check, pathspec[i], -1, &dtype))  						dir_add_ignored(&dir, pathspec[i], strlen(pathspec[i]));  				} else  					die(_("pathspec '%s' did not match any files"), @@ -458,6 +461,7 @@ int cmd_add(int argc, const char **argv, const char *prefix)  			}  		}  		free(seen); +		path_exclude_check_clear(&check);  	}  	plug_bulk_checkin(); | 
