CMS 3D CMS Logo

AnyMethodArgument.h
Go to the documentation of this file.
1 #ifndef CommonTools_Utils_AnyMethodArgument_h
2 #define CommonTools_Utils_AnyMethodArgument_h
3 
7 
8 #include <algorithm>
9 #include <string>
10 #include <cstdint>
11 
12 #include <boost/variant.hpp>
13 #include <boost/type_traits/is_same.hpp>
14 #include <boost/type_traits/is_integral.hpp>
15 #include <boost/type_traits/is_floating_point.hpp>
16 #include <boost/utility/enable_if.hpp>
17 #include <boost/mpl/if.hpp>
18 
19 namespace reco {
20  namespace parser {
21 
22  // true if T matches one of the integral types in the default
23  // AnyMethodArgument variant
24  template <typename T>
26  static bool const value =
31  };
32 
33  // size_t on 32-bit Os X is type unsigned long, which doesn't match uint32_t,
34  // so add unsigned long if it doesn't match any of the other integral types.
35  // Use "unsigned long" rather than size_t as PtrVector has unsigned long as
36  // size_type
37  typedef boost::mpl::if_<matches_another_integral_type<unsigned long>,
38  boost::variant<int8_t, uint8_t,
39  int16_t, uint16_t,
40  int32_t, uint32_t,
41  int64_t, uint64_t,
42  double,float,
43  std::string>,
44  boost::variant<int8_t, uint8_t,
45  int16_t, uint16_t,
46  int32_t, uint32_t,
47  int64_t, uint64_t,
48  unsigned long,
49  double,float,
50  std::string> >::type AnyMethodArgument;
51 
52  class AnyMethodArgumentFixup : public boost::static_visitor<std::pair<AnyMethodArgument, int> > {
53  private:
55  template<typename From, typename To>
56  std::pair<AnyMethodArgument, int> retOk_(const From &f, int cast) const {
57  return std::pair<AnyMethodArgument,int>(AnyMethodArgument(static_cast<To>(f)), cast);
58  }
59 
60  // correct return for each int output type
61  std::pair<AnyMethodArgument,int> doInt(int t) const {
62  if (dataType_ == typeid(int8_t)) { return retOk_<int,int8_t> (t,0); }
63  if (dataType_ == typeid(uint8_t)) { return retOk_<int,uint8_t> (t,0); }
64  if (dataType_ == typeid(int16_t)) { return retOk_<int,int16_t> (t,0); }
65  if (dataType_ == typeid(uint16_t)) { return retOk_<int,uint16_t>(t,0); }
66  if (dataType_ == typeid(int32_t)) { return retOk_<int,int32_t> (t,0); }
67  if (dataType_ == typeid(uint32_t)) { return retOk_<int,uint32_t>(t,0); }
68  if (dataType_ == typeid(int64_t)) { return retOk_<int,int64_t> (t,0); }
69  if (dataType_ == typeid(uint64_t)) { return retOk_<int,uint64_t>(t,0); }
70  if (dataType_ == typeid(unsigned long)) { return retOk_<int,unsigned long> (t,0); } // harmless if unsigned long matches another type
71  if (dataType_ == typeid(double)) { return retOk_<int,double> (t,1); }
72  if (dataType_ == typeid(float)) { return retOk_<int,float> (t,1); }
73  return std::pair<AnyMethodArgument,int>(t,-1);
74  }
75  public:
77  dataType_(type)
78  {
79  }
80 
81  // we handle all integer types through 'int', as that's the way they are parsed by boost::spirit
82  template<typename I>
83  typename boost::enable_if<boost::is_integral<I>, std::pair<AnyMethodArgument,int> >::type
84  operator()(const I &t) const { return doInt(t); }
85 
86  template<typename F>
87  typename boost::enable_if<boost::is_floating_point<F>, std::pair<AnyMethodArgument,int> >::type
88  operator()(const F &t) const {
89  if (dataType_ == typeid(double)) { return retOk_<F,double>(t,0); }
90  if (dataType_ == typeid(float)) { return retOk_<F,float> (t,0); }
91  return std::pair<AnyMethodArgument,int>(t,-1);
92  }
93 
94  std::pair<AnyMethodArgument,int> operator()(const std::string &t) const {
95  if (dataType_.isEnum()) {
96  if (dataType_.dataMemberSize() == 0) {
97  throw parser::Exception(t.c_str()) << "Enumerator '" << dataType_.name() << "' has no keys.\nPerhaps the dictionary is missing?\n";
98  }
99  int ival = dataType_.stringToEnumValue(t);
100  // std::cerr << " value is = " << dataType_.stringToEnumValue(t) << std::endl;
101  return std::pair<AnyMethodArgument,int>(ival,1);
102  }
103  if (dataType_ == typeid(std::string)) { return std::pair<AnyMethodArgument,int>(t,0); }
104  return std::pair<AnyMethodArgument,int>(t,-1);
105  }
106 
107  };
108 
109  class AnyMethodArgument2VoidPtr : public boost::static_visitor<void *> {
110  public:
111  template<typename T>
112  void * operator()(const T &t) const { return const_cast<void*>(static_cast<const void *>(&t)); }
113  };
114  }
115 }
116 
117 #endif
type
Definition: HCALResponse.h:21
bool isEnum() const
boost::enable_if< boost::is_integral< I >, std::pair< AnyMethodArgument, int > >::type operator()(const I &t) const
std::pair< AnyMethodArgument, int > operator()(const std::string &t) const
size_t dataMemberSize() const
std::pair< AnyMethodArgument, int > retOk_(const From &f, int cast) const
std::string name() const
const std::complex< double > I
Definition: I.h:8
std::pair< AnyMethodArgument, int > doInt(int t) const
double f[11][100]
Definition: value.py:1
AnyMethodArgumentFixup(const edm::TypeWithDict &type)
int stringToEnumValue(std::string const &) const
boost::mpl::if_< matches_another_integral_type< unsigned long >, boost::variant< int8_t, uint8_t, int16_t, uint16_t, int32_t, uint32_t, int64_t, uint64_t, double, float, std::string >, boost::variant< int8_t, uint8_t, int16_t, uint16_t, int32_t, uint32_t, int64_t, uint64_t, unsigned long, double, float, std::string > >::type AnyMethodArgument
unsigned long long uint64_t
Definition: Time.h:15
boost::enable_if< boost::is_floating_point< F >, std::pair< AnyMethodArgument, int > >::type operator()(const F &t) const
fixed size matrix
static uInt32 F(BLOWFISH_CTX *ctx, uInt32 x)
Definition: blowfish.cc:281
long double T