diff options
| author | Russell Belfer <rb@github.com> | 2012-10-24 17:32:50 -0700 | 
|---|---|---|
| committer | Russell Belfer <rb@github.com> | 2012-11-09 13:52:06 -0800 | 
| commit | 331e7de9004db5909edd1057db88f63a53dd2d3f (patch) | |
| tree | 8919f7b5791a3cff372f0099870b842276f39b54 | |
| parent | 8a328cf442237f65d58ad779d775c77a7c462df5 (diff) | |
| download | libgit2-331e7de9004db5909edd1057db88f63a53dd2d3f.tar.gz | |
Extensions to rmdir and mkdir utilities
* Rework GIT_DIRREMOVAL values to GIT_RMDIR flags, allowing
  combinations of flags
* Add GIT_RMDIR_EMPTY_PARENTS flag to remove parent dirs that
  are left empty after removal
* Add GIT_MKDIR_VERIFY_DIR to give an error if item is a file,
  not a dir (previously an EEXISTS error was ignored, even for
  files) and enable this flag for git_futils_mkpath2file call
* Improve accuracy of error messages from git_futils_mkdir
| -rw-r--r-- | src/checkout.c | 2 | ||||
| -rw-r--r-- | src/clone.c | 2 | ||||
| -rw-r--r-- | src/fileops.c | 136 | ||||
| -rw-r--r-- | src/fileops.h | 39 | ||||
| -rw-r--r-- | src/reflog.c | 2 | ||||
| -rw-r--r-- | src/refs.c | 13 | ||||
| -rw-r--r-- | tests-clar/core/copy.c | 8 | ||||
| -rw-r--r-- | tests-clar/core/mkdir.c | 14 | ||||
| -rw-r--r-- | tests-clar/core/rmdir.c | 42 | ||||
| -rw-r--r-- | tests-clar/object/blob/write.c | 4 | ||||
| -rw-r--r-- | tests-clar/repo/discover.c | 2 | ||||
| -rw-r--r-- | tests-clar/repo/open.c | 6 | ||||
| -rw-r--r-- | tests-clar/status/worktree.c | 6 | ||||
| -rw-r--r-- | tests-clar/submodule/status.c | 8 | 
14 files changed, 194 insertions, 90 deletions
| diff --git a/src/checkout.c b/src/checkout.c index e068e4f5f..b9a5399cc 100644 --- a/src/checkout.c +++ b/src/checkout.c @@ -213,7 +213,7 @@ static int checkout_remove_the_old(  		data->error = git_futils_rmdir_r(  			delta->new_file.path,  			git_repository_workdir(data->owner), -			GIT_DIRREMOVAL_FILES_AND_DIRS); +			GIT_RMDIR_REMOVE_FILES | GIT_RMDIR_EMPTY_PARENTS);  		data->completed_steps++;  		report_progress(data, delta->new_file.path); diff --git a/src/clone.c b/src/clone.c index 7352f5fb2..560d64c0d 100644 --- a/src/clone.c +++ b/src/clone.c @@ -338,7 +338,7 @@ static int clone_internal(  						fetch_progress_cb, fetch_progress_payload)) < 0) {  			/* Failed to fetch; clean up */  			git_repository_free(repo); -			git_futils_rmdir_r(path, NULL, GIT_DIRREMOVAL_FILES_AND_DIRS); +			git_futils_rmdir_r(path, NULL, GIT_RMDIR_REMOVE_FILES);  		} else {  			*out = repo;  			retcode = 0; diff --git a/src/fileops.c b/src/fileops.c index 2aceb112a..d2cbd046d 100644 --- a/src/fileops.c +++ b/src/fileops.c @@ -14,7 +14,8 @@  int git_futils_mkpath2file(const char *file_path, const mode_t mode)  {  	return git_futils_mkdir( -		file_path, NULL, mode, GIT_MKDIR_PATH | GIT_MKDIR_SKIP_LAST); +		file_path, NULL, mode, +		GIT_MKDIR_PATH | GIT_MKDIR_SKIP_LAST | GIT_MKDIR_VERIFY_DIR);  }  int git_futils_mktmp(git_buf *path_out, const char *filename) @@ -250,6 +251,7 @@ int git_futils_mkdir(  	mode_t mode,  	uint32_t flags)  { +	int error = -1;  	git_buf make_path = GIT_BUF_INIT;  	ssize_t root = 0;  	char lastch, *tail; @@ -297,12 +299,28 @@ int git_futils_mkdir(  		*tail = '\0';  		/* make directory */ -		if (p_mkdir(make_path.ptr, mode) < 0 && -			(errno != EEXIST || (flags & GIT_MKDIR_EXCL) != 0)) -		{ -			giterr_set(GITERR_OS, "Failed to make directory '%s'", -				make_path.ptr); -			goto fail; +		if (p_mkdir(make_path.ptr, mode) < 0) { +			if (errno == EEXIST) { +				if (!lastch && (flags & GIT_MKDIR_VERIFY_DIR) != 0) { +					if (!git_path_isdir(make_path.ptr)) { +						giterr_set( +							GITERR_OS, "Existing path is not a directory '%s'", +							make_path.ptr); +						error = GIT_ENOTFOUND; +						goto fail; +					} +				} +				if ((flags & GIT_MKDIR_EXCL) != 0) { +					giterr_set(GITERR_OS, "Directory already exists '%s'", +						make_path.ptr); +					error = GIT_EEXISTS; +					goto fail; +				} +			} else { +				giterr_set(GITERR_OS, "Failed to make directory '%s'", +					make_path.ptr); +				goto fail; +			}  		}  		/* chmod if requested */ @@ -324,7 +342,7 @@ int git_futils_mkdir(  fail:  	git_buf_free(&make_path); -	return -1; +	return error;  }  int git_futils_mkdir_r(const char *path, const char *base, const mode_t mode) @@ -332,57 +350,103 @@ int git_futils_mkdir_r(const char *path, const char *base, const mode_t mode)  	return git_futils_mkdir(path, base, mode, GIT_MKDIR_PATH);  } -static int _rmdir_recurs_foreach(void *opaque, git_buf *path) +typedef struct { +	uint32_t flags; +	int error; +} futils__rmdir_data; + +static int futils__error_cannot_rmdir(const char *path, const char *filemsg)  { -	git_directory_removal_type removal_type = *(git_directory_removal_type *)opaque; +	if (filemsg) +		giterr_set(GITERR_OS, "Could not remove directory. File '%s' %s", +				   path, filemsg); +	else +		giterr_set(GITERR_OS, "Could not remove directory '%s'", path); -	if (git_path_isdir(path->ptr) == true) { -		if (git_path_direach(path, _rmdir_recurs_foreach, opaque) < 0) -			return -1; +	return -1; +} -		if (p_rmdir(path->ptr) < 0) { -			if (removal_type == GIT_DIRREMOVAL_ONLY_EMPTY_DIRS && (errno == ENOTEMPTY || errno == EEXIST)) -				return 0; +static int futils__rmdir_recurs_foreach(void *opaque, git_buf *path) +{ +	futils__rmdir_data *data = opaque; -			giterr_set(GITERR_OS, "Could not remove directory '%s'", path->ptr); -			return -1; +	if (git_path_isdir(path->ptr) == true) { +		int error = git_path_direach(path, futils__rmdir_recurs_foreach, data); +		if (error < 0) +			return (error == GIT_EUSER) ? data->error : error; + +		data->error = p_rmdir(path->ptr); + +		if (data->error < 0) { +			if ((data->flags & GIT_RMDIR_SKIP_NONEMPTY) != 0 && +				(errno == ENOTEMPTY || errno == EEXIST)) +				data->error = 0; +			else +				futils__error_cannot_rmdir(path->ptr, NULL);  		} - -		return 0;  	} -	if (removal_type == GIT_DIRREMOVAL_FILES_AND_DIRS) { -		if (p_unlink(path->ptr) < 0) { -			giterr_set(GITERR_OS, "Could not remove directory.  File '%s' cannot be removed", path->ptr); -			return -1; -		} +	else if ((data->flags & GIT_RMDIR_REMOVE_FILES) != 0) { +		data->error = p_unlink(path->ptr); -		return 0; +		if (data->error < 0) +			futils__error_cannot_rmdir(path->ptr, "cannot be removed");  	} -	if (removal_type == GIT_DIRREMOVAL_EMPTY_HIERARCHY) { -		giterr_set(GITERR_OS, "Could not remove directory. File '%s' still present", path->ptr); -		return -1; +	else if ((data->flags & GIT_RMDIR_SKIP_NONEMPTY) == 0) { +		data->error = futils__error_cannot_rmdir(path->ptr, "still present");  	} -	return 0; +	return data->error; +} + +static int futils__rmdir_empty_parent(void *opaque, git_buf *path) +{ +	int error = p_rmdir(path->ptr); + +	GIT_UNUSED(opaque); + +	if (error) { +		int en = errno; + +		if (en == ENOENT || en == ENOTDIR) { +			giterr_clear(); +			error = 0; +		} else if (en == ENOTEMPTY || en == EEXIST) { +			giterr_clear(); +			error = GIT_ITEROVER; +		} else { +			futils__error_cannot_rmdir(path->ptr, NULL); +		} +	} + +	return error;  }  int git_futils_rmdir_r( -	const char *path, const char *base, git_directory_removal_type removal_type) +	const char *path, const char *base, uint32_t flags)  {  	int error;  	git_buf fullpath = GIT_BUF_INIT; - -	assert(removal_type == GIT_DIRREMOVAL_EMPTY_HIERARCHY -		|| removal_type == GIT_DIRREMOVAL_FILES_AND_DIRS -		|| removal_type == GIT_DIRREMOVAL_ONLY_EMPTY_DIRS); +	futils__rmdir_data data;  	/* build path and find "root" where we should start calling mkdir */  	if (git_path_join_unrooted(&fullpath, path, base, NULL) < 0)  		return -1; -	error = _rmdir_recurs_foreach(&removal_type, &fullpath); +	data.flags = flags; +	data.error = 0; + +	error = futils__rmdir_recurs_foreach(&data, &fullpath); + +	/* remove now-empty parents if requested */ +	if (!error && (flags & GIT_RMDIR_EMPTY_PARENTS) != 0) { +		error = git_path_walk_up( +			&fullpath, base, futils__rmdir_empty_parent, &data); + +		if (error == GIT_ITEROVER) +			error = 0; +	}  	git_buf_free(&fullpath); diff --git a/src/fileops.h b/src/fileops.h index 25e62c504..6952c463c 100644 --- a/src/fileops.h +++ b/src/fileops.h @@ -65,6 +65,7 @@ extern int git_futils_mkdir_r(const char *path, const char *base, const mode_t m   * * GIT_MKDIR_CHMOD says to chmod the final directory entry after creation   * * GIT_MKDIR_CHMOD_PATH says to chmod each directory component in the path   * * GIT_MKDIR_SKIP_LAST says to leave off the last element of the path + * * GIT_MKDIR_VERIFY_DIR says confirm final item is a dir, not just EEXIST   *   * Note that the chmod options will be executed even if the directory already   * exists, unless GIT_MKDIR_EXCL is given. @@ -74,7 +75,8 @@ typedef enum {  	GIT_MKDIR_PATH = 2,  	GIT_MKDIR_CHMOD = 4,  	GIT_MKDIR_CHMOD_PATH = 8, -	GIT_MKDIR_SKIP_LAST = 16 +	GIT_MKDIR_SKIP_LAST = 16, +	GIT_MKDIR_VERIFY_DIR = 32,  } git_futils_mkdir_flags;  /** @@ -98,27 +100,38 @@ extern int git_futils_mkdir(const char *path, const char *base, mode_t mode, uin   */  extern int git_futils_mkpath2file(const char *path, const mode_t mode); +/** + * Flags to pass to `git_futils_rmdir_r`. + * + * * GIT_RMDIR_EMPTY_HIERARCHY - the default; remove hierarchy of empty + *       dirs and generate error if any files are found. + * * GIT_RMDIR_REMOVE_FILES    - attempt to remove files in the hierarchy. + * * GIT_RMDIR_SKIP_NONEMPTY   - skip non-empty directories with no error. + * * GIT_RMDIR_EMPTY_PARENTS   - remove containing directories up to base + *       if removing this item leaves them empty + * + * The old values translate into the new as follows: + * + * * GIT_DIRREMOVAL_EMPTY_HIERARCHY == GIT_RMDIR_EMPTY_HIERARCHY + * * GIT_DIRREMOVAL_FILES_AND_DIRS  ~= GIT_RMDIR_REMOVE_FILES + * * GIT_DIRREMOVAL_ONLY_EMPTY_DIRS == GIT_RMDIR_SKIP_NONEMPTY + */  typedef enum { -	GIT_DIRREMOVAL_EMPTY_HIERARCHY = 0, -	GIT_DIRREMOVAL_FILES_AND_DIRS = 1, -	GIT_DIRREMOVAL_ONLY_EMPTY_DIRS = 2, -} git_directory_removal_type; +	GIT_RMDIR_EMPTY_HIERARCHY = 0, +	GIT_RMDIR_REMOVE_FILES    = (1 << 0), +	GIT_RMDIR_SKIP_NONEMPTY   = (1 << 1), +	GIT_RMDIR_EMPTY_PARENTS   = (1 << 2), +} git_futils_rmdir_flags;  /**   * Remove path and any files and directories beneath it.   *   * @param path Path to to top level directory to process.   * @param base Root for relative path. - * @param removal_type GIT_DIRREMOVAL_EMPTY_HIERARCHY to remove a hierarchy - *                     of empty directories (will fail if any file is found), - *                     GIT_DIRREMOVAL_FILES_AND_DIRS to remove a hierarchy of - *                     files and folders, - *                     GIT_DIRREMOVAL_ONLY_EMPTY_DIRS to only remove empty - *                     directories (no failure on file encounter). - * + * @param flags Combination of git_futils_rmdir_flags values   * @return 0 on success; -1 on error.   */ -extern int git_futils_rmdir_r(const char *path, const char *base, git_directory_removal_type removal_type); +extern int git_futils_rmdir_r(const char *path, const char *base, uint32_t flags);  /**   * Create and open a temporary file with a `_git2_` suffix. diff --git a/src/reflog.c b/src/reflog.c index 5d1465eca..0e333aa6f 100644 --- a/src/reflog.c +++ b/src/reflog.c @@ -378,7 +378,7 @@ int git_reflog_rename(git_reference *ref, const char *new_name)  		goto cleanup;  	if (git_path_isdir(git_buf_cstr(&new_path)) &&  -		(git_futils_rmdir_r(git_buf_cstr(&new_path), NULL, GIT_DIRREMOVAL_ONLY_EMPTY_DIRS) < 0)) +		(git_futils_rmdir_r(git_buf_cstr(&new_path), NULL, GIT_RMDIR_SKIP_NONEMPTY) < 0))  		goto cleanup;  	if (git_futils_mkpath2file(git_buf_cstr(&new_path), GIT_REFLOG_DIR_MODE) < 0) diff --git a/src/refs.c b/src/refs.c index bbf30ed9e..97c97563e 100644 --- a/src/refs.c +++ b/src/refs.c @@ -274,18 +274,15 @@ static int loose_write(git_reference *ref)  	git_buf ref_path = GIT_BUF_INIT;  	struct stat st; -	if (git_buf_joinpath(&ref_path, ref->owner->path_repository, ref->name) < 0) -		return -1; -  	/* Remove a possibly existing empty directory hierarchy  	 * which name would collide with the reference name  	 */ -	if (git_path_isdir(git_buf_cstr(&ref_path)) && -		git_futils_rmdir_r(git_buf_cstr(&ref_path), NULL, -			GIT_DIRREMOVAL_ONLY_EMPTY_DIRS) < 0) { -		git_buf_free(&ref_path); +	if (git_futils_rmdir_r(ref->name, ref->owner->path_repository, +		GIT_RMDIR_SKIP_NONEMPTY) < 0) +		return -1; + +	if (git_buf_joinpath(&ref_path, ref->owner->path_repository, ref->name) < 0)  		return -1; -	}  	if (git_filebuf_open(&file, ref_path.ptr, GIT_FILEBUF_FORCE) < 0) {  		git_buf_free(&ref_path); diff --git a/tests-clar/core/copy.c b/tests-clar/core/copy.c index d0b21f6ec..c0c59c056 100644 --- a/tests-clar/core/copy.c +++ b/tests-clar/core/copy.c @@ -41,7 +41,7 @@ void test_core_copy__file_in_dir(void)  	cl_assert(S_ISREG(st.st_mode));  	cl_assert(strlen(content) == (size_t)st.st_size); -	cl_git_pass(git_futils_rmdir_r("an_dir", NULL, GIT_DIRREMOVAL_FILES_AND_DIRS)); +	cl_git_pass(git_futils_rmdir_r("an_dir", NULL, GIT_RMDIR_REMOVE_FILES));  	cl_assert(!git_path_isdir("an_dir"));  } @@ -95,7 +95,7 @@ void test_core_copy__tree(void)  	cl_assert(S_ISLNK(st.st_mode));  #endif -	cl_git_pass(git_futils_rmdir_r("t1", NULL, GIT_DIRREMOVAL_FILES_AND_DIRS)); +	cl_git_pass(git_futils_rmdir_r("t1", NULL, GIT_RMDIR_REMOVE_FILES));  	cl_assert(!git_path_isdir("t1"));  	/* copy with empty dirs, no links, yes dotfiles, no overwrite */ @@ -119,8 +119,8 @@ void test_core_copy__tree(void)  	cl_git_fail(git_path_lstat("t2/c/d/l1", &st));  #endif -	cl_git_pass(git_futils_rmdir_r("t2", NULL, GIT_DIRREMOVAL_FILES_AND_DIRS)); +	cl_git_pass(git_futils_rmdir_r("t2", NULL, GIT_RMDIR_REMOVE_FILES));  	cl_assert(!git_path_isdir("t2")); -	cl_git_pass(git_futils_rmdir_r("src", NULL, GIT_DIRREMOVAL_FILES_AND_DIRS)); +	cl_git_pass(git_futils_rmdir_r("src", NULL, GIT_RMDIR_REMOVE_FILES));  } diff --git a/tests-clar/core/mkdir.c b/tests-clar/core/mkdir.c index e5dc6654b..1e50b4336 100644 --- a/tests-clar/core/mkdir.c +++ b/tests-clar/core/mkdir.c @@ -6,11 +6,11 @@  static void cleanup_basic_dirs(void *ref)  {  	GIT_UNUSED(ref); -	git_futils_rmdir_r("d0", NULL, GIT_DIRREMOVAL_EMPTY_HIERARCHY); -	git_futils_rmdir_r("d1", NULL, GIT_DIRREMOVAL_EMPTY_HIERARCHY); -	git_futils_rmdir_r("d2", NULL, GIT_DIRREMOVAL_EMPTY_HIERARCHY); -	git_futils_rmdir_r("d3", NULL, GIT_DIRREMOVAL_EMPTY_HIERARCHY); -	git_futils_rmdir_r("d4", NULL, GIT_DIRREMOVAL_EMPTY_HIERARCHY); +	git_futils_rmdir_r("d0", NULL, GIT_RMDIR_EMPTY_HIERARCHY); +	git_futils_rmdir_r("d1", NULL, GIT_RMDIR_EMPTY_HIERARCHY); +	git_futils_rmdir_r("d2", NULL, GIT_RMDIR_EMPTY_HIERARCHY); +	git_futils_rmdir_r("d3", NULL, GIT_RMDIR_EMPTY_HIERARCHY); +	git_futils_rmdir_r("d4", NULL, GIT_RMDIR_EMPTY_HIERARCHY);  }  void test_core_mkdir__basic(void) @@ -56,7 +56,7 @@ void test_core_mkdir__basic(void)  static void cleanup_basedir(void *ref)  {  	GIT_UNUSED(ref); -	git_futils_rmdir_r("base", NULL, GIT_DIRREMOVAL_EMPTY_HIERARCHY); +	git_futils_rmdir_r("base", NULL, GIT_RMDIR_EMPTY_HIERARCHY);  }  void test_core_mkdir__with_base(void) @@ -108,7 +108,7 @@ static void cleanup_chmod_root(void *ref)  		git__free(mode);  	} -	git_futils_rmdir_r("r", NULL, GIT_DIRREMOVAL_EMPTY_HIERARCHY); +	git_futils_rmdir_r("r", NULL, GIT_RMDIR_EMPTY_HIERARCHY);  }  static void check_mode(mode_t expected, mode_t actual) diff --git a/tests-clar/core/rmdir.c b/tests-clar/core/rmdir.c index 9ada8f426..f0b0bfa42 100644 --- a/tests-clar/core/rmdir.c +++ b/tests-clar/core/rmdir.c @@ -30,7 +30,7 @@ void test_core_rmdir__initialize(void)  /* make sure empty dir can be deleted recusively */  void test_core_rmdir__delete_recursive(void)  { -	cl_git_pass(git_futils_rmdir_r(empty_tmp_dir, NULL, GIT_DIRREMOVAL_EMPTY_HIERARCHY)); +	cl_git_pass(git_futils_rmdir_r(empty_tmp_dir, NULL, GIT_RMDIR_EMPTY_HIERARCHY));  }  /* make sure non-empty dir cannot be deleted recusively */ @@ -42,15 +42,15 @@ void test_core_rmdir__fail_to_delete_non_empty_dir(void)  	cl_git_mkfile(git_buf_cstr(&file), "dummy"); -	cl_git_fail(git_futils_rmdir_r(empty_tmp_dir, NULL, GIT_DIRREMOVAL_EMPTY_HIERARCHY)); +	cl_git_fail(git_futils_rmdir_r(empty_tmp_dir, NULL, GIT_RMDIR_EMPTY_HIERARCHY));  	cl_must_pass(p_unlink(file.ptr)); -	cl_git_pass(git_futils_rmdir_r(empty_tmp_dir, NULL, GIT_DIRREMOVAL_EMPTY_HIERARCHY)); +	cl_git_pass(git_futils_rmdir_r(empty_tmp_dir, NULL, GIT_RMDIR_EMPTY_HIERARCHY));  	git_buf_free(&file);  } -void test_core_rmdir__can_skip__non_empty_dir(void) +void test_core_rmdir__can_skip_non_empty_dir(void)  {  	git_buf file = GIT_BUF_INIT; @@ -58,11 +58,41 @@ void test_core_rmdir__can_skip__non_empty_dir(void)  	cl_git_mkfile(git_buf_cstr(&file), "dummy"); -	cl_git_pass(git_futils_rmdir_r(empty_tmp_dir, NULL, GIT_DIRREMOVAL_ONLY_EMPTY_DIRS)); +	cl_git_pass(git_futils_rmdir_r(empty_tmp_dir, NULL, GIT_RMDIR_SKIP_NONEMPTY));  	cl_assert(git_path_exists(git_buf_cstr(&file)) == true); -	cl_git_pass(git_futils_rmdir_r(empty_tmp_dir, NULL, GIT_DIRREMOVAL_FILES_AND_DIRS)); +	cl_git_pass(git_futils_rmdir_r(empty_tmp_dir, NULL, GIT_RMDIR_REMOVE_FILES));  	cl_assert(git_path_exists(empty_tmp_dir) == false);  	git_buf_free(&file);  } + +void test_core_rmdir__can_remove_empty_parents(void) +{ +	git_buf file = GIT_BUF_INIT; + +	cl_git_pass( +		git_buf_joinpath(&file, empty_tmp_dir, "/one/two_two/three/file.txt")); +	cl_git_mkfile(git_buf_cstr(&file), "dummy"); +	cl_assert(git_path_isfile(git_buf_cstr(&file))); + +	cl_git_pass(git_futils_rmdir_r("one/two_two/three/file.txt", empty_tmp_dir, +		GIT_RMDIR_REMOVE_FILES | GIT_RMDIR_EMPTY_PARENTS)); + +	cl_assert(!git_path_exists(git_buf_cstr(&file))); + +	git_buf_rtruncate_at_char(&file, '/'); /* three (only contained file.txt) */ +	cl_assert(!git_path_exists(git_buf_cstr(&file))); + +	git_buf_rtruncate_at_char(&file, '/'); /* two_two (only contained three) */ +	cl_assert(!git_path_exists(git_buf_cstr(&file))); + +	git_buf_rtruncate_at_char(&file, '/'); /* one (contained two_one also) */ +	cl_assert(git_path_exists(git_buf_cstr(&file))); + +	cl_assert(git_path_exists(empty_tmp_dir) == true); + +	git_buf_free(&file); + +	cl_git_pass(git_futils_rmdir_r(empty_tmp_dir, NULL, GIT_RMDIR_EMPTY_HIERARCHY)); +} diff --git a/tests-clar/object/blob/write.c b/tests-clar/object/blob/write.c index 87a9e2072..6d4cbab4f 100644 --- a/tests-clar/object/blob/write.c +++ b/tests-clar/object/blob/write.c @@ -49,7 +49,7 @@ void test_object_blob_write__can_create_a_blob_in_a_standard_repo_from_a_absolut  	assert_blob_creation(ELSEWHERE "/test.txt", git_buf_cstr(&full_path), &git_blob_create_fromdisk);  	git_buf_free(&full_path); -	cl_must_pass(git_futils_rmdir_r(ELSEWHERE, NULL, GIT_DIRREMOVAL_FILES_AND_DIRS)); +	cl_must_pass(git_futils_rmdir_r(ELSEWHERE, NULL, GIT_RMDIR_REMOVE_FILES));  }  void test_object_blob_write__can_create_a_blob_in_a_bare_repo_from_a_absolute_filepath(void) @@ -65,5 +65,5 @@ void test_object_blob_write__can_create_a_blob_in_a_bare_repo_from_a_absolute_fi  	assert_blob_creation(ELSEWHERE "/test.txt", git_buf_cstr(&full_path), &git_blob_create_fromdisk);  	git_buf_free(&full_path); -	cl_must_pass(git_futils_rmdir_r(ELSEWHERE, NULL, GIT_DIRREMOVAL_FILES_AND_DIRS)); +	cl_must_pass(git_futils_rmdir_r(ELSEWHERE, NULL, GIT_RMDIR_REMOVE_FILES));  } diff --git a/tests-clar/repo/discover.c b/tests-clar/repo/discover.c index b5afab75a..3d9aeedd7 100644 --- a/tests-clar/repo/discover.c +++ b/tests-clar/repo/discover.c @@ -135,7 +135,7 @@ void test_repo_discover__0(void)  	ensure_repository_discover(REPOSITORY_ALTERNATE_FOLDER_SUB_SUB, ceiling_dirs, sub_repository_path);  	ensure_repository_discover(REPOSITORY_ALTERNATE_FOLDER_SUB_SUB_SUB, ceiling_dirs, repository_path); -	cl_git_pass(git_futils_rmdir_r(TEMP_REPO_FOLDER, NULL, GIT_DIRREMOVAL_FILES_AND_DIRS)); +	cl_git_pass(git_futils_rmdir_r(TEMP_REPO_FOLDER, NULL, GIT_RMDIR_REMOVE_FILES));  	git_repository_free(repo);  	git_buf_free(&ceiling_dirs_buf);  } diff --git a/tests-clar/repo/open.c b/tests-clar/repo/open.c index ef912fa0e..7f93ae91a 100644 --- a/tests-clar/repo/open.c +++ b/tests-clar/repo/open.c @@ -7,7 +7,7 @@ void test_repo_open__cleanup(void)  	cl_git_sandbox_cleanup();  	if (git_path_isdir("alternate")) -		git_futils_rmdir_r("alternate", NULL, GIT_DIRREMOVAL_FILES_AND_DIRS); +		git_futils_rmdir_r("alternate", NULL, GIT_RMDIR_REMOVE_FILES);  }  void test_repo_open__bare_empty_repo(void) @@ -202,8 +202,8 @@ void test_repo_open__bad_gitlinks(void)  		cl_git_fail(git_repository_open_ext(&repo, "alternate", 0, NULL));  	} -	git_futils_rmdir_r("invalid", NULL, GIT_DIRREMOVAL_FILES_AND_DIRS); -	git_futils_rmdir_r("invalid2", NULL, GIT_DIRREMOVAL_FILES_AND_DIRS); +	git_futils_rmdir_r("invalid", NULL, GIT_RMDIR_REMOVE_FILES); +	git_futils_rmdir_r("invalid2", NULL, GIT_RMDIR_REMOVE_FILES);  }  #ifdef GIT_WIN32 diff --git a/tests-clar/status/worktree.c b/tests-clar/status/worktree.c index 116286f67..c154179b0 100644 --- a/tests-clar/status/worktree.c +++ b/tests-clar/status/worktree.c @@ -71,7 +71,7 @@ static int remove_file_cb(void *data, git_buf *file)  		return 0;  	if (git_path_isdir(filename)) -		cl_git_pass(git_futils_rmdir_r(filename, NULL, GIT_DIRREMOVAL_FILES_AND_DIRS)); +		cl_git_pass(git_futils_rmdir_r(filename, NULL, GIT_RMDIR_REMOVE_FILES));  	else  		cl_git_pass(p_unlink(git_buf_cstr(file))); @@ -314,7 +314,7 @@ void test_status_worktree__issue_592_3(void)  	repo = cl_git_sandbox_init("issue_592");  	cl_git_pass(git_buf_joinpath(&path, git_repository_workdir(repo), "c")); -	cl_git_pass(git_futils_rmdir_r(git_buf_cstr(&path), NULL, GIT_DIRREMOVAL_FILES_AND_DIRS)); +	cl_git_pass(git_futils_rmdir_r(git_buf_cstr(&path), NULL, GIT_RMDIR_REMOVE_FILES));  	cl_git_pass(git_status_foreach(repo, cb_status__check_592, "c/a.txt")); @@ -344,7 +344,7 @@ void test_status_worktree__issue_592_5(void)  	repo = cl_git_sandbox_init("issue_592");  	cl_git_pass(git_buf_joinpath(&path, git_repository_workdir(repo), "t")); -	cl_git_pass(git_futils_rmdir_r(git_buf_cstr(&path), NULL, GIT_DIRREMOVAL_FILES_AND_DIRS)); +	cl_git_pass(git_futils_rmdir_r(git_buf_cstr(&path), NULL, GIT_RMDIR_REMOVE_FILES));  	cl_git_pass(p_mkdir(git_buf_cstr(&path), 0777));  	cl_git_pass(git_status_foreach(repo, cb_status__check_592, NULL)); diff --git a/tests-clar/submodule/status.c b/tests-clar/submodule/status.c index eec028c40..325013466 100644 --- a/tests-clar/submodule/status.c +++ b/tests-clar/submodule/status.c @@ -50,7 +50,7 @@ void test_submodule_status__ignore_none(void)  	git_buf path = GIT_BUF_INIT;  	cl_git_pass(git_buf_joinpath(&path, git_repository_workdir(g_repo), "sm_unchanged")); -	cl_git_pass(git_futils_rmdir_r(git_buf_cstr(&path), NULL, GIT_DIRREMOVAL_FILES_AND_DIRS)); +	cl_git_pass(git_futils_rmdir_r(git_buf_cstr(&path), NULL, GIT_RMDIR_REMOVE_FILES));  	cl_git_fail(git_submodule_lookup(&sm, g_repo, "not_submodule")); @@ -135,7 +135,7 @@ void test_submodule_status__ignore_untracked(void)  	git_submodule_ignore_t ign = GIT_SUBMODULE_IGNORE_UNTRACKED;  	cl_git_pass(git_buf_joinpath(&path, git_repository_workdir(g_repo), "sm_unchanged")); -	cl_git_pass(git_futils_rmdir_r(git_buf_cstr(&path), NULL, GIT_DIRREMOVAL_FILES_AND_DIRS)); +	cl_git_pass(git_futils_rmdir_r(git_buf_cstr(&path), NULL, GIT_RMDIR_REMOVE_FILES));  	cl_git_pass(git_submodule_foreach(g_repo, set_sm_ignore, &ign)); @@ -195,7 +195,7 @@ void test_submodule_status__ignore_dirty(void)  	git_submodule_ignore_t ign = GIT_SUBMODULE_IGNORE_DIRTY;  	cl_git_pass(git_buf_joinpath(&path, git_repository_workdir(g_repo), "sm_unchanged")); -	cl_git_pass(git_futils_rmdir_r(git_buf_cstr(&path), NULL, GIT_DIRREMOVAL_FILES_AND_DIRS)); +	cl_git_pass(git_futils_rmdir_r(git_buf_cstr(&path), NULL, GIT_RMDIR_REMOVE_FILES));  	cl_git_pass(git_submodule_foreach(g_repo, set_sm_ignore, &ign)); @@ -255,7 +255,7 @@ void test_submodule_status__ignore_all(void)  	git_submodule_ignore_t ign = GIT_SUBMODULE_IGNORE_ALL;  	cl_git_pass(git_buf_joinpath(&path, git_repository_workdir(g_repo), "sm_unchanged")); -	cl_git_pass(git_futils_rmdir_r(git_buf_cstr(&path), NULL, GIT_DIRREMOVAL_FILES_AND_DIRS)); +	cl_git_pass(git_futils_rmdir_r(git_buf_cstr(&path), NULL, GIT_RMDIR_REMOVE_FILES));  	cl_git_pass(git_submodule_foreach(g_repo, set_sm_ignore, &ign)); | 
