mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-26 04:32:44 +01:00
[Tools] Mark output of tools as text if it is text
Several LLVM tools write text files/streams without using OF_Text. This can cause problems on platforms which distinguish between text and binary output. This PR adds the OF_Text flag for the following tools: - llvm-dis - llvm-dwarfdump - llvm-mca - llvm-mc (assembler files only) - opt (assembler files only) - RemarkStreamer (used e.g. by opt) Reviewers: rnk, vivekvpandya, Bigcheese, andreadb Differential Revision: https://reviews.llvm.org/D67696 llvm-svn: 374024
This commit is contained in:
parent
40c14830e6
commit
6221b33368
@ -122,18 +122,20 @@ llvm::setupOptimizationRemarks(LLVMContext &Context, StringRef RemarksFilename,
|
||||
if (RemarksFilename.empty())
|
||||
return nullptr;
|
||||
|
||||
Expected<remarks::Format> Format = remarks::parseFormat(RemarksFormat);
|
||||
if (Error E = Format.takeError())
|
||||
return make_error<RemarkSetupFormatError>(std::move(E));
|
||||
|
||||
std::error_code EC;
|
||||
auto Flags = *Format == remarks::Format::YAML ? sys::fs::OF_Text
|
||||
: sys::fs::OF_None;
|
||||
auto RemarksFile =
|
||||
std::make_unique<ToolOutputFile>(RemarksFilename, EC, sys::fs::OF_None);
|
||||
std::make_unique<ToolOutputFile>(RemarksFilename, EC, Flags);
|
||||
// We don't use llvm::FileError here because some diagnostics want the file
|
||||
// name separately.
|
||||
if (EC)
|
||||
return make_error<RemarkSetupFileError>(errorCodeToError(EC));
|
||||
|
||||
Expected<remarks::Format> Format = remarks::parseFormat(RemarksFormat);
|
||||
if (Error E = Format.takeError())
|
||||
return make_error<RemarkSetupFormatError>(std::move(E));
|
||||
|
||||
Expected<std::unique_ptr<remarks::RemarkSerializer>> RemarkSerializer =
|
||||
remarks::createRemarkSerializer(
|
||||
*Format, remarks::SerializerMode::Separate, RemarksFile->os());
|
||||
|
@ -186,7 +186,7 @@ int main(int argc, char **argv) {
|
||||
|
||||
std::error_code EC;
|
||||
std::unique_ptr<ToolOutputFile> Out(
|
||||
new ToolOutputFile(OutputFilename, EC, sys::fs::OF_None));
|
||||
new ToolOutputFile(OutputFilename, EC, sys::fs::OF_Text));
|
||||
if (EC) {
|
||||
errs() << EC.message() << '\n';
|
||||
return 1;
|
||||
|
@ -584,7 +584,7 @@ int main(int argc, char **argv) {
|
||||
}
|
||||
|
||||
std::error_code EC;
|
||||
ToolOutputFile OutputFile(OutputFilename, EC, sys::fs::OF_None);
|
||||
ToolOutputFile OutputFile(OutputFilename, EC, sys::fs::OF_Text);
|
||||
error("Unable to open output file" + OutputFilename, EC);
|
||||
// Don't remove output file if we exit with an error.
|
||||
OutputFile.keep();
|
||||
|
@ -209,9 +209,10 @@ static const Target *GetTarget(const char *ProgName) {
|
||||
return TheTarget;
|
||||
}
|
||||
|
||||
static std::unique_ptr<ToolOutputFile> GetOutputStream(StringRef Path) {
|
||||
static std::unique_ptr<ToolOutputFile> GetOutputStream(StringRef Path,
|
||||
sys::fs::OpenFlags Flags) {
|
||||
std::error_code EC;
|
||||
auto Out = std::make_unique<ToolOutputFile>(Path, EC, sys::fs::OF_None);
|
||||
auto Out = std::make_unique<ToolOutputFile>(Path, EC, Flags);
|
||||
if (EC) {
|
||||
WithColor::error() << EC.message() << '\n';
|
||||
return nullptr;
|
||||
@ -413,7 +414,9 @@ int main(int argc, char **argv) {
|
||||
FeaturesStr = Features.getString();
|
||||
}
|
||||
|
||||
std::unique_ptr<ToolOutputFile> Out = GetOutputStream(OutputFilename);
|
||||
sys::fs::OpenFlags Flags = (FileType == OFT_AssemblyFile) ? sys::fs::OF_Text
|
||||
: sys::fs::OF_None;
|
||||
std::unique_ptr<ToolOutputFile> Out = GetOutputStream(OutputFilename, Flags);
|
||||
if (!Out)
|
||||
return 1;
|
||||
|
||||
@ -423,7 +426,7 @@ int main(int argc, char **argv) {
|
||||
WithColor::error() << "dwo output only supported with object files\n";
|
||||
return 1;
|
||||
}
|
||||
DwoOut = GetOutputStream(SplitDwarfFile);
|
||||
DwoOut = GetOutputStream(SplitDwarfFile, sys::fs::OF_None);
|
||||
if (!DwoOut)
|
||||
return 1;
|
||||
}
|
||||
|
@ -238,7 +238,7 @@ ErrorOr<std::unique_ptr<ToolOutputFile>> getOutputStream() {
|
||||
OutputFilename = "-";
|
||||
std::error_code EC;
|
||||
auto Out =
|
||||
std::make_unique<ToolOutputFile>(OutputFilename, EC, sys::fs::OF_None);
|
||||
std::make_unique<ToolOutputFile>(OutputFilename, EC, sys::fs::OF_Text);
|
||||
if (!EC)
|
||||
return std::move(Out);
|
||||
return EC;
|
||||
|
@ -611,7 +611,9 @@ int main(int argc, char **argv) {
|
||||
OutputFilename = "-";
|
||||
|
||||
std::error_code EC;
|
||||
Out.reset(new ToolOutputFile(OutputFilename, EC, sys::fs::OF_None));
|
||||
sys::fs::OpenFlags Flags = OutputAssembly ? sys::fs::OF_Text
|
||||
: sys::fs::OF_None;
|
||||
Out.reset(new ToolOutputFile(OutputFilename, EC, Flags));
|
||||
if (EC) {
|
||||
errs() << EC.message() << '\n';
|
||||
return 1;
|
||||
|
Loading…
Reference in New Issue
Block a user