Checked in Xiaoyang's changes to String library
This commit is contained in:
parent
445d1688c9
commit
82fefa76ac
|
@ -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,94 +27,112 @@
|
||||||
|
|
||||||
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 );
|
||||||
const String & operator +=( const String &rhs );
|
const String & operator +=( const String &rhs );
|
||||||
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 );
|
//version checking
|
||||||
String replace( const String& match, const String& replace );
|
String version(void); // the version number
|
||||||
friend String operator + ( String lhs, const String &rhs );
|
|
||||||
|
protected:
|
||||||
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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
Loading…
Reference in New Issue