#include "cwCommon.h" #include "cwLog.h" #include "cwText.h" #include "cwCommonImpl.h" #include "cwMem.h" namespace cw { const char* _nextWhiteChar( const char* s, bool eosFl ) { if( s == nullptr ) return nullptr; for(; *s; ++s ) if( isspace(*s) ) return s; return eosFl ? s : nullptr; } const char* _nextNonWhiteChar( const char* s, bool eosFl ) { if( s == nullptr ) return nullptr; for(; *s; ++s ) if( !isspace(*s) ) return s; return eosFl ? s : nullptr; } /* unsigned _toText( char* buf, unsigned bufN, unsigned char v ) { if( bufN < 1 ) return 0; buf[0] = v; return 1; } unsigned _toText( char* buf, unsigned bufN, char v ) { if( bufN < 1 ) return 0; buf[0] = v; return 1; } */ } unsigned cw::textLength( const char* s ) { return s == nullptr ? 0 : strlen(s); } int cw::textCompare( const char* s0, const char* s1 ) { if( s0 == nullptr || s1 == nullptr ) return s0==s1 ? 0 : 1; // if both pointers are nullptr then trigger a match return strcmp(s0,s1); } int cw::textCompare( const char* s0, const char* s1, unsigned n) { if( s0 == nullptr || s1 == nullptr ) return s0==s1 ? 0 : 1; // if both pointers are nullptr then trigger a match return strncmp(s0,s1,n); } const char* cw::nextWhiteChar( const char* s ) { return _nextWhiteChar(s,false); } const char* cw::nextWhiteCharEOS( const char* s ) { return _nextWhiteChar(s,true); } const char* cw::nextNonWhiteChar( const char* s ) { return _nextNonWhiteChar(s,false); } const char* cw::nextNonWhiteCharEOS( const char* s ) { return _nextNonWhiteChar(s,true); } const char* cw::firstMatchChar( const char* s, char c ) { if( s == nullptr ) return nullptr; for(; *s; ++s) if(*s == c) return s; return nullptr; } const char* cw::lastMatchChar( const char* s, char c ) { unsigned sn; if( s == nullptr ) return nullptr; sn = textLength(s); if( sn == 0 ) return nullptr; for(const char* s1=s+(sn-1); s<=s1; --s1) if( *s1 == c ) return s1; return nullptr; } bool cw::isInteger( const char* s ) { for(; *s; ++s) if(!isdigit(*s)) return false; return true; } bool cw::isReal( const char* s) { unsigned decN = 0; for(; *s; ++s) if( *s == '.' ) { if( ++decN > 1) return false; } else { if(!isdigit(*s)) return false; } return true; } bool cw::isIdentifier( const char* s ) { if( !isalpha(*s) && *s != '_' ) return false; for(++s; *s; ++s) if( !isalnum(*s) && *s != '_' ) return false; return true; } char* cw::textJoin( const char* s0, const char* s1 ) { if( s0 == nullptr && s1 == nullptr ) return nullptr; unsigned s0n = textLength(s0); unsigned s1n = textLength(s1); unsigned sn = s0n + s1n + 1; char* s = mem::alloc(sn+1); s[0] = 0; if( s0 != nullptr ) strcpy(s,mem::duplStr(s0)); if( s0 != nullptr && s1 != nullptr ) strcpy(s + strlen(s0), mem::duplStr(s1) ); return s; } char* cw::textAppend( char* s0, const char* s1 ) { if( s0 == nullptr && s1==nullptr) return nullptr; return mem::appendStr(s0,s1); } unsigned cw::toText( char* buf, unsigned bufN, bool v ) { return toText( buf, bufN, v ? "true" : "false" ); } unsigned cw::toText( char* buf, unsigned bufN, char v ) { return snprintf(buf,bufN, "%c", v ); } unsigned cw::toText( char* buf, unsigned bufN, unsigned char v ) { return snprintf(buf,bufN, "%c", v ); } unsigned cw::toText( char* buf, unsigned bufN, unsigned short v ) { return snprintf(buf,bufN,"%i",v); } unsigned cw::toText( char* buf, unsigned bufN, short v ) { return snprintf(buf,bufN,"%i",v); } unsigned cw::toText( char* buf, unsigned bufN, unsigned int v ) { return snprintf(buf,bufN,"%i",v); } unsigned cw::toText( char* buf, unsigned bufN, int v ) { return snprintf(buf,bufN,"%i",v); } unsigned cw::toText( char* buf, unsigned bufN, unsigned long long v ) { return snprintf(buf,bufN,"%lli",v); } unsigned cw::toText( char* buf, unsigned bufN, long long v ) { return snprintf(buf,bufN,"%lli",v); } unsigned cw::toText( char* buf, unsigned bufN, float v ) { return snprintf(buf,bufN,"%f",v); } unsigned cw::toText( char* buf, unsigned bufN, double v ) { return snprintf(buf,bufN,"%f",v); } unsigned cw::toText( char* buf, unsigned bufN, const char* v ) { if( v == nullptr ) { cwLogError(kInvalidArgRC,"The source string in a call to 'toText()' was null."); return 0; } unsigned i; for(i=0; i