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;
-
- dsize_t 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 "";
- dsize_t 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 )
- 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;
- }
- }
|