[Orxonox-commit 720] r3250 - in branches/core4/src: core core/input orxonox orxonox/interfaces orxonox/objects/worldentities orxonox/overlays orxonox/overlays/hud orxonox/overlays/stats orxonox/tools util

rgrieder at orxonox.net rgrieder at orxonox.net
Mon Jun 29 18:10:46 CEST 2009


Author: rgrieder
Date: 2009-06-29 18:10:46 +0200 (Mon, 29 Jun 2009)
New Revision: 3250

Added:
   branches/core4/src/util/StringUtils.cc
   branches/core4/src/util/StringUtils.h
Removed:
   branches/core4/src/util/String.cc
   branches/core4/src/util/String.h
Modified:
   branches/core4/src/core/ArgumentCompletionFunctions.cc
   branches/core4/src/core/BaseObject.cc
   branches/core4/src/core/CommandEvaluation.cc
   branches/core4/src/core/CommandExecutor.cc
   branches/core4/src/core/CommandLine.cc
   branches/core4/src/core/ConfigFileManager.cc
   branches/core4/src/core/Executor.h
   branches/core4/src/core/Functor.h
   branches/core4/src/core/Game.h
   branches/core4/src/core/Identifier.cc
   branches/core4/src/core/LuaBind.cc
   branches/core4/src/core/TclBind.cc
   branches/core4/src/core/input/Button.cc
   branches/core4/src/orxonox/CameraManager.cc
   branches/core4/src/orxonox/GraphicsManager.cc
   branches/core4/src/orxonox/interfaces/RadarViewable.cc
   branches/core4/src/orxonox/objects/worldentities/Camera.cc
   branches/core4/src/orxonox/objects/worldentities/Light.cc
   branches/core4/src/orxonox/overlays/OrxonoxOverlay.cc
   branches/core4/src/orxonox/overlays/OverlayText.cc
   branches/core4/src/orxonox/overlays/hud/HUDBar.cc
   branches/core4/src/orxonox/overlays/hud/HUDNavigation.cc
   branches/core4/src/orxonox/overlays/hud/HUDRadar.cc
   branches/core4/src/orxonox/overlays/stats/Stats.cc
   branches/core4/src/orxonox/tools/BillboardSet.cc
   branches/core4/src/orxonox/tools/Mesh.cc
   branches/core4/src/util/CMakeLists.txt
   branches/core4/src/util/Convert.h
Log:
Executing decision on #300: Renaming String.h to StringUtils.h (String.h doesn't exactly suggest you would find utilities for string manipulations there).

Modified: branches/core4/src/core/ArgumentCompletionFunctions.cc
===================================================================
--- branches/core4/src/core/ArgumentCompletionFunctions.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/core/ArgumentCompletionFunctions.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -33,7 +33,7 @@
 #include <boost/filesystem.hpp>
 
 #include "util/Convert.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "Identifier.h"
 #include "ConfigValueContainer.h"
 #include "TclThreadManager.h"

Modified: branches/core4/src/core/BaseObject.cc
===================================================================
--- branches/core4/src/core/BaseObject.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/core/BaseObject.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -35,7 +35,7 @@
 
 #include <tinyxml/tinyxml.h>
 
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "CoreIncludes.h"
 #include "Event.h"
 #include "EventIncludes.h"

Modified: branches/core4/src/core/CommandEvaluation.cc
===================================================================
--- branches/core4/src/core/CommandEvaluation.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/core/CommandEvaluation.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -29,7 +29,7 @@
 #include "CommandEvaluation.h"
 
 #include "util/Debug.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "ConsoleCommand.h"
 #include "Identifier.h"
 

Modified: branches/core4/src/core/CommandExecutor.cc
===================================================================
--- branches/core4/src/core/CommandExecutor.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/core/CommandExecutor.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -29,7 +29,7 @@
 #include "CommandExecutor.h"
 
 #include "util/Debug.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "ConsoleCommand.h"
 #include "Identifier.h"
 #include "Language.h"

Modified: branches/core4/src/core/CommandLine.cc
===================================================================
--- branches/core4/src/core/CommandLine.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/core/CommandLine.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -33,7 +33,7 @@
 #include "util/Convert.h"
 #include "util/Debug.h"
 #include "util/Exception.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "util/SubString.h"
 #include "Core.h"
 

Modified: branches/core4/src/core/ConfigFileManager.cc
===================================================================
--- branches/core4/src/core/ConfigFileManager.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/core/ConfigFileManager.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -32,7 +32,7 @@
 
 #include "util/Convert.h"
 #include "util/Math.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "ConsoleCommand.h"
 #include "ConfigValueContainer.h"
 #include "Core.h"

Modified: branches/core4/src/core/Executor.h
===================================================================
--- branches/core4/src/core/Executor.h	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/core/Executor.h	2009-06-29 16:10:46 UTC (rev 3250)
@@ -34,7 +34,7 @@
 
 #include "util/Debug.h"
 #include "util/Math.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "util/SubString.h"
 #include "Functor.h"
 

