diff options
Diffstat (limited to 'contrib/llvm/lib/DebugInfo/PDB/GenericError.cpp')
| -rw-r--r-- | contrib/llvm/lib/DebugInfo/PDB/GenericError.cpp | 55 | 
1 files changed, 17 insertions, 38 deletions
diff --git a/contrib/llvm/lib/DebugInfo/PDB/GenericError.cpp b/contrib/llvm/lib/DebugInfo/PDB/GenericError.cpp index 2a677b9abe2d..256952073e88 100644 --- a/contrib/llvm/lib/DebugInfo/PDB/GenericError.cpp +++ b/contrib/llvm/lib/DebugInfo/PDB/GenericError.cpp @@ -14,55 +14,34 @@  using namespace llvm;  using namespace llvm::pdb; -namespace {  // FIXME: This class is only here to support the transition to llvm::Error. It  // will be removed once this transition is complete. Clients should prefer to  // deal with the Error value directly, rather than converting to error_code. -class GenericErrorCategory : public std::error_category { +class PDBErrorCategory : public std::error_category {  public:    const char *name() const noexcept override { return "llvm.pdb"; } -    std::string message(int Condition) const override { -    switch (static_cast<generic_error_code>(Condition)) { -    case generic_error_code::unspecified: +    switch (static_cast<pdb_error_code>(Condition)) { +    case pdb_error_code::unspecified:        return "An unknown error has occurred."; -    case generic_error_code::type_server_not_found: -      return "Type server PDB was not found."; -    case generic_error_code::dia_sdk_not_present: -      return "LLVM was not compiled with support for DIA.  This usually means " +    case pdb_error_code::dia_sdk_not_present: +      return "LLVM was not compiled with support for DIA. This usually means "               "that you are not using MSVC, or your Visual Studio " -             "installation " -             "is corrupt."; -    case generic_error_code::invalid_path: -      return "Unable to load PDB.  Make sure the file exists and is readable."; +             "installation is corrupt."; +    case pdb_error_code::dia_failed_loading: +      return "DIA is only supported when using MSVC."; +    case pdb_error_code::invalid_utf8_path: +      return "The PDB file path is an invalid UTF8 sequence."; +    case pdb_error_code::signature_out_of_date: +      return "The signature does not match; the file(s) might be out of date."; +    case pdb_error_code::external_cmdline_ref: +      return "The path to this file must be provided on the command-line.";      }      llvm_unreachable("Unrecognized generic_error_code");    }  }; -} // end anonymous namespace - -static ManagedStatic<GenericErrorCategory> Category; - -char GenericError::ID = 0; - -GenericError::GenericError(generic_error_code C) : GenericError(C, "") {} - -GenericError::GenericError(StringRef Context) -    : GenericError(generic_error_code::unspecified, Context) {} - -GenericError::GenericError(generic_error_code C, StringRef Context) : Code(C) { -  ErrMsg = "PDB Error: "; -  std::error_code EC = convertToErrorCode(); -  if (Code != generic_error_code::unspecified) -    ErrMsg += EC.message() + "  "; -  if (!Context.empty()) -    ErrMsg += Context; -} - -void GenericError::log(raw_ostream &OS) const { OS << ErrMsg << "\n"; } -StringRef GenericError::getErrorMessage() const { return ErrMsg; } +static llvm::ManagedStatic<PDBErrorCategory> PDBCategory; +const std::error_category &llvm::pdb::PDBErrCategory() { return *PDBCategory; } -std::error_code GenericError::convertToErrorCode() const { -  return std::error_code(static_cast<int>(Code), *Category); -} +char PDBError::ID;  | 
