Checked in Xiaoyang's changes to String library

This commit is contained in:
Tom Igoe 2010-07-27 10:06:49 +00:00
parent 8fcb098533
commit 27b3254e99
1 changed files with 79 additions and 61 deletions

View File

@ -1,21 +1,21 @@
/* /*
WString.h - String library for Wiring & Arduino WString.h - String library for Wiring & Arduino
Copyright (c) 2009-10 Hernando Barragan. All right reserved. Copyright (c) 2009-10 Hernando Barragan. All right reserved.
This library is free software; you can redistribute it and/or This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version. version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful, This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details. Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#ifndef String_h #ifndef String_h
#define String_h #define String_h
@ -27,17 +27,17 @@
class String class String
{ {
public: public:
// constructors // constructors
String( const char *value = "" ); String( const char* value = "" );
String( const String &value ); String( const String &value );
explicit String( const char ); explicit String( const char );
explicit String( const unsigned char ); explicit String( const unsigned char );
explicit String( const int, const int base=10); explicit String( const int, const int base=10);
explicit String( const unsigned int, const int base=10 ); explicit String( const unsigned int, const int base=10 );//negative sign only works on decimal
explicit String( const long, const int base=10 ); explicit String( const long, const int base=10 );
explicit String( const unsigned long, const int base=10 ); explicit String( const unsigned long, const int base=10 );//need add function to detect if number is bigger than the limit
~String() { free(_buffer); } ~String() { free(_buffer); _length = _capacity = 0;} //added _length = _capacity = 0;
// operators // operators
const String & operator = ( const String &rhs ); const String & operator = ( const String &rhs );
@ -45,75 +45,93 @@ class String
const String & operator +=( const char ); const String & operator +=( const char );
int operator ==( const String &rhs ) const; int operator ==( const String &rhs ) const;
int operator !=( const String &rhs ) const; int operator !=( const String &rhs ) const;
//is this useful?
int operator < ( const String &rhs ) const; int operator < ( const String &rhs ) const;
int operator > ( const String &rhs ) const; int operator > ( const String &rhs ) const;
int operator <=( const String &rhs ) const; int operator <=( const String &rhs ) const;
int operator >=( const String &rhs ) const; int operator >=( const String &rhs ) const;
friend String operator + ( String lhs, const String &rhs );
char operator []( unsigned int index ) const; char operator []( unsigned int index ) const;
char& operator []( unsigned int index ); char& operator []( unsigned int index );
//operator const char *() const { return _buffer; }
// general methods // general methods
char charAt( unsigned int index ) const; char charAt( unsigned int index ) const;
int compareTo( const String &anotherString ) const; void setCharAt(unsigned int index, const char ch);
boolean startsWith( const String &prefix ) const;
boolean startsWith( const String &prefix, unsigned int toffset ) const;
boolean endsWith( const String &suffix ) const; boolean endsWith( const String &suffix ) const;
boolean equals( const String &anObject ) const; boolean contains( const String &str ) const; //added
boolean equalsIgnoreCase( const String &anotherString ) const; boolean equals( const String &str ) const;
boolean equalsIgnoreCase( const String &str ) const;
String trim( ) const;
String toLowerCase( ) const;
String toUpperCase( ) const;
String replace( char oldChar, char newChar );
String replace( const String& match, const String& replace );
String substring( unsigned int beginIndex ) const;
String substring( unsigned int beginIndex, unsigned int endIndex ) const;
const String& append( const String &str );
const String& append( const char );
int compareTo( const String &str ) const;
int compareTo( const char* str ) const; //added
int indexOf( char ch ) const; int indexOf( char ch ) const;
int indexOf( char ch, unsigned int fromIndex ) const; int indexOf( char ch, unsigned int fromIndex ) const;
int indexOf( const String &str ) const; int indexOf( const String &str ) const;
int indexOf( const String &str, unsigned int fromIndex ) const; int indexOf( const String &str, unsigned int fromIndex ) const;
int lastIndexOf( char ch ) const; int lastIndexOf( char ch ) const;
int lastIndexOf( char ch, unsigned int fromIndex ) const; int lastIndexOf( char ch, unsigned int fromIndex ) const; //from right to left?
int lastIndexOf( const String &str ) const; int lastIndexOf( const String &str ) const;
int lastIndexOf( const String &str, unsigned int fromIndex ) const; int lastIndexOf( const String &str, unsigned int fromIndex ) const;
const unsigned int length( ) const { return _length; } const unsigned int length( ) const { return _length; }
void setCharAt(unsigned int index, const char ch);
boolean startsWith( const String &prefix ) const;
boolean startsWith( const String &prefix, unsigned int toffset ) const;
String substring( unsigned int beginIndex ) const;
String substring( unsigned int beginIndex, unsigned int endIndex ) const;
String toLowerCase( ) const;
String toUpperCase( ) const;
String trim( ) const;
const byte *getBytes() const { return (byte*)_buffer; } const byte *getBytes() const { return (byte*)_buffer; }
const char* toCharArray() const { return _buffer; } const char* toCharArray() const { return _buffer; }
const String& concat( const String &str );
String replace( char oldChar, char newChar );
String replace( const String& match, const String& replace );
friend String operator + ( String lhs, const String &rhs );
protected: //version checking
String version(void); // the version number
protected:
char *_buffer; // the actual char array char *_buffer; // the actual char array
unsigned int _capacity; // the array length minus one (for the '\0') unsigned int _capacity; // the array length minus one (for the '\0')
unsigned int _length; // the String length (not counting the '\0') unsigned int _length; // the String length (not counting the '\0')
void getBuffer(unsigned int maxStrLen); void getBuffer(unsigned int maxStrLen);
void doubleBuffer( ); //void doubleBuffer( );
private: private:
}; };
// allocate buffer space // allocate buffer space
inline void String::getBuffer(unsigned int maxStrLen) inline void String::getBuffer(unsigned int maxStrLen)
{ {
_capacity = maxStrLen; _capacity = maxStrLen;
_buffer = (char *) malloc(_capacity + 1); _buffer = (char *) malloc(_capacity + 1);
if(_buffer == NULL){ //added for memory alloc error
_length = _capacity = 0;
}
} }
// double the buffer size /* used only once, really not effcient
inline void String::doubleBuffer( ) // double the buffer size
{ inline void String::doubleBuffer( )
char *temp = _buffer; {
getBuffer( ++_capacity * 2 ); char *temp = _buffer;
strcpy( _buffer, temp ); getBuffer( ++_capacity * 2 );
free(temp); strcpy( _buffer, temp );
} free(temp);
}
*/
inline String operator+( String lhs, const String &rhs ) inline String operator+( String lhs, const String &rhs )
{ {
return lhs += rhs; return lhs += rhs;
} }