// file : build/utility -*- C++ -*- // copyright : Copyright (c) 2014-2015 Code Synthesis Tools CC // license : MIT; see accompanying LICENSE file #ifndef BUILD_UTILITY #define BUILD_UTILITY #include #include #include #include // strcmp #include #include namespace build { struct compare_c_string { bool operator() (const char* x, const char* y) const { return std::strcmp (x, y) < 0; } }; struct compare_pointer_target { template bool operator() (const P& x, const P& y) const {return *x < *y;} }; // Call a function if there is an exception. // // Means we are in the body of a destructor that is being called // as part of the exception stack unwindining. Used to compensate // for the deficiencies of uncaught_exception() until C++17 // uncaught_exceptions() becomes available. // // @@ MT: will have to be TLS. // extern bool exception_unwinding_dtor; template struct exception_guard; template inline exception_guard> make_exception_guard (F f, A&&... a) { return exception_guard> ( std::move (f), std::forward_as_tuple (a...)); } template struct exception_guard> { typedef std::tuple T; exception_guard (F f, T a): f_ (std::move (f)), a_ (std::move (a)) {} ~exception_guard () { if (std::uncaught_exception ()) { exception_unwinding_dtor = true; call (std::index_sequence_for ()); exception_unwinding_dtor = false; } } private: template void call (std::index_sequence) {f_ (std::get (a_)...);} F f_; T a_; }; // Pools (@@ perhaps move into a separate header). // struct string_pool: std::unordered_set { const std::string& find (const char* s) {return *emplace (s).first;} }; extern string_pool extension_pool; } #endif // BUILD_UTILITY