mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-25 05:15:58 +00:00
487196fe1d
Following D50807, and heading towards D50664, this intermediary change does the following: 1. Upgrade all custom Error types in llvm/trunk/lib/DebugInfo/ to use the new StringError behavior (D50807). 2. Implement std::is_error_code_enum and make_error_code() for DebugInfo error enumerations. 3. Rename GenericError -> PDBError (the file will be renamed in a subsequent commit) 4. Update custom error messages to follow the same formatting: (\w\s*)+\. 5. Keep generic "file not found" (ENOENT) errors as they are in PDB code. Previously, there used to be a custom enumeration for that purpose. 6. Remove a few extraneous LF in log() implementations. Printing LF is a responsability at a higher level, not at the error level. Differential Revision: https://reviews.llvm.org/D51499 llvm-svn: 341228
57 lines
1.7 KiB
C++
57 lines
1.7 KiB
C++
//===- BinaryStreamError.cpp - Error extensions for streams -----*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/Support/BinaryStreamError.h"
|
|
#include "llvm/Support/ErrorHandling.h"
|
|
|
|
using namespace llvm;
|
|
|
|
char BinaryStreamError::ID = 0;
|
|
|
|
BinaryStreamError::BinaryStreamError(stream_error_code C)
|
|
: BinaryStreamError(C, "") {}
|
|
|
|
BinaryStreamError::BinaryStreamError(StringRef Context)
|
|
: BinaryStreamError(stream_error_code::unspecified, Context) {}
|
|
|
|
BinaryStreamError::BinaryStreamError(stream_error_code C, StringRef Context)
|
|
: Code(C) {
|
|
ErrMsg = "Stream Error: ";
|
|
switch (C) {
|
|
case stream_error_code::unspecified:
|
|
ErrMsg += "An unspecified error has occurred.";
|
|
break;
|
|
case stream_error_code::stream_too_short:
|
|
ErrMsg += "The stream is too short to perform the requested operation.";
|
|
break;
|
|
case stream_error_code::invalid_array_size:
|
|
ErrMsg += "The buffer size is not a multiple of the array element size.";
|
|
break;
|
|
case stream_error_code::invalid_offset:
|
|
ErrMsg += "The specified offset is invalid for the current stream.";
|
|
break;
|
|
case stream_error_code::filesystem_error:
|
|
ErrMsg += "An I/O error occurred on the file system.";
|
|
break;
|
|
}
|
|
|
|
if (!Context.empty()) {
|
|
ErrMsg += " ";
|
|
ErrMsg += Context;
|
|
}
|
|
}
|
|
|
|
void BinaryStreamError::log(raw_ostream &OS) const { OS << ErrMsg; }
|
|
|
|
StringRef BinaryStreamError::getErrorMessage() const { return ErrMsg; }
|
|
|
|
std::error_code BinaryStreamError::convertToErrorCode() const {
|
|
return inconvertibleErrorCode();
|
|
}
|