⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 suffix.hpp

📁 system C源码 一种替代verilog的语言
💻 HPP
📖 第 1 页 / 共 2 页
字号:
#  undef BOOST_HAS_ABI_HEADERS#endif//  BOOST_NO_STDC_NAMESPACE workaround  --------------------------------------////  Because std::size_t usage is so common, even in boost headers which do not//  otherwise use the C library, the <cstddef> workaround is included here so//  that ugly workaround code need not appear in many other boost headers.//  NOTE WELL: This is a workaround for non-conforming compilers; <cstddef>//  must still be #included in the usual places so that <cstddef> inclusion//  works as expected with standard conforming compilers.  The resulting//  double inclusion of <cstddef> is harmless.# ifdef BOOST_NO_STDC_NAMESPACE#   include <cstddef>    namespace std { using ::ptrdiff_t; using ::size_t; }# endif//  Workaround for the unfortunate min/max macros defined by some platform headers#define BOOST_PREVENT_MACRO_SUBSTITUTION#ifndef BOOST_USING_STD_MIN#  define BOOST_USING_STD_MIN() using std::min#endif#ifndef BOOST_USING_STD_MAX#  define BOOST_USING_STD_MAX() using std::max#endif//  BOOST_NO_STD_MIN_MAX workaround  -----------------------------------------//#  ifdef BOOST_NO_STD_MIN_MAXnamespace std {  template <class _Tp>  inline const _Tp& min BOOST_PREVENT_MACRO_SUBSTITUTION (const _Tp& __a, const _Tp& __b) {    return __b < __a ? __b : __a;  }  template <class _Tp>  inline const _Tp& max BOOST_PREVENT_MACRO_SUBSTITUTION (const _Tp& __a, const _Tp& __b) {    return  __a < __b ? __b : __a;  }}#  endif// BOOST_STATIC_CONSTANT workaround --------------------------------------- //// On compilers which don't allow in-class initialization of static integral// constant members, we must use enums as a workaround if we want the constants// to be available at compile-time. This macro gives us a convenient way to// declare such constants.#  ifdef BOOST_NO_INCLASS_MEMBER_INITIALIZATION#       define BOOST_STATIC_CONSTANT(type, assignment) enum { assignment }#  else#     define BOOST_STATIC_CONSTANT(type, assignment) static const type assignment#  endif// BOOST_USE_FACET / HAS_FACET workaround ----------------------------------//// When the standard library does not have a conforming std::use_facet there// are various workarounds available, but they differ from library to library.// The same problem occurs with has_facet.// These macros provide a consistent way to access a locale's facets.// Usage://    replace//       std::use_facet<Type>(loc);//    with//       BOOST_USE_FACET(Type, loc);//    Note do not add a std:: prefix to the front of BOOST_USE_FACET!//  Use for BOOST_HAS_FACET is analagous.#if defined(BOOST_NO_STD_USE_FACET)#  ifdef BOOST_HAS_TWO_ARG_USE_FACET#     define BOOST_USE_FACET(Type, loc) std::use_facet(loc, static_cast<Type*>(0))#     define BOOST_HAS_FACET(Type, loc) std::has_facet(loc, static_cast<Type*>(0))#  elif defined(BOOST_HAS_MACRO_USE_FACET)#     define BOOST_USE_FACET(Type, loc) std::_USE(loc, Type)#     define BOOST_HAS_FACET(Type, loc) std::_HAS(loc, Type)#  elif defined(BOOST_HAS_STLP_USE_FACET)#     define BOOST_USE_FACET(Type, loc) (*std::_Use_facet<Type >(loc))#     define BOOST_HAS_FACET(Type, loc) std::has_facet< Type >(loc)#  endif#else#  define BOOST_USE_FACET(Type, loc) std::use_facet< Type >(loc)#  define BOOST_HAS_FACET(Type, loc) std::has_facet< Type >(loc)#endif// BOOST_NESTED_TEMPLATE workaround ------------------------------------------//// Member templates are supported by some compilers even though they can't use// the A::template member<U> syntax, as a workaround replace://// typedef typename A::template rebind<U> binder;//// with://// typedef typename A::BOOST_NESTED_TEMPLATE rebind<U> binder;#ifndef BOOST_NO_MEMBER_TEMPLATE_KEYWORD#  define BOOST_NESTED_TEMPLATE template#else#  define BOOST_NESTED_TEMPLATE#endif// BOOST_UNREACHABLE_RETURN(x) workaround -------------------------------------//// Normally evaluates to nothing, unless BOOST_NO_UNREACHABLE_RETURN_DETECTION// is defined, in which case it evaluates to return x; Use when you have a return// statement that can never be reached.#ifdef BOOST_NO_UNREACHABLE_RETURN_DETECTION#  define BOOST_UNREACHABLE_RETURN(x) return x;#else#  define BOOST_UNREACHABLE_RETURN(x)#endif// BOOST_DEDUCED_TYPENAME workaround ------------------------------------------////// Some compilers don't support the use of `typename' for dependent// types in deduced contexts, e.g.////     template <class T> void f(T, typename T::type);//                                  ^^^^^^^^// Replace these declarations with:////     template <class T> void f(T, BOOST_DEDUCED_TYPENAME T::type);#ifndef BOOST_NO_DEDUCED_TYPENAME#  define BOOST_DEDUCED_TYPENAME typename#else#  define BOOST_DEDUCED_TYPENAME#endif// long long workaround ------------------------------------------//// On gcc (and maybe other compilers?) long long is alway supported// but it's use may generate either warnings (with -ansi), or errors// (with -pedantic -ansi) unless it's use is prefixed by __extension__//#if defined(BOOST_HAS_LONG_LONG)namespace boost{#  ifdef __GNUC__   __extension__ typedef long long long_long_type;   __extension__ typedef unsigned long long ulong_long_type;#  else   typedef long long long_long_type;   typedef unsigned long long ulong_long_type;#  endif}#endif// BOOST_[APPEND_]EXPLICIT_TEMPLATE_[NON_]TYPE macros --------------------------////// Some compilers have problems with function templates whose// template parameters don't appear in the function parameter// list (basically they just link one instantiation of the// template in the final executable). These macros provide a// uniform way to cope with the problem with no effects on the// calling syntax.// Example:////  #include <iostream>//  #include <ostream>//  #include <typeinfo>////  template <int n>//  void f() { std::cout << n << ' '; }////  template <typename T>//  void g() { std::cout << typeid(T).name() << ' '; }////  int main() {//    f<1>();//    f<2>();////    g<int>();//    g<double>();//  }//// With VC++ 6.0 the output is:////   2 2 double double//// To fix it, write////   template <int n>//   void f(BOOST_EXPLICIT_TEMPLATE_NON_TYPE(int, n)) { ... }////   template <typename T>//   void g(BOOST_EXPLICIT_TEMPLATE_TYPE(T)) { ... }//#if defined BOOST_NO_EXPLICIT_FUNCTION_TEMPLATE_ARGUMENTS#  include "sysc/packages/boost/type.hpp"#  include "sysc/packages/boost/non_type.hpp"#  define BOOST_EXPLICIT_TEMPLATE_TYPE(t)         boost::type<t>* = 0#  define BOOST_EXPLICIT_TEMPLATE_TYPE_SPEC(t)    boost::type<t>*#  define BOOST_EXPLICIT_TEMPLATE_NON_TYPE(t, v)  boost::non_type<t, v>* = 0#  define BOOST_EXPLICIT_TEMPLATE_NON_TYPE_SPEC(t, v)  boost::non_type<t, v>*#  define BOOST_APPEND_EXPLICIT_TEMPLATE_TYPE(t)         \             , BOOST_EXPLICIT_TEMPLATE_TYPE(t)#  define BOOST_APPEND_EXPLICIT_TEMPLATE_TYPE_SPEC(t)    \             , BOOST_EXPLICIT_TEMPLATE_TYPE_SPEC(t)#  define BOOST_APPEND_EXPLICIT_TEMPLATE_NON_TYPE(t, v)  \             , BOOST_EXPLICIT_TEMPLATE_NON_TYPE(t, v)#  define BOOST_APPEND_EXPLICIT_TEMPLATE_NON_TYPE_SPEC(t, v)  \             , BOOST_EXPLICIT_TEMPLATE_NON_TYPE_SPEC(t, v)#else// no workaround needed: expand to nothing#  define BOOST_EXPLICIT_TEMPLATE_TYPE(t)#  define BOOST_EXPLICIT_TEMPLATE_TYPE_SPEC(t)#  define BOOST_EXPLICIT_TEMPLATE_NON_TYPE(t, v)#  define BOOST_EXPLICIT_TEMPLATE_NON_TYPE_SPEC(t, v)#  define BOOST_APPEND_EXPLICIT_TEMPLATE_TYPE(t)#  define BOOST_APPEND_EXPLICIT_TEMPLATE_TYPE_SPEC(t)#  define BOOST_APPEND_EXPLICIT_TEMPLATE_NON_TYPE(t, v)#  define BOOST_APPEND_EXPLICIT_TEMPLATE_NON_TYPE_SPEC(t, v)#endif // defined BOOST_NO_EXPLICIT_FUNCTION_TEMPLATE_ARGUMENTS// ---------------------------------------------------------------------------////// Helper macro BOOST_STRINGIZE:// Converts the parameter X to a string after macro replacement// on X has been performed.//#define BOOST_STRINGIZE(X) BOOST_DO_STRINGIZE(X)#define BOOST_DO_STRINGIZE(X) #X//// Helper macro BOOST_JOIN:// The following piece of macro magic joins the two// arguments together, even when one of the arguments is// itself a macro (see 16.3.1 in C++ standard).  The key// is that macro expansion of macro arguments does not// occur in BOOST_DO_JOIN2 but does in BOOST_DO_JOIN.//#define BOOST_JOIN( X, Y ) BOOST_DO_JOIN( X, Y )#define BOOST_DO_JOIN( X, Y ) BOOST_DO_JOIN2(X,Y)#define BOOST_DO_JOIN2( X, Y ) X##Y//// Set some default values for compiler/library/platform names.// These are for debugging config setup only://#  ifndef BOOST_COMPILER#     define BOOST_COMPILER "Unknown ISO C++ Compiler"#  endif#  ifndef BOOST_STDLIB#     define BOOST_STDLIB "Unknown ISO standard library"#  endif#  ifndef BOOST_PLATFORM#     if defined(unix) || defined(__unix) || defined(_XOPEN_SOURCE) \         || defined(_POSIX_SOURCE)#        define BOOST_PLATFORM "Generic Unix"#     else#        define BOOST_PLATFORM "Unknown"#     endif#  endif#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -