/*============================================================================ CMake - Cross Platform Makefile Generator Copyright 2000-2009 Kitware, Inc., Insight Software Consortium Distributed under the OSI-approved BSD License (the "License"); see accompanying file Copyright.txt for details. This software is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the License for more information. ============================================================================*/ /** * Include header files as a function of the build process, compiler, * and operating system. */ #ifndef cmStandardIncludes_h #define cmStandardIncludes_h #include <cmConfigure.h> #include <cmsys/Configure.hxx> #ifdef _MSC_VER #pragma warning ( disable : 4786 ) #pragma warning ( disable : 4503 ) #pragma warning ( disable : 4512 ) /* operator=() could not be generated */ #endif #ifdef __ICL #pragma warning ( disable : 985 ) #pragma warning ( disable : 1572 ) /* floating-point equality test */ #endif // Provide fixed-size integer types. #include <cmIML/INT.h> // Include stream compatibility layer from KWSys. // This is needed to work with large file support // on some platforms whose stream operators do not // support the large integer types. #if defined(CMAKE_BUILD_WITH_CMAKE) # include <cmsys/IOStream.hxx> #endif // Avoid warnings in system headers. #if defined(_MSC_VER) # pragma warning (push,1) #endif #include <fstream> #include <iostream> #include <iomanip> #include <sstream> // we must have stl with the standard include style #include <vector> #include <string> #include <iterator> #include <algorithm> #include <functional> #include <map> #include <list> #include <set> #include <deque> #if defined(_MSC_VER) # pragma warning(pop) #endif // include the "c" string header #include <string.h> #include <stdio.h> #include <stdlib.h> #if defined( _MSC_VER ) typedef unsigned short mode_t; #endif // use this class to shrink the size of symbols in .o files // std::string is really basic_string<....lots of stuff....> // when combined with a map or set, the symbols can be > 2000 chars! #include <cmsys/String.hxx> //typedef cmsys::String std::string; /* Poison this operator to avoid common mistakes. */ extern void operator << (std::ostream&, const std::ostringstream&); /** Standard documentation entry for cmDocumentation's formatting. */ struct cmDocumentationEntry { std::string Name; std::string Brief; cmDocumentationEntry(){} cmDocumentationEntry(const char *doc[2]) { if (doc[0]) this->Name = doc[0]; if (doc[1]) this->Brief = doc[1];} cmDocumentationEntry(const char *n, const char *b) { if (n) this->Name = n; if (b) this->Brief = b; } }; /** Data structure to represent a single command line. */ class cmCustomCommandLine: public std::vector<std::string> { public: typedef std::vector<std::string> Superclass; typedef Superclass::iterator iterator; typedef Superclass::const_iterator const_iterator; }; /** Data structure to represent a list of command lines. */ class cmCustomCommandLines: public std::vector<cmCustomCommandLine> { public: typedef std::vector<cmCustomCommandLine> Superclass; typedef Superclass::iterator iterator; typedef Superclass::const_iterator const_iterator; }; // All subclasses of cmCommand or cmCTestGenericHandler should // invoke this macro. #define cmTypeMacro(thisClass,superclass) \ virtual const char* GetNameOfClass() { return #thisClass; } \ typedef superclass Superclass; \ static bool IsTypeOf(const char *type) \ { \ if ( !strcmp(#thisClass,type) ) \ { \ return true; \ } \ return Superclass::IsTypeOf(type); \ } \ virtual bool IsA(const char *type) \ { \ return thisClass::IsTypeOf(type); \ } \ static thisClass* SafeDownCast(cmObject *c) \ { \ if ( c && c->IsA(#thisClass) ) \ { \ return static_cast<thisClass *>(c); \ } \ return 0;\ } \ class cmTypeMacro_UseTrailingSemicolon template<typename Range> std::string cmJoin(Range const& r, const char* delimiter) { if (r.empty()) { return std::string(); } std::ostringstream os; typedef typename Range::value_type ValueType; typedef typename Range::const_iterator InputIt; InputIt first = r.begin(); InputIt last = r.end(); --last; std::copy(first, last, std::ostream_iterator<ValueType>(os, delimiter)); os << *last; return os.str(); } template<typename Range> std::string cmJoin(Range const& r, std::string delimiter) { return cmJoin(r, delimiter.c_str()); }; inline bool cmHasLiteralPrefixImpl(const std::string &str1, const char *str2, size_t N) { return strncmp(str1.c_str(), str2, N) == 0; } inline bool cmHasLiteralPrefixImpl(const char* str1, const char *str2, size_t N) { return strncmp(str1, str2, N) == 0; } inline bool cmHasLiteralSuffixImpl(const std::string &str1, const char *str2, size_t N) { size_t len = str1.size(); return len >= N && strcmp(str1.c_str() + len - N, str2) == 0; } inline bool cmHasLiteralSuffixImpl(const char* str1, const char* str2, size_t N) { size_t len = strlen(str1); return len >= N && strcmp(str1 + len - N, str2) == 0; } template<typename T, size_t N> const T* cmArrayBegin(const T (&a)[N]) { return a; } template<typename T, size_t N> const T* cmArrayEnd(const T (&a)[N]) { return a + N; } template<typename T, size_t N> size_t cmArraySize(const T (&)[N]) { return N; } template<typename T, size_t N> bool cmHasLiteralPrefix(T str1, const char (&str2)[N]) { return cmHasLiteralPrefixImpl(str1, str2, N - 1); } template<typename T, size_t N> bool cmHasLiteralSuffix(T str1, const char (&str2)[N]) { return cmHasLiteralSuffixImpl(str1, str2, N - 1); } struct cmStrCmp { cmStrCmp(const char *test) : m_test(test) {} cmStrCmp(const std::string &test) : m_test(test) {} bool operator()(const std::string& input) const { return m_test == input; } bool operator()(const char * input) const { return strcmp(input, m_test.c_str()) == 0; } private: const std::string m_test; }; namespace ContainerAlgorithms { template<typename Container> struct DefaultDeleter { void operator()(typename Container::value_type value) { delete value; } }; template<typename K, typename V> struct DefaultDeleter<std::map<K, V> > { void operator()(typename std::map<K, V>::value_type value) { delete value.second; } }; } template<typename Container> void cmDeleteAll(Container const& c) { std::for_each(c.begin(), c.end(), ContainerAlgorithms::DefaultDeleter<Container>()); } #endif