HDFS-7162. Wrong path when deleting through fuse-dfs a file which already exists in trash (cmccabe)
(cherry picked from commit03db9cc839
) (cherry picked from commitab1afc4e1c
)
This commit is contained in:
parent
dea3f133ff
commit
94277a7d21
|
@ -533,6 +533,9 @@ Release 2.6.0 - UNRELEASED
|
||||||
HDFS-7181. Remove incorrect precondition check on key length in
|
HDFS-7181. Remove incorrect precondition check on key length in
|
||||||
FileEncryptionInfo. (wang)
|
FileEncryptionInfo. (wang)
|
||||||
|
|
||||||
|
HDFS-7162. Wrong path when deleting through fuse-dfs a file which already
|
||||||
|
exists in trash (Chenging Liu via cmccabe)
|
||||||
|
|
||||||
BREAKDOWN OF HDFS-6134 AND HADOOP-10150 SUBTASKS AND RELATED JIRAS
|
BREAKDOWN OF HDFS-6134 AND HADOOP-10150 SUBTASKS AND RELATED JIRAS
|
||||||
|
|
||||||
HDFS-6387. HDFS CLI admin tool for creating & deleting an
|
HDFS-6387. HDFS CLI admin tool for creating & deleting an
|
||||||
|
|
|
@ -150,13 +150,14 @@ int move_to_trash(const char *abs_path, hdfsFS userFS)
|
||||||
if (ret) {
|
if (ret) {
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
if (!strncmp(trash_base, abs_path, strlen(trash_base))) {
|
int trash_base_len = strlen(trash_base);
|
||||||
|
if (!strncmp(trash_base, abs_path, trash_base_len)
|
||||||
|
&& (strlen(abs_path) == trash_base_len || abs_path[trash_base_len] == '/')) {
|
||||||
INFO("move_to_trash(%s): file is already in the trash; deleting.",
|
INFO("move_to_trash(%s): file is already in the trash; deleting.",
|
||||||
abs_path);
|
abs_path);
|
||||||
ret = ALREADY_IN_TRASH_ERR;
|
ret = ALREADY_IN_TRASH_ERR;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
fprintf(stderr, "trash_base='%s'\n", trash_base);
|
|
||||||
if (asprintf(&target_dir, "%s%s", trash_base, parent_dir) < 0) {
|
if (asprintf(&target_dir, "%s%s", trash_base, parent_dir) < 0) {
|
||||||
ret = ENOMEM;
|
ret = ENOMEM;
|
||||||
target_dir = NULL;
|
target_dir = NULL;
|
||||||
|
@ -182,7 +183,7 @@ int move_to_trash(const char *abs_path, hdfsFS userFS)
|
||||||
int idx;
|
int idx;
|
||||||
for (idx = 1; idx < TRASH_RENAME_TRIES; idx++) {
|
for (idx = 1; idx < TRASH_RENAME_TRIES; idx++) {
|
||||||
free(target);
|
free(target);
|
||||||
if (asprintf(&target, "%s%s.%d", target_dir, pcomp, idx) < 0) {
|
if (asprintf(&target, "%s/%s.%d", target_dir, pcomp, idx) < 0) {
|
||||||
target = NULL;
|
target = NULL;
|
||||||
ret = ENOMEM;
|
ret = ENOMEM;
|
||||||
goto done;
|
goto done;
|
||||||
|
|
Loading…
Reference in New Issue