// Matrix Construct // // Copyright (C) Matrix Construct Developers, Authors & Contributors // Copyright (C) 2016-2018 Jason Volk // // Permission to use, copy, modify, and/or distribute this software for any // purpose with or without fee is hereby granted, provided that the above // copyright notice and this permission notice is present in all copies. The // full license for this software is available in the LICENSE file. #define HAVE_IRCD_STDINC_H /////////////////////////////////////////////////////////////////////////////// // // Standard includes // // This header includes almost everything we use out of the standard library. // This is a pre-compiled header. Project build time is significantly reduced // by doing things this way and C++ std headers have very little namespace // pollution and risk of conflicts. // // This pragma overrides any -fvisibility option on any unit to maintain // consistent default visibility of these items. #pragma GCC visibility push(default) // Windows Specific #ifdef _WIN32 #define WIN32_LEAN_AND_MEAN 1 #include // // Pollution // // This section lists all of the items introduced outside of our namespace // which may conflict with your project. // // Experimental std::string_view #if !defined(__cpp_lib_string_view) && defined(__cpp_lib_experimental_string_view) namespace std { using experimental::string_view; } #endif // Experimental std::optional #if !defined(__cpp_lib_optional) && defined(__cpp_lib_experimental_optional) namespace std { using experimental::optional; } #endif // Forward declare the existence of these in std:: to allow their immediate // use throughout the project as a developer convenience. is not // included here because it generates naive initialization code in every unit, // whereas we conduct it once for libircd in the right place. namespace std { extern istream cin; extern ostream cout; extern ostream cerr; } /////////////////////////////////////////////////////////////////////////////// // // libircd API // // Convenience short-hands for POD-types available in ircd:: namespace ircd { // 128-bit using u128 = uint128_t; using i128 = int128_t; using f128 = long double; // 64-bit using u64 = uint64_t; using i64 = int64_t; using f64 = double; // 32-bit using u32 = uint32_t; using i32 = int32_t; using c32 = char32_t; using f32 = float; // 16-bit using u16 = uint16_t; using i16 = int16_t; using c16 = char16_t; #if defined(HAVE__FLOAT16) #define HAVE_FP16 using f16 = _Float16; #elif defined(HAVE___FP16) #define HAVE_FP16 using f16 = __fp16; #elif defined(__clang__) #warning "Missing half-precision floating point support." #endif // 8-bit using u8 = uint8_t; using i8 = int8_t; #ifdef HAVE_CHAR8_T using c8 = char8_t; #endif #if defined(HAVE___FP8) #define HAVE_FP8 using f8 = __fp8; #endif } // Various standard library items imported into our namespace. namespace ircd { using std::get; using std::end; using std::begin; using std::nullptr_t; using std::nothrow_t; using std::const_pointer_cast; using std::static_pointer_cast; using std::dynamic_pointer_cast; using std::chrono::hours; using std::chrono::minutes; using std::chrono::seconds; using std::chrono::milliseconds; using std::chrono::microseconds; using std::chrono::nanoseconds; using std::chrono::duration; using std::chrono::duration_cast; using std::chrono::system_clock; using std::chrono::steady_clock; using std::chrono::high_resolution_clock; using std::chrono::time_point; using namespace std::string_literals; using namespace std::chrono_literals; using namespace std::literals::chrono_literals; using std::string_literals::operator""s; using std::chrono_literals::operator""s; namespace ph = std::placeholders; template using ilist = std::initializer_list; using std::error_code; /// Simple gimmick to allow shorter declarations when both elements /// of a pair are the same. template using pair = std::pair; } #pragma GCC visibility pop // default