mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-25 04:39:44 +00:00
Add Binary flag to raw_fd_ostream constructor.
Document raw_fd_ostream's treatment of "-". git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@59219 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
241085aa38
commit
0d9eb9b491
@ -156,7 +156,12 @@ public:
|
||||
/// error occurs, information about the error is put into ErrorInfo,
|
||||
/// and the stream should be immediately destroyed; the string will
|
||||
/// be empty if no error occurred.
|
||||
raw_fd_ostream(const char *Filename, std::string &ErrorInfo);
|
||||
///
|
||||
/// \param Filename - The file to open. If this is "-" then the
|
||||
/// stream will use stdout instead.
|
||||
/// \param Binary - The file should be opened in binary mode on
|
||||
/// platforms that support this distinction.
|
||||
raw_fd_ostream(const char *Filename, bool Binary, std::string &ErrorInfo);
|
||||
|
||||
/// raw_fd_ostream ctor - FD is the file descriptor that this writes to. If
|
||||
/// ShouldClose is true, this closes the file when
|
||||
|
@ -13,6 +13,7 @@
|
||||
|
||||
#include "llvm/Support/raw_ostream.h"
|
||||
#include "llvm/Support/Format.h"
|
||||
#include "llvm/System/Program.h"
|
||||
#include "llvm/ADT/SmallVector.h"
|
||||
#include "llvm/Config/config.h"
|
||||
#include <ostream>
|
||||
@ -200,17 +201,27 @@ void format_object_base::home() {
|
||||
/// occurs, information about the error is put into ErrorInfo, and the
|
||||
/// stream should be immediately destroyed; the string will be empty
|
||||
/// if no error occurred.
|
||||
raw_fd_ostream::raw_fd_ostream(const char *Filename, std::string &ErrorInfo) {
|
||||
raw_fd_ostream::raw_fd_ostream(const char *Filename, bool Binary,
|
||||
std::string &ErrorInfo) {
|
||||
ErrorInfo.clear();
|
||||
|
||||
// Handle "-" as stdout.
|
||||
if (Filename[0] == '-' && Filename[1] == 0) {
|
||||
FD = STDOUT_FILENO;
|
||||
// If user requested binary then put stdout into binary mode if
|
||||
// possible.
|
||||
if (Binary)
|
||||
sys::Program::ChangeStdoutToBinary();
|
||||
ShouldClose = false;
|
||||
return;
|
||||
}
|
||||
|
||||
FD = open(Filename, O_WRONLY|O_CREAT|O_TRUNC, 0644);
|
||||
int Flags = O_WRONLY|O_CREAT|O_TRUNC;
|
||||
#ifdef O_BINARY
|
||||
if (Binary)
|
||||
Flags |= O_BINARY;
|
||||
#endif
|
||||
FD = open(Filename, Flags, 0644);
|
||||
if (FD < 0) {
|
||||
ErrorInfo = "Error opening output file '" + std::string(Filename) + "'";
|
||||
ShouldClose = false;
|
||||
|
@ -125,7 +125,7 @@ static raw_ostream *GetOutputStream(const char *ProgName) {
|
||||
sys::RemoveFileOnSignal(sys::Path(OutputFilename));
|
||||
|
||||
std::string error;
|
||||
raw_ostream *Out = new raw_fd_ostream(OutputFilename.c_str(), error);
|
||||
raw_ostream *Out = new raw_fd_ostream(OutputFilename.c_str(), true, error);
|
||||
if (!error.empty()) {
|
||||
std::cerr << error << '\n';
|
||||
delete Out;
|
||||
@ -142,6 +142,7 @@ static raw_ostream *GetOutputStream(const char *ProgName) {
|
||||
|
||||
OutputFilename = GetFileNameRoot(InputFilename);
|
||||
|
||||
bool Binary = false;
|
||||
switch (FileType) {
|
||||
case TargetMachine::AssemblyFile:
|
||||
if (MArch->Name[0] == 'c') {
|
||||
@ -156,9 +157,11 @@ static raw_ostream *GetOutputStream(const char *ProgName) {
|
||||
break;
|
||||
case TargetMachine::ObjectFile:
|
||||
OutputFilename += ".o";
|
||||
Binary = true;
|
||||
break;
|
||||
case TargetMachine::DynamicLibrary:
|
||||
OutputFilename += LTDL_SHLIB_EXT;
|
||||
Binary = true;
|
||||
break;
|
||||
}
|
||||
|
||||
@ -175,7 +178,7 @@ static raw_ostream *GetOutputStream(const char *ProgName) {
|
||||
sys::RemoveFileOnSignal(sys::Path(OutputFilename));
|
||||
|
||||
std::string error;
|
||||
raw_ostream *Out = new raw_fd_ostream(OutputFilename.c_str(), error);
|
||||
raw_ostream *Out = new raw_fd_ostream(OutputFilename.c_str(), Binary, error);
|
||||
if (!error.empty()) {
|
||||
std::cerr << error << '\n';
|
||||
delete Out;
|
||||
|
@ -165,7 +165,7 @@ const void* LTOCodeGenerator::compile(size_t* length, std::string& errMsg)
|
||||
// generate assembly code
|
||||
bool genResult = false;
|
||||
{
|
||||
raw_fd_ostream asmFile(uniqueAsmPath.c_str(), errMsg);
|
||||
raw_fd_ostream asmFile(uniqueAsmPath.c_str(), false, errMsg);
|
||||
if (!errMsg.empty())
|
||||
return NULL;
|
||||
genResult = this->generateAssemblyCode(asmFile, errMsg);
|
||||
|
Loading…
Reference in New Issue
Block a user