2009-09-28 19:43:28 +04:00
|
|
|
/*============================================================================
|
|
|
|
CMake - Cross Platform Makefile Generator
|
|
|
|
Copyright 2000-2009 Kitware, Inc., Insight Software Consortium
|
2001-01-11 22:47:38 +03:00
|
|
|
|
2009-09-28 19:43:28 +04:00
|
|
|
Distributed under the OSI-approved BSD License (the "License");
|
|
|
|
see accompanying file Copyright.txt for details.
|
2001-01-11 22:47:38 +03:00
|
|
|
|
2009-09-28 19:43:28 +04:00
|
|
|
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.
|
|
|
|
============================================================================*/
|
2001-01-11 22:47:38 +03:00
|
|
|
/**
|
|
|
|
* Include header files as a function of the build process, compiler,
|
|
|
|
* and operating system.
|
|
|
|
*/
|
2001-01-05 19:41:20 +03:00
|
|
|
#ifndef cmStandardIncludes_h
|
|
|
|
#define cmStandardIncludes_h
|
|
|
|
|
2009-11-10 16:09:54 +03:00
|
|
|
#include <cmConfigure.h>
|
2006-08-23 18:00:11 +04:00
|
|
|
#include <cmsys/Configure.hxx>
|
2001-01-05 19:41:20 +03:00
|
|
|
|
|
|
|
#ifdef _MSC_VER
|
|
|
|
#pragma warning ( disable : 4786 )
|
2001-07-06 17:22:41 +04:00
|
|
|
#pragma warning ( disable : 4503 )
|
2006-08-29 18:27:50 +04:00
|
|
|
#pragma warning ( disable : 4512 ) /* operator=() could not be generated */
|
2001-01-05 19:41:20 +03:00
|
|
|
#endif
|
|
|
|
|
2006-08-01 19:38:42 +04:00
|
|
|
|
2001-03-21 23:52:29 +03:00
|
|
|
#ifdef __ICL
|
|
|
|
#pragma warning ( disable : 985 )
|
2009-11-24 16:57:06 +03:00
|
|
|
#pragma warning ( disable : 1572 ) /* floating-point equality test */
|
2001-03-21 23:52:29 +03:00
|
|
|
#endif
|
|
|
|
|
2014-02-11 00:31:40 +04:00
|
|
|
// Provide fixed-size integer types.
|
|
|
|
#include <cmIML/INT.h>
|
|
|
|
|
2006-08-27 21:23:54 +04:00
|
|
|
// 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
|
|
|
|
|
2006-08-29 18:27:50 +04:00
|
|
|
// Avoid warnings in system headers.
|
|
|
|
#if defined(_MSC_VER)
|
|
|
|
# pragma warning (push,1)
|
|
|
|
#endif
|
|
|
|
|
2015-01-05 22:33:18 +03:00
|
|
|
#include <fstream>
|
|
|
|
#include <iostream>
|
|
|
|
#include <iomanip>
|
|
|
|
#include <sstream>
|
2001-01-05 19:41:20 +03:00
|
|
|
|
2001-08-08 19:54:46 +04:00
|
|
|
// we must have stl with the standard include style
|
2001-01-05 19:41:20 +03:00
|
|
|
#include <vector>
|
|
|
|
#include <string>
|
|
|
|
#include <iterator>
|
|
|
|
#include <algorithm>
|
|
|
|
#include <functional>
|
|
|
|
#include <map>
|
2001-02-13 03:49:52 +03:00
|
|
|
#include <list>
|
2001-04-24 00:40:29 +04:00
|
|
|
#include <set>
|
2005-06-01 16:25:21 +04:00
|
|
|
#include <deque>
|
2001-01-05 19:41:20 +03:00
|
|
|
|
2006-08-29 18:27:50 +04:00
|
|
|
#if defined(_MSC_VER)
|
|
|
|
# pragma warning(pop)
|
|
|
|
#endif
|
|
|
|
|
2001-08-08 19:54:46 +04:00
|
|
|
// include the "c" string header
|
2001-06-22 20:18:10 +04:00
|
|
|
#include <string.h>
|
2003-08-08 19:19:17 +04:00
|
|
|
#include <stdio.h>
|
2005-03-11 18:03:56 +03:00
|
|
|
#include <stdlib.h>
|
2001-06-22 20:18:10 +04:00
|
|
|
|
2004-01-27 17:05:01 +03:00
|
|
|
#if defined( _MSC_VER )
|
2004-01-26 23:03:09 +03:00
|
|
|
typedef unsigned short mode_t;
|
|
|
|
#endif
|
|
|
|
|
2001-09-15 00:26:56 +04:00
|
|
|
// use this class to shrink the size of symbols in .o files
|
2001-08-24 00:00:46 +04:00
|
|
|
// std::string is really basic_string<....lots of stuff....>
|
|
|
|
// when combined with a map or set, the symbols can be > 2000 chars!
|
2006-02-07 18:11:40 +03:00
|
|
|
#include <cmsys/String.hxx>
|
2014-02-10 09:21:34 +04:00
|
|
|
//typedef cmsys::String std::string;
|
2002-06-19 23:21:49 +04:00
|
|
|
|
2004-04-29 22:51:08 +04:00
|
|
|
/* Poison this operator to avoid common mistakes. */
|
2015-01-05 22:31:31 +03:00
|
|
|
extern void operator << (std::ostream&, const std::ostringstream&);
|
2004-04-29 22:51:08 +04:00
|
|
|
|
2003-02-14 18:53:37 +03:00
|
|
|
/** Standard documentation entry for cmDocumentation's formatting. */
|
|
|
|
struct cmDocumentationEntry
|
|
|
|
{
|
2007-10-22 20:49:09 +04:00
|
|
|
std::string Name;
|
|
|
|
std::string Brief;
|
2014-04-03 23:35:22 +04:00
|
|
|
cmDocumentationEntry(){}
|
2013-09-16 22:04:39 +04:00
|
|
|
cmDocumentationEntry(const char *doc[2])
|
2012-08-13 21:42:58 +04:00
|
|
|
{ if (doc[0]) this->Name = doc[0];
|
2014-04-03 23:35:22 +04:00
|
|
|
if (doc[1]) this->Brief = doc[1];}
|
2013-09-16 22:04:39 +04:00
|
|
|
cmDocumentationEntry(const char *n, const char *b)
|
2014-04-03 23:35:22 +04:00
|
|
|
{ if (n) this->Name = n; if (b) this->Brief = b; }
|
2003-02-14 18:53:37 +03:00
|
|
|
};
|
|
|
|
|
2005-02-22 16:22:38 +03:00
|
|
|
/** 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;
|
|
|
|
};
|
|
|
|
|
2012-08-13 21:42:58 +04:00
|
|
|
// All subclasses of cmCommand or cmCTestGenericHandler should
|
2006-03-10 19:13:15 +03:00
|
|
|
// invoke this macro.
|
2005-06-17 21:04:56 +04:00
|
|
|
#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) ) \
|
|
|
|
{ \
|
2006-07-13 17:27:10 +04:00
|
|
|
return static_cast<thisClass *>(c); \
|
2005-06-17 21:04:56 +04:00
|
|
|
} \
|
|
|
|
return 0;\
|
2014-04-03 23:28:10 +04:00
|
|
|
} \
|
|
|
|
class cmTypeMacro_UseTrailingSemicolon
|
2005-06-17 21:04:56 +04:00
|
|
|
|
2015-01-07 10:21:29 +03:00
|
|
|
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());
|
|
|
|
};
|
|
|
|
|
2013-11-20 05:12:48 +04:00
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
2013-12-30 19:09:46 +04:00
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
2013-10-22 03:02:49 +04:00
|
|
|
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; }
|
|
|
|
|
2013-11-20 05:12:48 +04:00
|
|
|
template<typename T, size_t N>
|
|
|
|
bool cmHasLiteralPrefix(T str1, const char (&str2)[N])
|
|
|
|
{
|
|
|
|
return cmHasLiteralPrefixImpl(str1, str2, N - 1);
|
|
|
|
}
|
|
|
|
|
2013-12-30 19:09:46 +04:00
|
|
|
template<typename T, size_t N>
|
|
|
|
bool cmHasLiteralSuffix(T str1, const char (&str2)[N])
|
|
|
|
{
|
|
|
|
return cmHasLiteralSuffixImpl(str1, str2, N - 1);
|
|
|
|
}
|
|
|
|
|
2013-10-22 03:02:49 +04:00
|
|
|
struct cmStrCmp {
|
|
|
|
cmStrCmp(const char *test) : m_test(test) {}
|
2014-01-17 22:38:27 +04:00
|
|
|
cmStrCmp(const std::string &test) : m_test(test) {}
|
|
|
|
|
|
|
|
bool operator()(const std::string& input) const
|
|
|
|
{
|
|
|
|
return m_test == input;
|
|
|
|
}
|
2013-10-22 03:02:49 +04:00
|
|
|
|
2013-12-15 03:00:57 +04:00
|
|
|
bool operator()(const char * input) const
|
2013-10-22 03:02:49 +04:00
|
|
|
{
|
2014-01-17 22:38:27 +04:00
|
|
|
return strcmp(input, m_test.c_str()) == 0;
|
2013-10-22 03:02:49 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2014-02-10 09:21:34 +04:00
|
|
|
const std::string m_test;
|
2013-10-22 03:02:49 +04:00
|
|
|
};
|
2005-06-17 21:04:56 +04:00
|
|
|
|
2015-01-04 16:53:24 +03:00
|
|
|
namespace ContainerAlgorithms {
|
|
|
|
|
2015-01-04 17:16:56 +03:00
|
|
|
template<typename T>
|
|
|
|
struct cmIsPair
|
|
|
|
{
|
|
|
|
enum { value = false };
|
|
|
|
};
|
|
|
|
|
|
|
|
template<typename K, typename V>
|
|
|
|
struct cmIsPair<std::pair<K, V> >
|
|
|
|
{
|
|
|
|
enum { value = true };
|
|
|
|
};
|
|
|
|
|
|
|
|
template<typename Container,
|
|
|
|
bool valueTypeIsPair = cmIsPair<typename Container::value_type>::value>
|
2015-01-04 16:53:24 +03:00
|
|
|
struct DefaultDeleter
|
|
|
|
{
|
|
|
|
void operator()(typename Container::value_type value) {
|
|
|
|
delete value;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2015-01-04 17:16:56 +03:00
|
|
|
template<typename Container>
|
|
|
|
struct DefaultDeleter<Container, /* valueTypeIsPair = */ true>
|
2015-01-04 16:53:24 +03:00
|
|
|
{
|
2015-01-04 17:16:56 +03:00
|
|
|
void operator()(typename Container::value_type value) {
|
2015-01-04 16:53:24 +03:00
|
|
|
delete value.second;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
template<typename Container>
|
|
|
|
void cmDeleteAll(Container const& c)
|
|
|
|
{
|
|
|
|
std::for_each(c.begin(), c.end(),
|
|
|
|
ContainerAlgorithms::DefaultDeleter<Container>());
|
|
|
|
}
|
|
|
|
|
2001-01-05 19:41:20 +03:00
|
|
|
#endif
|