| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217 | //-----------------------------------------------------------------------------// Copyright (c) 2012 GarageGames, LLC//// 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.//-----------------------------------------------------------------------------#include "core/strings/stringFunctions.h"#include "core/strings/stringUnit.h"#include "console/console.h"namespace StringUnit{   static char _returnBuffer[ 2048 ];   const char *getUnit(const char *string, U32 index, const char *set, char* buffer, U32 bufferSize)   {      if( !buffer )      {         buffer = _returnBuffer;         bufferSize = sizeof( _returnBuffer );      }      AssertFatal( bufferSize, "StringUnit::getUnit - bufferSize cannot be zero!" );      if( !bufferSize )         return "";               buffer[0] = 0;            U32 sz;      while(index--)      {         if(!*string)            return buffer;         sz = dStrcspn(string, set);         if (string[sz] == 0)            return buffer;                     string += (sz + 1);      }      sz = dStrcspn(string, set);      if (sz == 0)         return buffer;      AssertWarn( sz + 1 < bufferSize, "Size of returned string too large for return buffer" );      sz = getMin( sz, bufferSize - 1 );      dStrncpy(buffer, string, sz);      buffer[sz] = '\0';      return buffer;   }   const char *getUnits(const char *string, S32 startIndex, S32 endIndex, const char *set)   {      if( startIndex > endIndex )         return "";      S32 sz;      S32 index = startIndex;      while(index--)      {         if(!*string)            return "";         sz = dStrcspn(string, set);         if (string[sz] == 0)            return "";         string += (sz + 1);      }      const char *startString = string;      for( U32 i = startIndex; i <= endIndex && *string; i ++ )      {         sz = dStrcspn(string, set);         string += sz;         if( i < endIndex )            string ++;      }            S32 totalSize = ( S32 )( string - startString );      AssertWarn( totalSize + 1 < sizeof( _returnBuffer ), "Size of returned string too large for return buffer" );      totalSize = getMin( totalSize, S32( sizeof( _returnBuffer ) - 1 ) );      if( totalSize > 0 )      {         char *ret = &_returnBuffer[0];         dStrncpy( ret, startString, totalSize );         ret[ totalSize ] = '\0';                  return ret;      }      return "";   }   U32 getUnitCount(const char *string, const char *set)   {      U32 count = 0;      U8 last = 0;      while(*string)      {         last = *string++;         for(U32 i =0; set[i]; i++)         {            if(last == set[i])            {               count++;               last = 0;               break;            }         }      }      if(last)         count++;      return count;   }   const char* setUnit(const char *string, U32 index, const char *replace, const char *set)   {      U32 sz;      const char *start = string;      AssertFatal( dStrlen(string) + dStrlen(replace) + 1 < sizeof( _returnBuffer ), "Size of returned string too large for return buffer" );      char *ret = &_returnBuffer[0];      ret[0] = '\0';      U32 padCount = 0;      while(index--)      {         sz = dStrcspn(string, set);         if(string[sz] == 0)         {            string += sz;            padCount = index + 1;            break;         }         else            string += (sz + 1);      }      // copy first chunk      sz = string-start;      dStrncpy(ret, start, sz);      for(U32 i = 0; i < padCount; i++)         ret[sz++] = set[0];      // replace this unit      ret[sz] = '\0';      dStrcat(ret, replace, 2048);      // copy remaining chunks      sz = dStrcspn(string, set);         // skip chunk we're replacing      if(!sz && !string[sz])         return ret;      string += sz;      dStrcat(ret, string, 2048);      return ret;   }   const char* removeUnit(const char *string, U32 index, const char *set)   {      U32 sz;      const char *start = string;      AssertFatal( dStrlen(string) + 1 < sizeof( _returnBuffer ), "Size of returned string too large for return buffer" );      char *ret = &_returnBuffer[0];      ret[0] = '\0';      while(index--)      {         sz = dStrcspn(string, set);         // if there was no unit out there... return the original string         if(string[sz] == 0)            return start;         else            string += (sz + 1);      }      // copy first chunk      sz = string-start;      dStrncpy(ret, start, sz);      ret[sz] = 0;      // copy remaining chunks      sz = dStrcspn(string, set);         // skip chunk we're removing      if(string[sz] == 0) {               // if that was the last...         if(string != start) {            ret[string - start - 1] = 0;  // then kill any trailing delimiter         }         return ret;                      // and bail      }      string += sz + 1; // skip the extra field delimiter      dStrcat(ret, string, 2048);      return ret;   }}
 |