[llvm] Update report_fatal_error calls from raw_string_ostream to use Twine(OS.str())

As described on D111049, we're trying to remove the <string> dependency from error handling and replace uses of report_fatal_error(const std::string&) with the Twine() variant which can be forward declared.

We can use the raw_string_ostream::str() method to perform the implicit flush() and return a reference to the std::string container that we can then wrap inside Twine().
This commit is contained in:
Simon Pilgrim 2021-10-05 18:34:02 +01:00
parent 5bc32ad08d
commit 2e5daac217
13 changed files with 22 additions and 39 deletions

View File

@ -2517,7 +2517,7 @@ const MCExpr *AsmPrinter::lowerConstant(const Constant *CV) {
OS << "Unsupported expression in static initializer: "; OS << "Unsupported expression in static initializer: ";
CE->printAsOperand(OS, /*PrintType=*/false, CE->printAsOperand(OS, /*PrintType=*/false,
!MF ? nullptr : MF->getFunction().getParent()); !MF ? nullptr : MF->getFunction().getParent());
report_fatal_error(OS.str()); report_fatal_error(Twine(OS.str()));
} }
case Instruction::GetElementPtr: { case Instruction::GetElementPtr: {
// Generate a symbolic expression for the byte address // Generate a symbolic expression for the byte address

View File

@ -582,7 +582,7 @@ void AsmPrinter::PrintSpecial(const MachineInstr *MI, raw_ostream &OS,
raw_string_ostream Msg(msg); raw_string_ostream Msg(msg);
Msg << "Unknown special formatter '" << Code Msg << "Unknown special formatter '" << Code
<< "' for machine instr: " << *MI; << "' for machine instr: " << *MI;
report_fatal_error(Msg.str()); report_fatal_error(Twine(Msg.str()));
} }
} }

View File

@ -9938,12 +9938,9 @@ SDValue SelectionDAG::getSymbolFunctionGlobalAddress(SDValue Op,
std::string ErrorStr; std::string ErrorStr;
raw_string_ostream ErrorFormatter(ErrorStr); raw_string_ostream ErrorFormatter(ErrorStr);
ErrorFormatter << "Undefined external symbol "; ErrorFormatter << "Undefined external symbol ";
ErrorFormatter << '"' << Symbol << '"'; ErrorFormatter << '"' << Symbol << '"';
ErrorFormatter.flush(); report_fatal_error(Twine(ErrorFormatter.str()));
report_fatal_error(ErrorStr);
} }
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//

View File

@ -218,8 +218,7 @@ void MCJIT::generateCodeForModule(Module *M) {
std::string Buf; std::string Buf;
raw_string_ostream OS(Buf); raw_string_ostream OS(Buf);
logAllUnhandledErrors(LoadedObject.takeError(), OS); logAllUnhandledErrors(LoadedObject.takeError(), OS);
OS.flush(); report_fatal_error(Twine(OS.str()));
report_fatal_error(Buf);
} }
std::unique_ptr<RuntimeDyld::LoadedObjectInfo> L = std::unique_ptr<RuntimeDyld::LoadedObjectInfo> L =
Dyld.loadObject(*LoadedObject.get()); Dyld.loadObject(*LoadedObject.get());

View File

@ -1236,8 +1236,7 @@ RuntimeDyldELF::processRelocationRef(
std::string Buf; std::string Buf;
raw_string_ostream OS(Buf); raw_string_ostream OS(Buf);
logAllUnhandledErrors(SymTypeOrErr.takeError(), OS); logAllUnhandledErrors(SymTypeOrErr.takeError(), OS);
OS.flush(); report_fatal_error(Twine(OS.str()));
report_fatal_error(Buf);
} }
SymType = *SymTypeOrErr; SymType = *SymTypeOrErr;
} }
@ -1257,8 +1256,7 @@ RuntimeDyldELF::processRelocationRef(
std::string Buf; std::string Buf;
raw_string_ostream OS(Buf); raw_string_ostream OS(Buf);
logAllUnhandledErrors(SectionOrErr.takeError(), OS); logAllUnhandledErrors(SectionOrErr.takeError(), OS);
OS.flush(); report_fatal_error(Twine(OS.str()));
report_fatal_error(Buf);
} }
section_iterator si = *SectionOrErr; section_iterator si = *SectionOrErr;
if (si == Obj.section_end()) if (si == Obj.section_end())

View File

