187 lines
5.0 KiB
C++
187 lines
5.0 KiB
C++
/* Extended string routines
|
|
*
|
|
* Copyright notice for this file:
|
|
* Copyright (C) 2004 Jason Oster (Parasyte)
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
*/
|
|
|
|
#include "xstring.h"
|
|
|
|
|
|
//Upper case routine
|
|
// Returns number of characters modified
|
|
int str_ucase(char *str) {
|
|
unsigned int i=0,j=0; //mbg merge 7/17/06 changed to unsigned int
|
|
|
|
while (i < strlen(str)) {
|
|
if ((str[i] >= 'a') && (str[i] <= 'z')) {
|
|
str[i] &= ~0x20;
|
|
j++;
|
|
}
|
|
i++;
|
|
}
|
|
return j;
|
|
}
|
|
|
|
|
|
//Lower case routine
|
|
// Returns number of characters modified
|
|
int str_lcase(char *str) {
|
|
unsigned int i=0,j=0; //mbg merge 7/17/06 changed to unsigned int
|
|
|
|
while (i < strlen(str)) {
|
|
if ((str[i] >= 'A') && (str[i] <= 'Z')) {
|
|
str[i] |= 0x20;
|
|
j++;
|
|
}
|
|
i++;
|
|
}
|
|
return j;
|
|
}
|
|
|
|
|
|
//White space-trimming routine
|
|
// Removes whitespace from left side of string, depending on the flags set (See STRIP_x definitions in xstring.h)
|
|
// Returns number of characters removed
|
|
int str_ltrim(char *str, int flags) {
|
|
unsigned int i=0; //mbg merge 7/17/06 changed to unsigned int
|
|
|
|
while (str[0]) {
|
|
if ((str[0] != ' ') || (str[0] != '\t') || (str[0] != '\r') || (str[0] != '\n')) break;
|
|
|
|
if ((flags & STRIP_SP) && (str[0] == ' ')) {
|
|
i++;
|
|
strcpy(str,str+1);
|
|
}
|
|
if ((flags & STRIP_TAB) && (str[0] == '\t')) {
|
|
i++;
|
|
strcpy(str,str+1);
|
|
}
|
|
if ((flags & STRIP_CR) && (str[0] == '\r')) {
|
|
i++;
|
|
strcpy(str,str+1);
|
|
}
|
|
if ((flags & STRIP_LF) && (str[0] == '\n')) {
|
|
i++;
|
|
strcpy(str,str+1);
|
|
}
|
|
}
|
|
return i;
|
|
}
|
|
|
|
|
|
//White space-trimming routine
|
|
// Removes whitespace from right side of string, depending on the flags set (See STRIP_x definitions in xstring.h)
|
|
// Returns number of characters removed
|
|
int str_rtrim(char *str, int flags) {
|
|
unsigned int i=0; //mbg merge 7/17/06 changed to unsigned int
|
|
|
|
while (strlen(str)) {
|
|
if ((str[strlen(str)-1] != ' ') ||
|
|
(str[strlen(str)-1] != '\t') ||
|
|
(str[strlen(str)-1] != '\r') ||
|
|
(str[strlen(str)-1] != '\n')) break;
|
|
|
|
if ((flags & STRIP_SP) && (str[0] == ' ')) {
|
|
i++;
|
|
str[strlen(str)-1] = 0;
|
|
}
|
|
if ((flags & STRIP_TAB) && (str[0] == '\t')) {
|
|
i++;
|
|
str[strlen(str)-1] = 0;
|
|
}
|
|
if ((flags & STRIP_CR) && (str[0] == '\r')) {
|
|
i++;
|
|
str[strlen(str)-1] = 0;
|
|
}
|
|
if ((flags & STRIP_LF) && (str[0] == '\n')) {
|
|
i++;
|
|
str[strlen(str)-1] = 0;
|
|
}
|
|
}
|
|
return i;
|
|
}
|
|
|
|
|
|
//White space-stripping routine
|
|
// Removes whitespace depending on the flags set (See STRIP_x definitions in xstring.h)
|
|
// Returns number of characters removed, or -1 on error
|
|
int str_strip(char *str, int flags) {
|
|
unsigned int i=0,j=0; //mbg merge 7/17/06 changed to unsigned int
|
|
char *astr,chr;
|
|
|
|
if (!strlen(str)) return -1;
|
|
if (!(flags & (STRIP_SP|STRIP_TAB|STRIP_CR|STRIP_LF))) return -1;
|
|
if (!(astr = (char*)malloc(strlen(str)+1))) return -1;
|
|
while (i < strlen(str)) {
|
|
chr = str[i++];
|
|
if ((flags & STRIP_SP) && (chr == ' ')) chr = 0;
|
|
if ((flags & STRIP_TAB) && (chr == '\t')) chr = 0;
|
|
if ((flags & STRIP_CR) && (chr == '\r')) chr = 0;
|
|
if ((flags & STRIP_LF) && (chr == '\n')) chr = 0;
|
|
|
|
if (chr) astr[j++] = chr;
|
|
}
|
|
astr[j] = 0;
|
|
strcpy(str,astr);
|
|
free(astr);
|
|
return j;
|
|
}
|
|
|
|
|
|
//Character replacement routine
|
|
// Replaces all instances of 'search' with 'replace'
|
|
// Returns number of characters modified
|
|
int chr_replace(char *str, char search, char replace) {
|
|
unsigned int i=0,j=0; //mbg merge 7/17/06 changed to unsigned int
|
|
|
|
while (i < strlen(str)) {
|
|
if (str[i] == search) {
|
|
str[i] = replace;
|
|
j++;
|
|
}
|
|
i++;
|
|
}
|
|
return j;
|
|
}
|
|
|
|
|
|
//Sub-String replacement routine
|
|
// Replaces all instances of 'search' with 'replace'
|
|
// Returns number of sub-strings modified, or -1 on error
|
|
int str_replace(char *str, char *search, char *replace) {
|
|
unsigned int i=0,j=0; //mbg merge 7/17/06 changed to unsigned int
|
|
int searchlen,replacelen;
|
|
char *astr;
|
|
|
|
searchlen = strlen(search);
|
|
replacelen = strlen(replace);
|
|
if ((!strlen(str)) || (!searchlen)) return -1; //note: allow *replace to have a length of zero!
|
|
if (!(astr = (char*)malloc(strlen(str)+1))) return -1;
|
|
while (i < strlen(str)) {
|
|
if (!strncmp(str+i,search,searchlen)) {
|
|
if (replacelen) memcpy(astr+j,replace,replacelen);
|
|
i += searchlen;
|
|
j += replacelen;
|
|
}
|
|
else astr[j++] = str[i++];
|
|
}
|
|
astr[j] = 0;
|
|
strcpy(str,astr);
|
|
free(astr);
|
|
return j;
|
|
}
|