// UsingDirective.cpp : Defines the entry point for the console application.
//
#include "stdafx.h"
#include <iostream>
using namespace std;
#pragma once
#include <type_traits>
#pragma region CheckForFailureSignalPolicy
template<class Exception>
struct ThrowOnFailure;
template<class Exception>
struct NullOnFailure;
template<template<class>class FailureSignalPolicy>
struct IsThrowOnFailure;
template<>
struct IsThrowOnFailure<ThrowOnFailure>
{
enum {value = 1};
};
template<>
struct IsThrowOnFailure<NullOnFailure>
{
enum {value = 0};
};
#pragma endregion
template<int v>
struct Int2Type
{};
template<template<class> class FailurePolicy,class ExceptionType >
struct IReportFailure
{
enum {isThrowing = IsThrowOnFailure<FailurePolicy>::value};
#pragma region empty
static auto reportFailure()-> typename std::conditional<isThrowing,void,std::nullptr_t>::type
{
return rprt_help(Int2Type<isThrowing>());
}
static void rprt_help(Int2Type<true>)
{
throw ExceptionType();
}
static std::nullptr_t rprt_help(Int2Type<false>)
{
return nullptr;
}
#pragma endregion
//******************************************
template<class Argument>
static auto reportFailure(const Argument& arg)-> typename std::conditional<isThrowing,void,std::nullptr_t>::type
{
return rprt_help(const Argument& arg,Int2Type<isThrowing>());
}
template<class Argument>
static void rprt_help(const Argument& arg,Int2Type<true>)
{
throw ExceptionType(arg);
}
template<class Argument>
static std::nullptr_t rprt_help(const Argument& arg,Int2Type<false>)
{
return nullptr;
}
#pragma region ExceptionType
static auto reportFailure(const ExceptionType& ex)-> typename std::conditional<isThrowing,void,std::nullptr_t>::type
{
return rprt_help(const ExceptionType& ex,Int2Type<isThrowing>());
}
static void rprt_help(const ExceptionType& ex,Int2Type<true>)
{
throw ExceptionType(ex);
}
static std::nullptr_t rprt_help(const ExceptionType& ex,Int2Type<false>)
{
return nullptr;
}
#pragma endregion
};
template<template<class> class FailurePolicy, class ExceptionType>
struct FailureSignalPolicy
{
enum {isThrowing = IsThrowOnFailure<FailurePolicy>::value};
static auto
signalFailure() -> typename std::conditional<IsThrowOnFailure<FailurePolicy>::value,void,std::nullptr_t>::type
{
return IReportFailure<FailurePolicy,ExceptionType>::reportFailure();
}
static auto
signalFailure(const ExceptionType& ex) -> typename std::conditional<IsThrowOnFailure<FailurePolicy>::value,void,std::nullptr_t>::type
{
return IReportFailure<FailurePolicy,ExceptionType>::reportFailure(ex);
}
///*******************************************
template<class Argument>
static auto
signalFailure(const Argument& arg) -> typename std::conditional<IsThrowOnFailure<FailurePolicy>::value,void,std::nullptr_t>::type
{
return IReportFailure<FailurePolicy,ExceptionType>::reportFailure(arg);
}
};
template<class ExceptionType>
struct ThrowOnFailure : private FailureSignalPolicy<ThrowOnFailure,ExceptionType>
{
using FailureSignalPolicy< ::ThrowOnFailure,ExceptionType>::signalFailure;
};
template<class ExceptionType>
struct NullOnFailure : private FailureSignalPolicy<NullOnFailure,ExceptionType>
{
using FailureSignalPolicy< ::NullOnFailure,ExceptionType>::signalFailure;
};
int _tmain(int argc, _TCHAR* argv[])
{
try
{
/*ThrowOnFailure<int>::signalFailure();
NullOnFailure<int>::signalFailure();*/
ThrowOnFailure<std::out_of_range>::signalFailure(1);
}
catch(...)
{
}
return 0;
}
试图编译这个我得到了古怪的错误:
错误1错误C2143:语法错误:在'const'之前缺少')'
错误2错误C2661:'IReportFailure :: rprt_help':没有重载函数需要0个参数
错误3错误C2059:语法错误:')'
有问题的fnc在代码中标有 * ** *
答案 0 :(得分:2)
IReportFailure::reportFailure
的正文应更改为:
return rprt_help(arg, Int2Type<isThrowing>());