@ -29,8 +29,7 @@ static bool isThumbFunc(object::symbol_iterator Symbol,
std::string Buf; std::string Buf;
raw_string_ostream OS(Buf); raw_string_ostream OS(Buf);
logAllUnhandledErrors(SymTypeOrErr.takeError(), OS); logAllUnhandledErrors(SymTypeOrErr.takeError(), OS);
OS.flush(); report_fatal_error(Twine(OS.str()));
report_fatal_error(Buf);
} }
if (*SymTypeOrErr != object::SymbolRef::ST_Function) if (*SymTypeOrErr != object::SymbolRef::ST_Function)

View File

@ -222,8 +222,7 @@ void LLVMMoveToContainingSection(LLVMSectionIteratorRef Sect,
std::string Buf; std::string Buf;
raw_string_ostream OS(Buf); raw_string_ostream OS(Buf);
logAllUnhandledErrors(SecOrErr.takeError(), OS); logAllUnhandledErrors(SecOrErr.takeError(), OS);
OS.flush(); report_fatal_error(Twine(OS.str()));
report_fatal_error(Buf);
} }
*unwrap(Sect) = *SecOrErr; *unwrap(Sect) = *SecOrErr;
} }
@ -304,8 +303,7 @@ const char *LLVMGetSymbolName(LLVMSymbolIteratorRef SI) {
std::string Buf; std::string Buf;
raw_string_ostream OS(Buf); raw_string_ostream OS(Buf);
logAllUnhandledErrors(Ret.takeError(), OS); logAllUnhandledErrors(Ret.takeError(), OS);
OS.flush(); report_fatal_error(Twine(OS.str()));
report_fatal_error(Buf);
} }
return Ret->data(); return Ret->data();
} }
@ -316,8 +314,7 @@ uint64_t LLVMGetSymbolAddress(LLVMSymbolIteratorRef SI) {
std::string Buf; std::string Buf;
raw_string_ostream OS(Buf); raw_string_ostream OS(Buf);
logAllUnhandledErrors(Ret.takeError(), OS); logAllUnhandledErrors(Ret.takeError(), OS);
OS.flush(); report_fatal_error(Twine(OS.str()));
report_fatal_error(Buf);
} }
return *Ret; return *Ret;
} }

View File

@ -453,7 +453,7 @@ void HexagonMCCodeEmitter::EncodeSingleInstruction(const MCInst &MI,
raw_string_ostream Stream(Text); raw_string_ostream Stream(Text);
Stream << "Unrecognized relocation combination: width=" << Width Stream << "Unrecognized relocation combination: width=" << Width
<< " kind=" << Kind; << " kind=" << Kind;
report_fatal_error(Stream.str()); report_fatal_error(Twine(Stream.str()));
} }
/// Some insns are not extended and thus have no bits. These cases require /// Some insns are not extended and thus have no bits. These cases require

View File

