mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-12 02:33:33 +00:00
[Support][ErrorOr] Add support for implicit conversion from error code/condition enums.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@176228 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
2b9a946f98
commit
9b4886ee55
@ -180,6 +180,16 @@ private:
|
|||||||
public:
|
public:
|
||||||
ErrorOr() : IsValid(false) {}
|
ErrorOr() : IsValid(false) {}
|
||||||
|
|
||||||
|
template <class E>
|
||||||
|
ErrorOr(E ErrorCode, typename enable_if_c<is_error_code_enum<E>::value ||
|
||||||
|
is_error_condition_enum<E>::value,
|
||||||
|
void *>::type = 0)
|
||||||
|
: HasError(true), IsValid(true) {
|
||||||
|
Error = new ErrorHolderBase;
|
||||||
|
Error->Error = make_error_code(ErrorCode);
|
||||||
|
Error->HasUserData = false;
|
||||||
|
}
|
||||||
|
|
||||||
ErrorOr(llvm::error_code EC) : HasError(true), IsValid(true) {
|
ErrorOr(llvm::error_code EC) : HasError(true), IsValid(true) {
|
||||||
Error = new ErrorHolderBase;
|
Error = new ErrorHolderBase;
|
||||||
Error->Error = EC;
|
Error->Error = EC;
|
||||||
@ -387,6 +397,22 @@ class ErrorOr<void> {
|
|||||||
public:
|
public:
|
||||||
ErrorOr() : Error(0, 0) {}
|
ErrorOr() : Error(0, 0) {}
|
||||||
|
|
||||||
|
template <class E>
|
||||||
|
ErrorOr(E ErrorCode, typename enable_if_c<is_error_code_enum<E>::value ||
|
||||||
|
is_error_condition_enum<E>::value,
|
||||||
|
void *> ::type = 0)
|
||||||
|
: Error(0, 0) {
|
||||||
|
error_code EC = make_error_code(ErrorCode);
|
||||||
|
if (EC == errc::success) {
|
||||||
|
Error.setInt(1);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
ErrorHolderBase *EHB = new ErrorHolderBase;
|
||||||
|
EHB->Error = EC;
|
||||||
|
EHB->HasUserData = false;
|
||||||
|
Error.setPointer(EHB);
|
||||||
|
}
|
||||||
|
|
||||||
ErrorOr(llvm::error_code EC) : Error(0, 0) {
|
ErrorOr(llvm::error_code EC) : Error(0, 0) {
|
||||||
if (EC == errc::success) {
|
if (EC == errc::success) {
|
||||||
Error.setInt(1);
|
Error.setInt(1);
|
||||||
|
@ -18,7 +18,7 @@ using namespace llvm;
|
|||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
ErrorOr<int> t1() {return 1;}
|
ErrorOr<int> t1() {return 1;}
|
||||||
ErrorOr<int> t2() {return make_error_code(errc::invalid_argument);}
|
ErrorOr<int> t2() { return errc::invalid_argument; }
|
||||||
|
|
||||||
TEST(ErrorOr, SimpleValue) {
|
TEST(ErrorOr, SimpleValue) {
|
||||||
ErrorOr<int> a = t1();
|
ErrorOr<int> a = t1();
|
||||||
@ -45,8 +45,8 @@ TEST(ErrorOr, Types) {
|
|||||||
*a = 42;
|
*a = 42;
|
||||||
EXPECT_EQ(42, x);
|
EXPECT_EQ(42, x);
|
||||||
|
|
||||||
EXPECT_FALSE(ErrorOr<void>(make_error_code(errc::broken_pipe)));
|
EXPECT_FALSE(ErrorOr<void>(errc::broken_pipe));
|
||||||
EXPECT_TRUE(ErrorOr<void>(make_error_code(errc::success)));
|
EXPECT_TRUE(ErrorOr<void>(errc::success));
|
||||||
|
|
||||||
#if LLVM_HAS_CXX11_STDLIB
|
#if LLVM_HAS_CXX11_STDLIB
|
||||||
// Move only types.
|
// Move only types.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user