/usr/include/OGRE/OgreString.h is in libogre-1.9-dev 1.9.0+dfsg1-7+b4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 | /*
-----------------------------------------------------------------------------
This source file is part of OGRE
(Object-oriented Graphics Rendering Engine)
For the latest info, see http://www.ogre3d.org/
Copyright (c) 2000-2013 Torus Knot Software Ltd
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.
-----------------------------------------------------------------------------
*/
#ifndef _String_H__
#define _String_H__
#include "OgrePrerequisites.h"
#include "OgreHeaderPrefix.h"
// If we're using the GCC 3.1 C++ Std lib
#if OGRE_COMPILER == OGRE_COMPILER_GNUC && OGRE_COMP_VER >= 310 && !defined(STLPORT)
// For gcc 4.3 see http://gcc.gnu.org/gcc-4.3/changes.html
# if OGRE_COMP_VER >= 430
# include <tr1/unordered_map>
# else
# include <ext/hash_map>
namespace __gnu_cxx
{
template <> struct hash< Ogre::_StringBase >
{
size_t operator()( const Ogre::_StringBase _stringBase ) const
{
/* This is the PRO-STL way, but it seems to cause problems with VC7.1
and in some other cases (although I can't recreate it)
hash<const char*> H;
return H(_stringBase.c_str());
*/
/** This is our custom way */
register size_t ret = 0;
for( Ogre::_StringBase::const_iterator it = _stringBase.begin(); it != _stringBase.end(); ++it )
ret = 5 * ret + *it;
return ret;
}
};
}
# endif
#endif
namespace Ogre {
/** \addtogroup Core
* @{
*/
/** \addtogroup General
* @{
*/
/** Utility class for manipulating Strings. */
class _OgreExport StringUtil
{
public:
typedef StringStream StrStreamType;
/** Removes any whitespace characters, be it standard space or
TABs and so on.
@remarks
The user may specify whether they want to trim only the
beginning or the end of the String ( the default action is
to trim both).
*/
static void trim( String& str, bool left = true, bool right = true );
/** Returns a StringVector that contains all the substrings delimited
by the characters in the passed <code>delims</code> argument.
@param
delims A list of delimiter characters to split by
@param
maxSplits The maximum number of splits to perform (0 for unlimited splits). If this
parameters is > 0, the splitting process will stop after this many splits, left to right.
@param
preserveDelims Flag to determine if delimiters should be saved as substrings
*/
static vector<String>::type split( const String& str, const String& delims = "\t\n ", unsigned int maxSplits = 0, bool preserveDelims = false);
/** Returns a StringVector that contains all the substrings delimited
by the characters in the passed <code>delims</code> argument,
or in the <code>doubleDelims</code> argument, which is used to include (normal)
delimeters in the tokenised string. For example, "strings like this".
@param
delims A list of delimiter characters to split by
@param
doubleDelims A list of double delimeters characters to tokenise by
@param
maxSplits The maximum number of splits to perform (0 for unlimited splits). If this
parameters is > 0, the splitting process will stop after this many splits, left to right.
*/
static vector<String>::type tokenise( const String& str, const String& delims = "\t\n ", const String& doubleDelims = "\"", unsigned int maxSplits = 0);
/** Lower-cases all the characters in the string.
*/
static void toLowerCase( String& str );
/** Upper-cases all the characters in the string.
*/
static void toUpperCase( String& str );
/** Returns whether the string begins with the pattern passed in.
@param pattern The pattern to compare with.
@param lowerCase If true, the start of the string will be lower cased before
comparison, pattern should also be in lower case.
*/
static bool startsWith(const String& str, const String& pattern, bool lowerCase = true);
/** Returns whether the string ends with the pattern passed in.
@param pattern The pattern to compare with.
@param lowerCase If true, the end of the string will be lower cased before
comparison, pattern should also be in lower case.
*/
static bool endsWith(const String& str, const String& pattern, bool lowerCase = true);
/** Method for standardising paths - use forward slashes only, end with slash.
*/
static String standardisePath( const String &init);
/** Returns a normalized version of a file path
This method can be used to make file path strings which point to the same directory
but have different texts to be normalized to the same text. The function:
- Transforms all backward slashes to forward slashes.
- Removes repeating slashes.
- Removes initial slashes from the beginning of the path.
- Removes ".\" and "..\" meta directories.
- Sets all characters to lowercase (if requested)
@param init The file path to normalize.
@param makeLowerCase If true, transforms all characters in the string to lowercase.
*/
static String normalizeFilePath(const String& init, bool makeLowerCase = true);
/** Method for splitting a fully qualified filename into the base name
and path.
@remarks
Path is standardised as in standardisePath
*/
static void splitFilename(const String& qualifiedName,
String& outBasename, String& outPath);
/** Method for splitting a fully qualified filename into the base name,
extension and path.
@remarks
Path is standardised as in standardisePath
*/
static void splitFullFilename(const Ogre::String& qualifiedName,
Ogre::String& outBasename, Ogre::String& outExtention,
Ogre::String& outPath);
/** Method for splitting a filename into the base name
and extension.
*/
static void splitBaseFilename(const Ogre::String& fullName,
Ogre::String& outBasename, Ogre::String& outExtention);
/** Simple pattern-matching routine allowing a wildcard pattern.
@param str String to test
@param pattern Pattern to match against; can include simple '*' wildcards
@param caseSensitive Whether the match is case sensitive or not
*/
static bool match(const String& str, const String& pattern, bool caseSensitive = true);
/** replace all instances of a sub-string with a another sub-string.
@param source Source string
@param replaceWhat Sub-string to find and replace
@param replaceWithWhat Sub-string to replace with (the new sub-string)
@return An updated string with the sub-string replaced
*/
static const String replaceAll(const String& source, const String& replaceWhat, const String& replaceWithWhat);
/// Constant blank string, useful for returning by ref where local does not exist
static const String BLANK;
};
#if OGRE_COMPILER == OGRE_COMPILER_GNUC && OGRE_COMP_VER >= 310 && !defined(STLPORT)
# if OGRE_COMP_VER < 430
typedef ::__gnu_cxx::hash< _StringBase > _StringHash;
# else
typedef ::std::tr1::hash< _StringBase > _StringHash;
# endif
#elif OGRE_COMPILER == OGRE_COMPILER_CLANG
# if defined(_LIBCPP_VERSION)
typedef ::std::hash< _StringBase > _StringHash;
# else
typedef ::std::tr1::hash< _StringBase > _StringHash;
# endif
#elif OGRE_COMPILER == OGRE_COMPILER_MSVC && OGRE_COMP_VER >= 1600 && !defined(STLPORT) // VC++ 10.0
typedef ::std::tr1::hash< _StringBase > _StringHash;
#elif !defined( _STLP_HASH_FUN_H )
typedef stdext::hash_compare< _StringBase, std::less< _StringBase > > _StringHash;
#else
typedef std::hash< _StringBase > _StringHash;
#endif
/** @} */
/** @} */
} // namespace Ogre
#include "OgreHeaderSuffix.h"
#if OGRE_DEBUG_MODE && (OGRE_PLATFORM == OGRE_PLATFORM_WIN32 || OGRE_PLATFORM == OGRE_PLATFORM_WINRT)
# pragma push_macro("NOMINMAX")
# define NOMINMAX
# include <windows.h>
# pragma pop_macro("NOMINMAX")
# define Ogre_OutputCString(str) ::OutputDebugStringA(str)
# define Ogre_OutputWString(str) ::OutputDebugStringW(str)
#else
# define Ogre_OutputCString(str) std::cerr << str
# define Ogre_OutputWString(str) std::cerr << str
#endif
#endif // _String_H__
|