@ -1923,7 +1923,7 @@ NVPTXAsmPrinter::lowerConstantForGV(const Constant *CV, bool ProcessingGeneric)
OS << "Unsupported expression in static initializer: "; OS << "Unsupported expression in static initializer: ";
CE->printAsOperand(OS, /*PrintType=*/false, CE->printAsOperand(OS, /*PrintType=*/false,
!MF ? nullptr : MF->getFunction().getParent()); !MF ? nullptr : MF->getFunction().getParent());
report_fatal_error(OS.str()); report_fatal_error(Twine(OS.str()));
} }
case Instruction::AddrSpaceCast: { case Instruction::AddrSpaceCast: {
@ -1937,7 +1937,7 @@ NVPTXAsmPrinter::lowerConstantForGV(const Constant *CV, bool ProcessingGeneric)
OS << "Unsupported expression in static initializer: "; OS << "Unsupported expression in static initializer: ";
CE->printAsOperand(OS, /*PrintType=*/ false, CE->printAsOperand(OS, /*PrintType=*/ false,
!MF ? nullptr : MF->getFunction().getParent()); !MF ? nullptr : MF->getFunction().getParent());
report_fatal_error(OS.str()); report_fatal_error(Twine(OS.str()));
} }
case Instruction::GetElementPtr: { case Instruction::GetElementPtr: {

View File

@ -282,8 +282,7 @@ ErrorOr<SymbolRef> Decoder::getSymbolForLocation(
std::string Buf; std::string Buf;
llvm::raw_string_ostream OS(Buf); llvm::raw_string_ostream OS(Buf);
logAllUnhandledErrors(AddressOrErr.takeError(), OS); logAllUnhandledErrors(AddressOrErr.takeError(), OS);
OS.flush(); report_fatal_error(Twine(OS.str()));
report_fatal_error(Buf);
} }
// We apply SymbolOffset here directly. We return it separately to allow // We apply SymbolOffset here directly. We return it separately to allow
// the caller to print it as an offset on the symbol name. // the caller to print it as an offset on the symbol name.
@ -1006,8 +1005,7 @@ bool Decoder::dumpXDataRecord(const COFFObjectFile &COFF,
std::string Buf; std::string Buf;
llvm::raw_string_ostream OS(Buf); llvm::raw_string_ostream OS(Buf);
logAllUnhandledErrors(Name.takeError(), OS); logAllUnhandledErrors(Name.takeError(), OS);
OS.flush(); report_fatal_error(Twine(OS.str()));
report_fatal_error(Buf);
} }
ListScope EHS(SW, "ExceptionHandler"); ListScope EHS(SW, "ExceptionHandler");
@ -1046,8 +1044,7 @@ bool Decoder::dumpUnpackedEntry(const COFFObjectFile &COFF,
std::string Buf; std::string Buf;
llvm::raw_string_ostream OS(Buf); llvm::raw_string_ostream OS(Buf);
logAllUnhandledErrors(FunctionNameOrErr.takeError(), OS); logAllUnhandledErrors(FunctionNameOrErr.takeError(), OS);
OS.flush(); report_fatal_error(Twine(OS.str()));
report_fatal_error(Buf);
} }
FunctionName = *FunctionNameOrErr; FunctionName = *FunctionNameOrErr;
} }
@ -1061,8 +1058,7 @@ bool Decoder::dumpUnpackedEntry(const COFFObjectFile &COFF,
std::string Buf; std::string Buf;
llvm::raw_string_ostream OS(Buf); llvm::raw_string_ostream OS(Buf);
logAllUnhandledErrors(Name.takeError(), OS); logAllUnhandledErrors(Name.takeError(), OS);
OS.flush(); report_fatal_error(Twine(OS.str()));
report_fatal_error(Buf);
} }
SW.printString("ExceptionRecord", SW.printString("ExceptionRecord",
@ -1107,8 +1103,7 @@ bool Decoder::dumpPackedEntry(const object::COFFObjectFile &COFF,
std::string Buf; std::string Buf;
llvm::raw_string_ostream OS(Buf); llvm::raw_string_ostream OS(Buf);
logAllUnhandledErrors(FunctionNameOrErr.takeError(), OS); logAllUnhandledErrors(FunctionNameOrErr.takeError(), OS);
OS.flush(); report_fatal_error(Twine(OS.str()));
report_fatal_error(Buf);
} }
FunctionName = *FunctionNameOrErr; FunctionName = *FunctionNameOrErr;
} }
@ -1149,8 +1144,7 @@ bool Decoder::dumpPackedARM64Entry(const object::COFFObjectFile &COFF,
std::string Buf; std::string Buf;
llvm::raw_string_ostream OS(Buf); llvm::raw_string_ostream OS(Buf);
logAllUnhandledErrors(FunctionNameOrErr.takeError(), OS); logAllUnhandledErrors(FunctionNameOrErr.takeError(), OS);
OS.flush(); report_fatal_error(Twine(OS.str()));
report_fatal_error(Buf);
} }
FunctionName = *FunctionNameOrErr; FunctionName = *FunctionNameOrErr;
} }

View File

@ -204,8 +204,7 @@ void COFFDumper::dumpSections(unsigned NumSections) {
std::string Buf; std::string Buf;
raw_string_ostream OS(Buf); raw_string_ostream OS(Buf);
logAllUnhandledErrors(SymbolNameOrErr.takeError(), OS); logAllUnhandledErrors(SymbolNameOrErr.takeError(), OS);
OS.flush(); report_fatal_error(Twine(OS.str()));
report_fatal_error(Buf);
} }
if (SymbolUnique.lookup(*SymbolNameOrErr)) if (SymbolUnique.lookup(*SymbolNameOrErr))
Rel.SymbolName = *SymbolNameOrErr; Rel.SymbolName = *SymbolNameOrErr;

View File

@ -37,7 +37,7 @@ protected:
Error.print("", os); Error.print("", os);
if (!M) if (!M)
report_fatal_error(os.str()); report_fatal_error(Twine(os.str()));
} }
::testing::AssertionResult isLibFunc(const Function *FDecl, ::testing::AssertionResult isLibFunc(const Function *FDecl,

View File

@ -36,7 +36,7 @@ protected:
// A failure here means that the test itself is buggy. // A failure here means that the test itself is buggy.
if (!M) if (!M)
report_fatal_error(os.str()); report_fatal_error(Twine(os.str()));
Function *F = M->getFunction("test"); Function *F = M->getFunction("test");
if (F == nullptr) if (F == nullptr)