forked from OSchip/llvm-project
Support: Add llvm::sys::fs::copy_file
A function to copy one file's contents to another. llvm-svn: 211302
This commit is contained in:
parent
03b1c3f438
commit
cd45f963e2
|
@ -335,6 +335,12 @@ std::error_code remove(const Twine &path, bool IgnoreNonExisting = true);
|
||||||
/// @param to The path to rename to. This is created.
|
/// @param to The path to rename to. This is created.
|
||||||
std::error_code rename(const Twine &from, const Twine &to);
|
std::error_code rename(const Twine &from, const Twine &to);
|
||||||
|
|
||||||
|
/// @brief Copy the contents of \a From to \a To.
|
||||||
|
///
|
||||||
|
/// @param From The path to copy from.
|
||||||
|
/// @param To The path to copy to. This is created.
|
||||||
|
std::error_code copy_file(const Twine &From, const Twine &To);
|
||||||
|
|
||||||
/// @brief Resize path to size. File is resized as if by POSIX truncate().
|
/// @brief Resize path to size. File is resized as if by POSIX truncate().
|
||||||
///
|
///
|
||||||
/// @param path Input path.
|
/// @param path Input path.
|
||||||
|
|
|
@ -846,6 +846,40 @@ std::error_code create_directories(const Twine &Path, bool IgnoreExisting) {
|
||||||
return create_directory(P, IgnoreExisting);
|
return create_directory(P, IgnoreExisting);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::error_code copy_file(const Twine &From, const Twine &To) {
|
||||||
|
int ReadFD, WriteFD;
|
||||||
|
if (std::error_code EC = openFileForRead(From, ReadFD))
|
||||||
|
return EC;
|
||||||
|
if (std::error_code EC = openFileForWrite(To, WriteFD, F_None)) {
|
||||||
|
close(ReadFD);
|
||||||
|
return EC;
|
||||||
|
}
|
||||||
|
|
||||||
|
const size_t BufSize = 4096;
|
||||||
|
char *Buf = new char[BufSize];
|
||||||
|
int BytesRead = 0, BytesWritten = 0;
|
||||||
|
for (;;) {
|
||||||
|
BytesRead = read(ReadFD, Buf, BufSize);
|
||||||
|
if (BytesRead <= 0)
|
||||||
|
break;
|
||||||
|
while (BytesRead) {
|
||||||
|
BytesWritten = write(WriteFD, Buf, BytesRead);
|
||||||
|
if (BytesWritten < 0)
|
||||||
|
break;
|
||||||
|
BytesRead -= BytesWritten;
|
||||||
|
}
|
||||||
|
if (BytesWritten < 0)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
close(ReadFD);
|
||||||
|
close(WriteFD);
|
||||||
|
delete[] Buf;
|
||||||
|
|
||||||
|
if (BytesRead < 0 || BytesWritten < 0)
|
||||||
|
return std::error_code(errno, std::generic_category());
|
||||||
|
return std::error_code();
|
||||||
|
}
|
||||||
|
|
||||||
bool exists(file_status status) {
|
bool exists(file_status status) {
|
||||||
return status_known(status) && status.type() != file_type::file_not_found;
|
return status_known(status) && status.type() != file_type::file_not_found;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue