svn_fs_dirent_t *dirent = reinterpret_cast<svn_fs_dirent_t *>(value);
QByteArray entryName = pathname + '/' + dirent->name;
- QString entryFinalName;
- if (finalPathName.isEmpty())
- entryFinalName = dirent->name;
- else
- entryFinalName = finalPathName + '/' + dirent->name;
+ QString entryFinalName = finalPathName + dirent->name;
if (dirent->kind == svn_node_dir) {
+ entryFinalName += '/';
if (recursiveDumpDir(txn, fs_root, entryName, entryFinalName, dirpool) == EXIT_FAILURE)
return EXIT_FAILURE;
} else if (dirent->kind == svn_node_file) {
}
}
- Repository::Transaction *txn = transactions.value(repository, 0);
+ Repository::Transaction *txn = transactions.value(repository + branch, 0);
if (!txn) {
Repository *repo = repositories.value(repository, 0);
if (!repo) {
if (!txn)
return EXIT_FAILURE;
- transactions.insert(repository, txn);
+ transactions.insert(repository + branch, txn);
}
if (change->change_kind == svn_fs_path_change_delete) {
} else if (!current.endsWith('/')) {
dumpBlob(txn, fs_root, key, path, pool);
} else {
- txn->deleteFile(path);
+ QString pathNoSlash = path;
+ pathNoSlash.chop(1);
+ txn->deleteFile(pathNoSlash);
recursiveDumpDir(txn, fs_root, key, path, pool);
}
return EXIT_FAILURE;
}
}
+
+ return EXIT_SUCCESS;
}