功能模板bizzare问题

时间:2010-11-28 19:54:53

标签: c++ templates

    // 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在代码中标有 * ** *

1 个答案:

答案 0 :(得分:2)

IReportFailure::reportFailure的正文应更改为:

return rprt_help(arg, Int2Type<isThrowing>());