blob: 38bc5f3b69920405bf8604f594500e7dba1104b1 [file] [log] [blame]
/*************************************************************************/
/* */
/* Language Technologies Institute */
/* Carnegie Mellon University */
/* Copyright (c) 1999 */
/* All Rights Reserved. */
/* */
/* Permission is hereby granted, free of charge, to use and distribute */
/* this software and its documentation without restriction, including */
/* without limitation the rights to use, copy, modify, merge, publish, */
/* distribute, sublicense, and/or sell copies of this work, and to */
/* permit persons to whom this work is furnished to do so, subject to */
/* the following conditions: */
/* 1. The code must retain the above copyright notice, this list of */
/* conditions and the following disclaimer. */
/* 2. Any modifications must be clearly marked as such. */
/* 3. Original authors' names are not deleted. */
/* 4. The authors' names are not used to endorse or promote products */
/* derived from this software without specific prior written */
/* permission. */
/* */
/* CARNEGIE MELLON UNIVERSITY AND THE CONTRIBUTORS TO THIS WORK */
/* DISCLAIM ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING */
/* ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT */
/* SHALL CARNEGIE MELLON UNIVERSITY NOR THE CONTRIBUTORS BE LIABLE */
/* FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES */
/* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN */
/* AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, */
/* ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF */
/* THIS SOFTWARE. */
/* */
/*************************************************************************/
/* Author: Alan W Black (awb@cs.cmu.edu) */
/* Date: December 1999 */
/*************************************************************************/
/* */
/* String manipulation functions */
/* */
/*************************************************************************/
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include "cst_alloc.h"
#include "cst_string.h"
#include "cst_file.h"
#ifdef UNDER_CE /* WinCE does not fully implement ANSI C */
cst_string *cst_strrchr(const cst_string *str, int c)
{
cst_string *p = (const cst_string *)str + cst_strlen(str);
while (p >= str) {
if (*p == c)
return p;
--p;
}
return NULL;
}
double cst_atof(const char *str)
{
/* double f = 0.0; */
/* sscanf(str, "%f", &f); */
return atof(str);
}
#else /* Sane operating system */
cst_string *cst_strrchr(const cst_string *str, int c)
{
return (cst_string *)strrchr((const char *)str, c);
}
double cst_atof(const char *str)
{
return atof(str);
}
#endif /* WinCE */
cst_string *cst_strdup(const cst_string *str)
{
cst_string *nstr = NULL;
if (str)
{
nstr = cst_alloc(cst_string,cst_strlen((const char *)str)+1);
memmove(nstr,str,cst_strlen((const char *)str)+1);
}
return nstr;
}
cst_string *cst_strchr(const cst_string *s, int c)
{
return (cst_string *)strchr((const char *)s,c);
}
char *cst_substr(const char *str,int start, int length)
{
char *nstr = NULL;
if (str)
{
nstr = cst_alloc(char,length+1);
strncpy(nstr,str+start,length);
nstr[length] = '\0';
}
return nstr;
}
char *cst_string_before(const char *s,const char *c)
{
char *p;
char *q;
p = (char *)cst_strstr(s,c);
if (p == NULL)
return NULL;
q = (char *)cst_strdup((cst_string *)s);
q[cst_strlen(s)-cst_strlen(p)] = '\0';
return q;
}
cst_string *cst_downcase(const cst_string *str)
{
cst_string *dc;
int i;
dc = cst_strdup(str);
for (i=0; str[i] != '\0'; i++)
{
if (isupper((int)str[i]))
dc[i] = tolower((int)str[i]);
}
return dc;
}
cst_string *cst_upcase(const cst_string *str)
{
cst_string *uc;
int i;
uc = cst_strdup(str);
for (i=0; str[i] != '\0'; i++)
{
if (islower((int)str[i]))
uc[i] = toupper((int)str[i]);
}
return uc;
}
int cst_member_string(const char *str, const char * const *slist)
{
const char * const *p;
for (p = slist; *p; ++p)
if (cst_streq(*p, str))
break;
return *p != NULL;
}
char *cst_strcat(const char *a, const char *b)
{
char *r;
r = cst_alloc(char,cst_strlen(a)+cst_strlen(b)+1);
cst_sprintf(r,"%s%s",a,b);
return r;
}
char *cst_strcat3(const char *a, const char *b, const char *c)
{
char *r;
r = cst_alloc(char,cst_strlen(a)+cst_strlen(b)+cst_strlen(c)+1);
cst_sprintf(r,"%s%s%s",a,b,c);
return r;
}