Modified: branches/core4/src/core/Functor.h
===================================================================
--- branches/core4/src/core/Functor.h	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/core/Functor.h	2009-06-29 16:10:46 UTC (rev 3250)
@@ -34,7 +34,7 @@
 
 #include "util/Debug.h"
 #include "util/MultiType.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 
 namespace orxonox
 {

Modified: branches/core4/src/core/Game.h
===================================================================
--- branches/core4/src/core/Game.h	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/core/Game.h	2009-06-29 16:10:46 UTC (rev 3250)
@@ -46,7 +46,7 @@
 #include <boost/preprocessor/cat.hpp>
 
 #include "util/Debug.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 
 /**
 @def

Modified: branches/core4/src/core/Identifier.cc
===================================================================
--- branches/core4/src/core/Identifier.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/core/Identifier.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -35,7 +35,7 @@
 
 #include <ostream>
 
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "ConfigValueContainer.h"
 #include "ConsoleCommand.h"
 #include "Factory.h"

Modified: branches/core4/src/core/LuaBind.cc
===================================================================
--- branches/core4/src/core/LuaBind.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/core/LuaBind.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -37,7 +37,7 @@
 #include <boost/filesystem.hpp>
 
 #include "util/Debug.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "ToluaBindCore.h"
 #include "Core.h"
 

Modified: branches/core4/src/core/TclBind.cc
===================================================================
--- branches/core4/src/core/TclBind.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/core/TclBind.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -33,7 +33,7 @@
 #include <cpptcl/cpptcl.h>
 
 #include "util/Debug.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "CommandExecutor.h"
 #include "ConsoleCommand.h"
 #include "TclThreadManager.h"

Modified: branches/core4/src/core/input/Button.cc
===================================================================
--- branches/core4/src/core/input/Button.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/core/input/Button.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -36,7 +36,7 @@
 
 #include "util/Convert.h"
 #include "util/SubString.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "util/Debug.h"
 #include "core/ConsoleCommand.h"
 #include "core/CommandEvaluation.h"

Modified: branches/core4/src/orxonox/CameraManager.cc
===================================================================
--- branches/core4/src/orxonox/CameraManager.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/orxonox/CameraManager.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -31,7 +31,7 @@
 #include <OgreViewport.h>
 #include <OgreCompositorManager.h>
 
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "core/GameMode.h"
 #include "core/ObjectList.h"
 #include "tools/Shader.h"

Modified: branches/core4/src/orxonox/GraphicsManager.cc
===================================================================
--- branches/core4/src/orxonox/GraphicsManager.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/orxonox/GraphicsManager.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -52,7 +52,7 @@
 
 #include "SpecialConfig.h"
 #include "util/Exception.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "util/SubString.h"
 #include "core/Clock.h"
 #include "core/ConsoleCommand.h"

Modified: branches/core4/src/orxonox/interfaces/RadarViewable.cc
===================================================================
--- branches/core4/src/orxonox/interfaces/RadarViewable.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/orxonox/interfaces/RadarViewable.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -32,7 +32,7 @@
 #include <OgreSceneNode.h>
 #include <OgreEntity.h>
 
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "core/CoreIncludes.h"
 #include "tools/DynamicLines.h"
 #include "objects/worldentities/WorldEntity.h"

Modified: branches/core4/src/orxonox/objects/worldentities/Camera.cc
===================================================================
--- branches/core4/src/orxonox/objects/worldentities/Camera.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/orxonox/objects/worldentities/Camera.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -33,7 +33,7 @@
 #include <OgreSceneNode.h>
 
 #include "util/Exception.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "core/CoreIncludes.h"
 #include "core/ConfigValueIncludes.h"
 #include "objects/Scene.h"

Modified: branches/core4/src/orxonox/objects/worldentities/Light.cc
===================================================================
--- branches/core4/src/orxonox/objects/worldentities/Light.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/orxonox/objects/worldentities/Light.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -32,7 +32,7 @@
 #include <OgreLight.h>
 #include <boost/static_assert.hpp>
 
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "util/Exception.h"
 #include "core/CoreIncludes.h"
 #include "core/GameMode.h"

Modified: branches/core4/src/orxonox/overlays/OrxonoxOverlay.cc
===================================================================
--- branches/core4/src/orxonox/overlays/OrxonoxOverlay.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/orxonox/overlays/OrxonoxOverlay.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -41,7 +41,7 @@
 
 #include "util/Convert.h"
 #include "util/Exception.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "core/GameMode.h"
 #include "core/CoreIncludes.h"
 #include "core/XMLPort.h"

Modified: branches/core4/src/orxonox/overlays/OverlayText.cc
===================================================================
--- branches/core4/src/orxonox/overlays/OverlayText.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/orxonox/overlays/OverlayText.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -33,7 +33,7 @@
 #include <OgreTextAreaOverlayElement.h>
 #include <boost/static_assert.hpp>
 
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "core/CoreIncludes.h"
 #include "core/XMLPort.h"
 

Modified: branches/core4/src/orxonox/overlays/hud/HUDBar.cc
===================================================================
--- branches/core4/src/orxonox/overlays/hud/HUDBar.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/orxonox/overlays/hud/HUDBar.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -37,7 +37,7 @@
 #include <OgrePanelOverlayElement.h>
 
 #include "util/Convert.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "core/CoreIncludes.h"
 #include "core/XMLPort.h"
 

Modified: branches/core4/src/orxonox/overlays/hud/HUDNavigation.cc
===================================================================
--- branches/core4/src/orxonox/overlays/hud/HUDNavigation.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/orxonox/overlays/hud/HUDNavigation.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -34,7 +34,7 @@
 #include <OgrePanelOverlayElement.h>
 
 #include "util/Math.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "util/Convert.h"
 #include "core/CoreIncludes.h"
 #include "core/XMLPort.h"

Modified: branches/core4/src/orxonox/overlays/hud/HUDRadar.cc
===================================================================
--- branches/core4/src/orxonox/overlays/hud/HUDRadar.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/orxonox/overlays/hud/HUDRadar.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -33,7 +33,7 @@
 #include <OgrePanelOverlayElement.h>
 
 #include "util/Math.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "core/CoreIncludes.h"
 #include "core/XMLPort.h"
 #include "tools/TextureGenerator.h"

Modified: branches/core4/src/orxonox/overlays/stats/Stats.cc
===================================================================
--- branches/core4/src/orxonox/overlays/stats/Stats.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/orxonox/overlays/stats/Stats.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -32,7 +32,7 @@
 #include <OgreOverlayManager.h>
 #include <OgreBorderPanelOverlayElement.h>
 
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "core/CoreIncludes.h"
 #include "core/ConfigValueIncludes.h"
 

Modified: branches/core4/src/orxonox/tools/BillboardSet.cc
===================================================================
--- branches/core4/src/orxonox/tools/BillboardSet.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/orxonox/tools/BillboardSet.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -37,7 +37,7 @@
 
 #include "util/Convert.h"
 #include "util/Math.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "core/GameMode.h"
 
 namespace orxonox

Modified: branches/core4/src/orxonox/tools/Mesh.cc
===================================================================
--- branches/core4/src/orxonox/tools/Mesh.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/orxonox/tools/Mesh.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -35,7 +35,7 @@
 #include <OgreSceneManager.h>
 
 #include "util/Convert.h"
-#include "util/String.h"
+#include "util/StringUtils.h"
 #include "core/GameMode.h"
 
 namespace orxonox

Modified: branches/core4/src/util/CMakeLists.txt
===================================================================
--- branches/core4/src/util/CMakeLists.txt	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/util/CMakeLists.txt	2009-06-29 16:10:46 UTC (rev 3250)
@@ -28,7 +28,7 @@
   OutputHandler.cc
   SignalHandler.cc
   Sleep.cc
-  String.cc
+  StringUtils.cc
   SubString.cc
 )
 

Modified: branches/core4/src/util/Convert.h
===================================================================
--- branches/core4/src/util/Convert.h	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/util/Convert.h	2009-06-29 16:10:46 UTC (rev 3250)
@@ -42,7 +42,7 @@
 #include <typeinfo>
 
 #include "Debug.h"
-#include "String.h"
+#include "StringUtils.h"
 
 // GCC generates warnings when implicitely casting from float to int for instance.
 // This is however exactly what convertValue does, so we need to suppress these warnings.

Deleted: branches/core4/src/util/String.cc
===================================================================
--- branches/core4/src/util/String.cc	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/util/String.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -1,492 +0,0 @@
-/*
- *   ORXONOX - the hottest 3D action shooter ever to exist
- *                    > www.orxonox.net <
- *
- *
- *   License notice:
- *
- *   This program is free software; you can redistribute it and/or
- *   modify it under the terms of the GNU General Public License
- *   as published by the Free Software Foundation; either version 2
- *   of the License, or (at your option) any later version.
- *
- *   This program is distributed in the hope that it will be useful,
- *   but WITHOUT ANY WARRANTY; without even the implied warranty of
- *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- *   GNU General Public License for more details.
- *
- *   You should have received a copy of the GNU General Public License
- *   along with this program; if not, write to the Free Software
- *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
- *
- *   Author:
- *      Fabian 'x3n' Landau
- *   Co-authors:
- *      Benjamin Grauer
- *
- */
-
-/**
-    @file
-    @brief Implementation of several string manipulation functions.
-*/
-
-#include "String.h"
-
-#include <cctype>
-#include "Convert.h"
-#include "Math.h"
-
-namespace orxonox
-{
-    std::string BLANKSTRING("");
-
-    std::string getUniqueNumberString()
-    {
-        return convertToString(getUniqueNumber());
-    }
-
-    /**
-        @brief Removes all whitespaces from a string.
-        @param str The string to strip
-    */
-    void strip(std::string* str)
-    {
-        size_t pos;
-        while ((pos = (*str).find(" ")) < (*str).length())
-            (*str).erase(pos, 1);
-        while ((pos = (*str).find("\t")) < (*str).length())
-            (*str).erase(pos, 1);
-        while ((pos = (*str).find("\n")) < (*str).length())
-            (*str).erase(pos, 1);
-    }
-
-    /**
-        @brief Returns a copy of a string without whitespaces.
-        @param str The string to strip
-        @return The stripped line
-    */
-    std::string getStripped(const std::string& str)
-    {
-        std::string output = std::string(str);
-        strip(&output);
-        return output;
-    }
-
-    /**
-        @brief Returns a copy of a string without trailing whitespaces.
-        @param str The string
-        @return The modified copy
-    */
-    std::string removeTrailingWhitespaces(const std::string& str)
-    {
-        size_t pos1 = 0;
-        int pos2 = (int)(str.size() - 1);
-        for (; pos1 < str.size() && (str[pos1] == ' ' || str[pos1] == '\t' || str[pos1] == '\n'); pos1++);
-        for (; pos2 > 0         && (str[pos2] == ' ' || str[pos2] == '\t' || str[pos2] == '\n'); pos2--);
-        return str.substr(pos1, pos2 - pos1 + 1);
-    }
-
-    /**
-        @brief Returns the position of the next quote in the string, starting with start.
-        @param str The string
-        @param start The startposition
-        @return The position of the next quote (std::string::npos if there is no next quote)
-    */
-    size_t getNextQuote(const std::string& str, size_t start)
-    {
-        size_t quote = start - 1;
-
-        while ((quote = str.find('\"', quote + 1)) != std::string::npos)
-        {
-            size_t backslash = quote;
-            size_t numbackslashes = 0;
-            for (; backslash > 0; backslash--, numbackslashes++)
-                if (str[backslash - 1] != '\\')
-                    break;
-
-            if (numbackslashes % 2 == 0)
-                break;
-        }
-
-        return quote;
-    }
-
-    /**
-        @brief Returns true if pos is between two quotes.
-        @param str The string
-        @param pos The position to check
-        @return True if pos is between two quotes
-    */
-    bool isBetweenQuotes(const std::string& str, size_t pos)
-    {
-        if (pos == std::string::npos)
-            return false;
-
-        size_t quotecount = 0;
-        size_t quote = (size_t)-1;
-        while ((quote = getNextQuote(str, quote + 1)) < pos)
-        {
-            if (quote == pos)
-                return false;
-            quotecount++;
-        }
-
-        if (quote == std::string::npos)
-            return false;
-
-        return ((quotecount % 2) == 1);
-    }
-
-    /**
-        @brief Returns true if the string contains something like '..."between quotes"...'.
-        @param The string
-        @return True if there is something between quotes
-    */
-    bool hasStringBetweenQuotes(const std::string& str)
-    {
-        size_t pos1 = getNextQuote(str, 0);
-        size_t pos2 = getNextQuote(str, pos1 + 1);
-        return (pos1 != std::string::npos && pos2 != std::string::npos && pos2 > pos1 + 1);
-    }
-
-    /**
-        @brief If the string contains something like '..."between quotes"...' then 'between quotes' gets returned (without quotes).
-        @param The string
-        @param The string between the quotes
-    */
-    std::string getStringBetweenQuotes(const std::string& str)
-    {
-        size_t pos1 = getNextQuote(str, 0);
-        size_t pos2 = getNextQuote(str, pos1 + 1);
-        if (pos1 != std::string::npos && pos2 != std::string::npos)
-            return str.substr(pos1, pos2 - pos1 + 1);
-        else
-            return "";
-    }
-
-    /**
-        @brief Removes enclosing quotes if available (including whitespaces at the outside of the quotes).
-        @brief str The string to strip
-        @return The string with removed quotes
-    */
-    std::string stripEnclosingQuotes(const std::string& str)
-    {
-        size_t start = std::string::npos;
-        size_t end = 0;
-
-        for (size_t pos = 0; (pos < str.size()) && (pos < std::string::npos); pos++)
-        {
-            if (str[pos] == '"')
-            {
-                start = pos;
-                break;
-            }
-
-            if ((str[pos] != ' ') && (str[pos] != '\t') && (str[pos] != '\n'))
-                return str;
-        }
-
-        for (size_t pos = str.size() - 1; pos < std::string::npos; pos--)
-        {
-            if (str[pos] == '"')
-            {
-                end = pos;
-                break;
-            }
-
-            if ((str[pos] != ' ') && (str[pos] != '\t') && (str[pos] != '\n'))
-                return str;
-        }
-
-        if ((start != std::string::npos) && (end != 0))
-            return str.substr(start + 1, end - start - 1);
-        else
-            return str;
-    }
-
-    /**
-        @brief Removes enclosing {braces} (braces must be exactly on the beginning and the end of the string).
-        @param str The string to strip
-        @return The striped string
-    */
-    std::string stripEnclosingBraces(const std::string& str)
-    {
-        std::string output = str;
-
-        while (output.size() >= 2 && output[0] == '{' && output[output.size() - 1] == '}')
-            output = output.substr(1, output.size() - 2);
-
-        return output;
-    }
-
-    /**
-        @brief Determines if a string is a comment (starts with a comment-symbol).
-        @param str The string to check
-        @return True = it's a comment
-
-        A comment is defined by a leading '#', '%', ';' or '//'.
-    */
-    bool isComment(const std::string& str)
-    {
-        // Strip the line, whitespaces are disturbing
-        std::string teststring = getStripped(str);
-
-        // There are four possible comment-symbols:
-        //  1) #comment in script-language style
-        //  2) %comment in matlab style
-        //  3) ;comment in unreal tournament config-file style
-        //  4) //comment in code style
-        if (teststring.size() >= 2)
-        {
-            if (teststring[0] == '#' || teststring[0] == '%' || teststring[0] == ';' || (teststring[0] == '/' && teststring[1] == '/'))
-                return true;
-        }
-        else if (teststring.size() == 1)
-        {
-            if (teststring[0] == '#' || teststring[0] == '%' || teststring[0] == ';')
-                return true;
-        }
-
-        return false;
-    }
-
-    /**
-        @brief Determines if a string is empty (contains only whitespaces).
-        @param str The string to check
-        @return True = it's empty
-    */
-    bool isEmpty(const std::string& str)
-    {
-        std::string temp = getStripped(str);
-        return ((temp == "") || (temp.size() == 0));
-    }
-
-    /**
-        @brief Determines if a string contains only numbers and maximal one '.'.
-        @param str The string to check
-        @return True = it's a number
-    */
-    bool isNumeric(const std::string& str)
-    {
-        bool foundPoint = false;
-
-        for (std::string::const_iterator it = str.begin(); it != str.end(); ++it)
-        {
-            if (((*it) < '0' || (*it) > '9'))
-            {
-                if ((*it) != '.' && !foundPoint)
-                    foundPoint = true;
-                else
-                    return false;
-            }
-        }
-
-        return true;
-    }
-
-    /**
-        @brief Adds backslashes to the given string which makes special chars visible. Existing slashes will be doubled.
-        @param str The string to manipulate
-        @return The string with added slashes
-    */
-    std::string addSlashes(const std::string& str)
-    {
-        std::string output = str;
-
-        for (size_t pos = 0; (pos = output.find('\\', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\\\"); }
-        for (size_t pos = 0; (pos = output.find('\n', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\n"); }
-        for (size_t pos = 0; (pos = output.find('\t', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\t"); }
-        for (size_t pos = 0; (pos = output.find('\v', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\v"); }
-        for (size_t pos = 0; (pos = output.find('\b', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\b"); }
-        for (size_t pos = 0; (pos = output.find('\r', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\r"); }
-        for (size_t pos = 0; (pos = output.find('\f', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\f"); }
-        for (size_t pos = 0; (pos = output.find('\a', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\a"); }
-        for (size_t pos = 0; (pos = output.find('"', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\\""); }
-        for (size_t pos = 0; (pos = output.find('\0', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\0"); }
-
-        return output;
-    }
-
-    /**
-        @brief Removes backslashes from the given string. Double backslashes are interpreted as one backslash.
-        @param str The string to manipulate
-        @return The string with removed slashes
-    */
-    std::string removeSlashes(const std::string& str)
-    {
-        if (str.size() <= 1)
-            return str;
-
-        std::string output = "";
-        for (size_t pos = 0; pos < str.size() - 1; )
-        {
-            if (str[pos] == '\\')
-            {
-                if (str[pos + 1] == '\\') { output += '\\'; pos += 2; continue; }
-                else if (str[pos + 1] == 'n') { output += '\n'; pos += 2; continue; }
-                else if (str[pos + 1] == 't') { output += '\t'; pos += 2; continue; }
-                else if (str[pos + 1] == 'v') { output += '\v'; pos += 2; continue; }
-                else if (str[pos + 1] == 'b') { output += '\b'; pos += 2; continue; }
-                else if (str[pos + 1] == 'r') { output += '\r'; pos += 2; continue; }
-                else if (str[pos + 1] == 'f') { output += '\f'; pos += 2; continue; }
-                else if (str[pos + 1] == 'a') { output += '\a'; pos += 2; continue; }
-                else if (str[pos + 1] == '"') { output += '"'; pos += 2; continue; }
-                else if (str[pos + 1] == '0') { output += '\0'; pos += 2; continue; }
-            }
-            output += str[pos];
-            pos++;
-            if (pos == str.size() - 1)
-                output += str[pos];
-        }
-
-        return output;
-    }
-
-    /**
-        @brief Replaces each char between A and Z with its lowercase equivalent.
-        @param str The string to convert
-    */
-    void lowercase(std::string* str)
-    {
-        for (size_t i = 0; i < str->size(); ++i)
-        {
-            (*str)[i] = (char)tolower((*str)[i]);
-        }
-    }
-
-    /**
-        @brief Returns a copy of the given string without uppercase chars.
-        @param str The string
-        @return The copy
-    */
-    std::string getLowercase(const std::string& str)
-    {
-        std::string output = std::string(str);
-        lowercase(&output);
-        return output;
-    }
-
-    /**
-        @brief Replaces each char between a and z with its uppercase equivalent.
-        @param str The string to convert
-    */
-    void uppercase(std::string* str)
-    {
-        for (size_t i = 0; i < str->size(); ++i)
-        {
-            (*str)[i] = (char)toupper((*str)[i]);
-        }
-    }
-
-    /**
-        @brief Returns a copy of the given string without lowercase chars.
-        @param str The string
-        @return The copy
-    */
-    std::string getUppercase(const std::string& str)
-    {
-        std::string output = std::string(str);
-        uppercase(&output);
-        return output;
-    }
-
-    /**
-        @brief Compares two strings ignoring different casing.
-        @param s1 First string
-        @param s2 Second string
-    */
-    int nocaseCmp(const std::string& s1, const std::string& s2)
-    {
-        std::string::const_iterator it1=s1.begin();
-        std::string::const_iterator it2=s2.begin();
-
-        //stop when either string's end has been reached
-        while ( (it1!=s1.end()) && (it2!=s2.end()) )
-        {
-            if(::toupper(*it1) != ::toupper(*it2)) //letters differ?
-                // return -1 to indicate smaller than, 1 otherwise
-                return (::toupper(*it1)  < ::toupper(*it2)) ? -1 : 1;
-            //proceed to the next character in each string
-            ++it1;
-            ++it2;
-        }
-        size_t size1=s1.size(), size2=s2.size();// cache lengths
-        //return -1,0 or 1 according to strings' lengths
-        if (size1==size2)
-            return 0;
-        return (size1<size2) ? -1 : 1;
-    }
-
-
-    /**
-        @brief Compares the first 'len' chars of two strings ignoring different casing.
-        @param s1 First string
-        @param s2 Second string
-        @param len Maximal number of chars to compare
-    */
-    int nocaseCmp(const std::string& s1, const std::string& s2, size_t len)
-    {
-        if (len == 0)
-            return 0;
-        std::string::const_iterator it1=s1.begin();
-        std::string::const_iterator it2=s2.begin();
-
-        //stop when either string's end has been reached
-        while ( (it1!=s1.end()) && (it2!=s2.end()) && len-- > 0)
-        {
-            if(::toupper(*it1) != ::toupper(*it2)) //letters differ?
-                // return -1 to indicate smaller than, 1 otherwise
-                return (::toupper(*it1)  < ::toupper(*it2)) ? -1 : 1;
-            //proceed to the next character in each string
-            ++it1;
-            ++it2;
-        }
-        return 0;
-    }
-
-    /**
-        @brief Returns true if the string contains a comment, introduced by #, %, ; or //.
-        @param str The string
-        @return True if the string contains a comment
-    */
-    bool hasComment(const std::string& str)
-    {
-        return (getCommentPosition(str) != std::string::npos);
-    }
-
-    /**
-        @brief If the string contains a comment, the comment gets returned (including the comment symbol), an empty string otherwise.
-        @param str The string
-        @return The comment
-    */
-    std::string getComment(const std::string& str)
-    {
-        return str.substr(getCommentPosition(str));
-    }
-
-    /**
-        @brief If the string contains a comment, the position of the comment-symbol gets returned, std::string::npos otherwise.
-        @param str The string
-        @return The position
-    */
-    size_t getCommentPosition(const std::string& str)
-    {
-        return getNextCommentPosition(str, 0);
-    }
-
-    /**
-        @brief Returns the position of the next comment-symbol, starting with start.
-        @param str The string
-        @param start The startposition
-        @return The position
-    */
-    size_t getNextCommentPosition(const std::string& str, size_t start)
-    {
-        for (size_t i = start; i < str.size(); i++)
-            if (isComment(str.substr(i)))
-                return i;
-
-        return std::string::npos;
-    }
-}

Deleted: branches/core4/src/util/String.h
===================================================================
--- branches/core4/src/util/String.h	2009-06-29 14:01:35 UTC (rev 3249)
+++ branches/core4/src/util/String.h	2009-06-29 16:10:46 UTC (rev 3250)
@@ -1,81 +0,0 @@
-/*
- *   ORXONOX - the hottest 3D action shooter ever to exist
- *                    > www.orxonox.net <
- *
- *
- *   License notice:
- *
- *   This program is free software; you can redistribute it and/or
- *   modify it under the terms of the GNU General Public License
- *   as published by the Free Software Foundation; either version 2
- *   of the License, or (at your option) any later version.
- *
- *   This program is distributed in the hope that it will be useful,
- *   but WITHOUT ANY WARRANTY; without even the implied warranty of
- *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- *   GNU General Public License for more details.
- *
- *   You should have received a copy of the GNU General Public License
- *   along with this program; if not, write to the Free Software
- *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
- *
- *   Author:
- *      Fabian 'x3n' Landau
- *   Co-authors:
- *      ...
- *
- */
-
-/**
-    @file
-    @brief Declaration of several string manipulation functions, used in many parts of the game.
-*/
-
-#ifndef _Util_String_H__
-#define _Util_String_H__
-
-#include "UtilPrereqs.h"
-#include <string>
-
-namespace orxonox
-{
-    extern _UtilExport std::string BLANKSTRING;
-    _UtilExport std::string getUniqueNumberString();
-
-    _UtilExport void        strip(std::string* str);
-    _UtilExport std::string getStripped(const std::string& str);
-
-    _UtilExport std::string removeTrailingWhitespaces(const std::string& str);
-
-    _UtilExport size_t      getNextQuote(const std::string& str, size_t start);
-    _UtilExport bool        isBetweenQuotes(const std::string& str, size_t pos);
-
-    _UtilExport bool        hasStringBetweenQuotes(const std::string& str);
-    _UtilExport std::string getStringBetweenQuotes(const std::string& str);
-
-    _UtilExport std::string stripEnclosingQuotes(const std::string& str);
-    _UtilExport std::string stripEnclosingBraces(const std::string& str);
-
-    _UtilExport bool        isEmpty(const std::string& str);
-    _UtilExport bool        isComment(const std::string& str);
-    _UtilExport bool        isNumeric(const std::string& str);
-
-    _UtilExport std::string addSlashes(const std::string& str);
-    _UtilExport std::string removeSlashes(const std::string& str);
-
-    _UtilExport void        lowercase(std::string* str);
-    _UtilExport std::string getLowercase(const std::string& str);
-
-    _UtilExport void        uppercase(std::string* str);
-    _UtilExport std::string getUppercase(const std::string& str);
-
-    _UtilExport int         nocaseCmp(const std::string& s1, const std::string& s2);
-    _UtilExport int         nocaseCmp(const std::string& s1, const std::string& s2, size_t len);
-
-    _UtilExport bool        hasComment(const std::string& str);
-    _UtilExport std::string getComment(const std::string& str);
-    _UtilExport size_t      getCommentPosition(const std::string& str);
-    _UtilExport size_t      getNextCommentPosition(const std::string& str, size_t start = 0);
-}
-
-#endif /* _Util_String_H__ */

Copied: branches/core4/src/util/StringUtils.cc (from rev 3222, branches/core4/src/util/String.cc)
===================================================================
--- branches/core4/src/util/StringUtils.cc	                        (rev 0)
+++ branches/core4/src/util/StringUtils.cc	2009-06-29 16:10:46 UTC (rev 3250)
@@ -0,0 +1,492 @@
+/*
+ *   ORXONOX - the hottest 3D action shooter ever to exist
+ *                    > www.orxonox.net <
+ *
+ *
+ *   License notice:
+ *
+ *   This program is free software; you can redistribute it and/or
+ *   modify it under the terms of the GNU General Public License
+ *   as published by the Free Software Foundation; either version 2
+ *   of the License, or (at your option) any later version.
+ *
+ *   This program is distributed in the hope that it will be useful,
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *   GNU General Public License for more details.
+ *
+ *   You should have received a copy of the GNU General Public License
+ *   along with this program; if not, write to the Free Software
+ *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
+ *
+ *   Author:
+ *      Fabian 'x3n' Landau
+ *   Co-authors:
+ *      Benjamin Grauer
+ *
+ */
+
+/**
+    @file
+    @brief Implementation of several string manipulation functions.
+*/
+
+#include "StringUtils.h"
+
+#include <cctype>
+#include "Convert.h"
+#include "Math.h"
+
+namespace orxonox
+{
+    std::string BLANKSTRING("");
+
+    std::string getUniqueNumberString()
+    {
+        return convertToString(getUniqueNumber());
+    }
+
+    /**
+        @brief Removes all whitespaces from a string.
+        @param str The string to strip
+    */
+    void strip(std::string* str)
+    {
+        size_t pos;
+        while ((pos = (*str).find(" ")) < (*str).length())
+            (*str).erase(pos, 1);
+        while ((pos = (*str).find("\t")) < (*str).length())
+            (*str).erase(pos, 1);
+        while ((pos = (*str).find("\n")) < (*str).length())
+            (*str).erase(pos, 1);
+    }
+
+    /**
+        @brief Returns a copy of a string without whitespaces.
+        @param str The string to strip
+        @return The stripped line
+    */
+    std::string getStripped(const std::string& str)
+    {
+        std::string output = std::string(str);
+        strip(&output);
+        return output;
+    }
+
+    /**
+        @brief Returns a copy of a string without trailing whitespaces.
+        @param str The string
+        @return The modified copy
+    */
+    std::string removeTrailingWhitespaces(const std::string& str)
+    {
+        size_t pos1 = 0;
+        int pos2 = (int)(str.size() - 1);
+        for (; pos1 < str.size() && (str[pos1] == ' ' || str[pos1] == '\t' || str[pos1] == '\n'); pos1++);
+        for (; pos2 > 0         && (str[pos2] == ' ' || str[pos2] == '\t' || str[pos2] == '\n'); pos2--);
+        return str.substr(pos1, pos2 - pos1 + 1);
+    }
+
+    /**
+        @brief Returns the position of the next quote in the string, starting with start.
+        @param str The string
+        @param start The startposition
+        @return The position of the next quote (std::string::npos if there is no next quote)
+    */
+    size_t getNextQuote(const std::string& str, size_t start)
+    {
+        size_t quote = start - 1;
+
+        while ((quote = str.find('\"', quote + 1)) != std::string::npos)
+        {
+            size_t backslash = quote;
+            size_t numbackslashes = 0;
+            for (; backslash > 0; backslash--, numbackslashes++)
+                if (str[backslash - 1] != '\\')
+                    break;
+
+            if (numbackslashes % 2 == 0)
+                break;
+        }
+
+        return quote;
+    }
+
+    /**
+        @brief Returns true if pos is between two quotes.
+        @param str The string
+        @param pos The position to check
+        @return True if pos is between two quotes
+    */
+    bool isBetweenQuotes(const std::string& str, size_t pos)
+    {
+        if (pos == std::string::npos)
+            return false;
+
+        size_t quotecount = 0;
+        size_t quote = (size_t)-1;
+        while ((quote = getNextQuote(str, quote + 1)) < pos)
+        {
+            if (quote == pos)
+                return false;
+            quotecount++;
+        }
+
+        if (quote == std::string::npos)
+            return false;
+
+        return ((quotecount % 2) == 1);
+    }
+
+    /**
+        @brief Returns true if the string contains something like '..."between quotes"...'.
+        @param The string
+        @return True if there is something between quotes
+    */
+    bool hasStringBetweenQuotes(const std::string& str)
+    {
+        size_t pos1 = getNextQuote(str, 0);
+        size_t pos2 = getNextQuote(str, pos1 + 1);
+        return (pos1 != std::string::npos && pos2 != std::string::npos && pos2 > pos1 + 1);
+    }
+
+    /**
+        @brief If the string contains something like '..."between quotes"...' then 'between quotes' gets returned (without quotes).
+        @param The string
+        @param The string between the quotes
+    */
+    std::string getStringBetweenQuotes(const std::string& str)
+    {
+        size_t pos1 = getNextQuote(str, 0);
+        size_t pos2 = getNextQuote(str, pos1 + 1);
+        if (pos1 != std::string::npos && pos2 != std::string::npos)
+            return str.substr(pos1, pos2 - pos1 + 1);
+        else
+            return "";
+    }
+
+    /**
+        @brief Removes enclosing quotes if available (including whitespaces at the outside of the quotes).
+        @brief str The string to strip
+        @return The string with removed quotes
+    */
+    std::string stripEnclosingQuotes(const std::string& str)
+    {
+        size_t start = std::string::npos;
+        size_t end = 0;
+
+        for (size_t pos = 0; (pos < str.size()) && (pos < std::string::npos); pos++)
+        {
+            if (str[pos] == '"')
+            {
+                start = pos;
+                break;
+            }
+
+            if ((str[pos] != ' ') && (str[pos] != '\t') && (str[pos] != '\n'))
+                return str;
+        }
+
+        for (size_t pos = str.size() - 1; pos < std::string::npos; pos--)
+        {
+            if (str[pos] == '"')
+            {
+                end = pos;
+                break;
+            }
+
+            if ((str[pos] != ' ') && (str[pos] != '\t') && (str[pos] != '\n'))
+                return str;
+        }
+
+        if ((start != std::string::npos) && (end != 0))
+            return str.substr(start + 1, end - start - 1);
+        else
+            return str;
+    }
+
+    /**
+        @brief Removes enclosing {braces} (braces must be exactly on the beginning and the end of the string).
+        @param str The string to strip
+        @return The striped string
+    */
+    std::string stripEnclosingBraces(const std::string& str)
+    {
+        std::string output = str;
+
+        while (output.size() >= 2 && output[0] == '{' && output[output.size() - 1] == '}')
+            output = output.substr(1, output.size() - 2);
+
+        return output;
+    }
+
+    /**
+        @brief Determines if a string is a comment (starts with a comment-symbol).
+        @param str The string to check
+        @return True = it's a comment
+
+        A comment is defined by a leading '#', '%', ';' or '//'.
+    */
+    bool isComment(const std::string& str)
+    {
+        // Strip the line, whitespaces are disturbing
+        std::string teststring = getStripped(str);
+
+        // There are four possible comment-symbols:
+        //  1) #comment in script-language style
+        //  2) %comment in matlab style
+        //  3) ;comment in unreal tournament config-file style
+        //  4) //comment in code style
+        if (teststring.size() >= 2)
+        {
+            if (teststring[0] == '#' || teststring[0] == '%' || teststring[0] == ';' || (teststring[0] == '/' && teststring[1] == '/'))
+                return true;
+        }
+        else if (teststring.size() == 1)
+        {
+            if (teststring[0] == '#' || teststring[0] == '%' || teststring[0] == ';')
+                return true;
+        }
+
+        return false;
+    }
+
+    /**
+        @brief Determines if a string is empty (contains only whitespaces).
+        @param str The string to check
+        @return True = it's empty
+    */
+    bool isEmpty(const std::string& str)
+    {
+        std::string temp = getStripped(str);
+        return ((temp == "") || (temp.size() == 0));
+    }
+
+    /**
+        @brief Determines if a string contains only numbers and maximal one '.'.
+        @param str The string to check
+        @return True = it's a number
+    */
+    bool isNumeric(const std::string& str)
+    {
+        bool foundPoint = false;
+
+        for (std::string::const_iterator it = str.begin(); it != str.end(); ++it)
+        {
+            if (((*it) < '0' || (*it) > '9'))
+            {
+                if ((*it) != '.' && !foundPoint)
+                    foundPoint = true;
+                else
+                    return false;
+            }
+        }
+
+        return true;
+    }
+
+    /**
+        @brief Adds backslashes to the given string which makes special chars visible. Existing slashes will be doubled.
+        @param str The string to manipulate
+        @return The string with added slashes
+    */
+    std::string addSlashes(const std::string& str)
+    {
+        std::string output = str;
+
+        for (size_t pos = 0; (pos = output.find('\\', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\\\"); }
+        for (size_t pos = 0; (pos = output.find('\n', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\n"); }
+        for (size_t pos = 0; (pos = output.find('\t', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\t"); }
+        for (size_t pos = 0; (pos = output.find('\v', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\v"); }
+        for (size_t pos = 0; (pos = output.find('\b', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\b"); }
+        for (size_t pos = 0; (pos = output.find('\r', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\r"); }
+        for (size_t pos = 0; (pos = output.find('\f', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\f"); }
+        for (size_t pos = 0; (pos = output.find('\a', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\a"); }
+        for (size_t pos = 0; (pos = output.find('"', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\\""); }
+        for (size_t pos = 0; (pos = output.find('\0', pos)) < std::string::npos; pos += 2) { output.replace(pos, 1, "\\0"); }
+
+        return output;
+    }
+
+    /**
+        @brief Removes backslashes from the given string. Double backslashes are interpreted as one backslash.
+        @param str The string to manipulate
+        @return The string with removed slashes
+    */
+    std::string removeSlashes(const std::string& str)
+    {
+        if (str.size() <= 1)
+            return str;
+
+        std::string output = "";
+        for (size_t pos = 0; pos < str.size() - 1; )
+        {
+            if (str[pos] == '\\')
+            {
+                if (str[pos + 1] == '\\') { output += '\\'; pos += 2; continue; }
+                else if (str[pos + 1] == 'n') { output += '\n'; pos += 2; continue; }
+                else if (str[pos + 1] == 't') { output += '\t'; pos += 2; continue; }
+                else if (str[pos + 1] == 'v') { output += '\v'; pos += 2; continue; }
+                else if (str[pos + 1] == 'b') { output += '\b'; pos += 2; continue; }
+                else if (str[pos + 1] == 'r') { output += '\r'; pos += 2; continue; }
+                else if (str[pos + 1] == 'f') { output += '\f'; pos += 2; continue; }
+                else if (str[pos + 1] == 'a') { output += '\a'; pos += 2; continue; }
+                else if (str[pos + 1] == '"') { output += '"'; pos += 2; continue; }
+                else if (str[pos + 1] == '0') { output += '\0'; pos += 2; continue; }
+            }
+            output += str[pos];
+            pos++;
+            if (pos == str.size() - 1)
+                output += str[pos];
+        }
+
+        return output;
+    }
+
+    /**
+        @brief Replaces each char between A and Z with its lowercase equivalent.
+        @param str The string to convert
+    */
+    void lowercase(std::string* str)
+    {
+        for (size_t i = 0; i < str->size(); ++i)
+        {
+            (*str)[i] = (char)tolower((*str)[i]);
+        }
+    }
+
+    /**
+        @brief Returns a copy of the given string without uppercase chars.
+        @param str The string
+        @return The copy
+    */
+    std::string getLowercase(const std::string& str)
+    {
+        std::string output = std::string(str);
+        lowercase(&output);
+        return output;
+    }
+
+    /**
+        @brief Replaces each char between a and z with its uppercase equivalent.
+        @param str The string to convert
+    */
+    void uppercase(std::string* str)
+    {
+        for (size_t i = 0; i < str->size(); ++i)
+        {
+            (*str)[i] = (char)toupper((*str)[i]);
+        }
+    }
+
+    /**
+        @brief Returns a copy of the given string without lowercase chars.
+        @param str The string
+        @return The copy
+    */
+    std::string getUppercase(const std::string& str)
+    {
+        std::string output = std::string(str);
+        uppercase(&output);
+        return output;
+    }
+
+    /**
+        @brief Compares two strings ignoring different casing.
+        @param s1 First string
+        @param s2 Second string
+    */
+    int nocaseCmp(const std::string& s1, const std::string& s2)
+    {
+        std::string::const_iterator it1=s1.begin();
+        std::string::const_iterator it2=s2.begin();
+
+        //stop when either string's end has been reached
+        while ( (it1!=s1.end()) && (it2!=s2.end()) )
+        {
+            if(::toupper(*it1) != ::toupper(*it2)) //letters differ?
+                // return -1 to indicate smaller than, 1 otherwise
+                return (::toupper(*it1)  < ::toupper(*it2)) ? -1 : 1;
+            //proceed to the next character in each string
+            ++it1;
+            ++it2;
+        }
+        size_t size1=s1.size(), size2=s2.size();// cache lengths
+        //return -1,0 or 1 according to strings' lengths
+        if (size1==size2)
+            return 0;
+        return (size1<size2) ? -1 : 1;
+    }
+
+
+    /**
+        @brief Compares the first 'len' chars of two strings ignoring different casing.
+        @param s1 First string
+        @param s2 Second string
+        @param len Maximal number of chars to compare
+    */
+    int nocaseCmp(const std::string& s1, const std::string& s2, size_t len)
+    {
+        if (len == 0)
+            return 0;
+        std::string::const_iterator it1=s1.begin();
+        std::string::const_iterator it2=s2.begin();
+
+        //stop when either string's end has been reached
+        while ( (it1!=s1.end()) && (it2!=s2.end()) && len-- > 0)
+        {
+            if(::toupper(*it1) != ::toupper(*it2)) //letters differ?
+                // return -1 to indicate smaller than, 1 otherwise
+                return (::toupper(*it1)  < ::toupper(*it2)) ? -1 : 1;
+            //proceed to the next character in each string
+            ++it1;
+            ++it2;
+        }
+        return 0;
+    }
+
+    /**
+        @brief Returns true if the string contains a comment, introduced by #, %, ; or //.
+        @param str The string
+        @return True if the string contains a comment
+    */
+    bool hasComment(const std::string& str)
+    {
+        return (getCommentPosition(str) != std::string::npos);
+    }
+
+    /**
+        @brief If the string contains a comment, the comment gets returned (including the comment symbol), an empty string otherwise.
+        @param str The string
+        @return The comment
+    */
+    std::string getComment(const std::string& str)
+    {
+        return str.substr(getCommentPosition(str));
+    }
+
+    /**
+        @brief If the string contains a comment, the position of the comment-symbol gets returned, std::string::npos otherwise.
+        @param str The string
+        @return The position
+    */
+    size_t getCommentPosition(const std::string& str)
+    {
+        return getNextCommentPosition(str, 0);
+    }
+
+    /**
+        @brief Returns the position of the next comment-symbol, starting with start.
+        @param str The string
+        @param start The startposition
+        @return The position
+    */
+    size_t getNextCommentPosition(const std::string& str, size_t start)
+    {
+        for (size_t i = start; i < str.size(); i++)
+            if (isComment(str.substr(i)))
+                return i;
+
+        return std::string::npos;
+    }
+}

Copied: branches/core4/src/util/StringUtils.h (from rev 3222, branches/core4/src/util/String.h)
===================================================================
--- branches/core4/src/util/StringUtils.h	                        (rev 0)
+++ branches/core4/src/util/StringUtils.h	2009-06-29 16:10:46 UTC (rev 3250)
@@ -0,0 +1,81 @@
+/*
+ *   ORXONOX - the hottest 3D action shooter ever to exist
+ *                    > www.orxonox.net <
+ *
+ *
+ *   License notice:
+ *
+ *   This program is free software; you can redistribute it and/or
+ *   modify it under the terms of the GNU General Public License
+ *   as published by the Free Software Foundation; either version 2
+ *   of the License, or (at your option) any later version.
+ *
+ *   This program is distributed in the hope that it will be useful,
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *   GNU General Public License for more details.
+ *
+ *   You should have received a copy of the GNU General Public License
+ *   along with this program; if not, write to the Free Software
+ *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
+ *
+ *   Author:
+ *      Fabian 'x3n' Landau
+ *   Co-authors:
+ *      ...
+ *
+ */
+
+/**
+    @file
+    @brief Declaration of several string manipulation functions, used in many parts of the game.
+*/
+
+#ifndef _StringUtils_H__
+#define _StringUtils_H__
+
+#include "UtilPrereqs.h"
+#include <string>
+
+namespace orxonox
+{
+    extern _UtilExport std::string BLANKSTRING;
+    _UtilExport std::string getUniqueNumberString();
+
+    _UtilExport void        strip(std::string* str);
+    _UtilExport std::string getStripped(const std::string& str);
+
+    _UtilExport std::string removeTrailingWhitespaces(const std::string& str);
+
+    _UtilExport size_t      getNextQuote(const std::string& str, size_t start);
+    _UtilExport bool        isBetweenQuotes(const std::string& str, size_t pos);
+
+    _UtilExport bool        hasStringBetweenQuotes(const std::string& str);
+    _UtilExport std::string getStringBetweenQuotes(const std::string& str);
+
+    _UtilExport std::string stripEnclosingQuotes(const std::string& str);
+    _UtilExport std::string stripEnclosingBraces(const std::string& str);
+
+    _UtilExport bool        isEmpty(const std::string& str);
+    _UtilExport bool        isComment(const std::string& str);
+    _UtilExport bool        isNumeric(const std::string& str);
+
+    _UtilExport std::string addSlashes(const std::string& str);
+    _UtilExport std::string removeSlashes(const std::string& str);
+
+    _UtilExport void        lowercase(std::string* str);
+    _UtilExport std::string getLowercase(const std::string& str);
+
+    _UtilExport void        uppercase(std::string* str);
+    _UtilExport std::string getUppercase(const std::string& str);
+
+    _UtilExport int         nocaseCmp(const std::string& s1, const std::string& s2);
+    _UtilExport int         nocaseCmp(const std::string& s1, const std::string& s2, size_t len);
+
+    _UtilExport bool        hasComment(const std::string& str);
+    _UtilExport std::string getComment(const std::string& str);
+    _UtilExport size_t      getCommentPosition(const std::string& str);
+    _UtilExport size_t      getNextCommentPosition(const std::string& str, size_t start = 0);
+}
+
+#endif /* _StringUtils_H__ */




More information about the Orxonox-commit mailing list