#import <string.h>
#import <stdlib.h>
#import <stdio.h>
#import <varargs.h>
#import "stringops.h"
char *copyString(char *s)
{
int len;
char *t;
if (s == NULL) return NULL;
len = strlen(s) + 1;
t = malloc(len);
bcopy(s, t, len);
return t;
}
char *concatString(char *s, char *t)
{
int len;
if (t == NULL) return s;
len = strlen(s) + strlen(t) + 1;
s = realloc(s, len);
strcat(s, t);
return s;
}
char **insertString(char *s, char **l, unsigned int x)
{
int i, len;
if (s == NULL) return l;
if (l == NULL)
{
l = (char **)malloc(2 * sizeof(char *));
l[0] = copyString(s);
l[1] = NULL;
return l;
}
for (i = 0; l[i] != NULL; i++);
len = i + 1;
l = (char **)realloc(l, (len + 1) * sizeof(char *));
if ((x >= (len - 1)) || (x == IndexNull))
{
l[len - 1] = copyString(s);
l[len] = NULL;
return l;
}
for (i = len; i > x; i--) l[i] = l[i - 1];
l[x] = copyString(s);
return l;
}
char **appendString(char *s, char **l)
{
return insertString(s, l, IndexNull);
}
void freeList(char **l)
{
int i;
if (l == NULL) return;
for (i = 0; l[i] != NULL; i++)
{
if (l[i] != NULL) free(l[i]);
l[i] = NULL;
}
if (l != NULL) free(l);
}
void freeString(char *s)
{
if (s == NULL) return;
free(s);
}
unsigned int listLength(char **l)
{
int i;
if (l == NULL) return 0;
for (i = 0; l[i] != NULL; i++);
return i;
}
unsigned int listIndex(char *s,char **l)
{
int i;
if (l == NULL) return IndexNull;
for (i = 0; l[i] != NULL; i++)
{
if (strcmp(s, l[i]) == 0) return i;
}
return IndexNull;
}
char *prefix(char *s, char c)
{
int i;
char *t;
if (s == NULL) return NULL;
for (i = 0; ((s[i] != '\0') && (s[i] != c)); i++);
if (i == 0) return NULL;
if (s[i] == '\0') return copyString(s);
t = malloc(i + 1);
bcopy(s, t, i);
t[i] = '\0';
return t;
}
char *postfix(char *s, char c)
{
int i, len;
char *t;
if (s == NULL) return NULL;
for (i = 0; ((s[i] != '\0') && (s[i] != c)); i++);
if (s[i] == '\0') return NULL;
len = strlen(s) - i;
if (len == 1) return NULL;
t = malloc(len);
len--;
bcopy((s + i + 1), t, len);
t[len] = '\0';
return t;
}
char *presuffix(char *s, char c)
{
int i, len;
char *t;
if (s == NULL) return NULL;
len = strlen(s);
for (i = len - 1; ((i >= 0) && (s[i] != c)); i--);
if (i == 0) return NULL;
if (s[0] == '\0') return NULL;
t = malloc(i + 1);
bcopy(s, t, i);
t[i] = '\0';
return t;
}
char *suffix(char *s, char c)
{
int i, len;
char *t;
if (s == NULL) return NULL;
len = strlen(s);
for (i = len - 1; ((i >= 0) && (s[i] != c)); i--);
if (i == 0) return NULL;
len -= i;
if (len == 1) return NULL;
t = malloc(len);
len--;
bcopy((s + i + 1), t, len);
t[len] = '\0';
return t;
}
char *lowerCase(char *s)
{
int i;
char *t;
if (s == NULL) return NULL;
t = malloc(strlen(s) + 1);
for (i = 0; s[i] != '\0'; i++)
{
if ((s[i] >= 'A') && (s[i] <= 'Z')) t[i] = s[i] + 32;
else t[i] = s[i];
}
t[i] = '\0';
return t;
}
char **explode(char *s, char c)
{
char **l = NULL;
char *p, *t;
int i, n;
if (s == NULL) return NULL;
p = s;
while (p[0] != '\0')
{
for (i = 0; ((p[i] != '\0') && p[i] != c); i++);
n = i;
t = malloc(n + 1);
for (i = 0; i < n; i++) t[i] = p[i];
t[n] = '\0';
l = appendString(t, l);
free(t);
t = NULL;
if (p[i] == '\0') return l;
if (p[i + 1] == '\0') l = appendString("", l);
p = p + i + 1;
}
return l;
}
char *itoa(int n)
{
char s[32];
sprintf(s, "%d", n);
return copyString(s);
}