4 * Copyright 2000 Jon Griffiths
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
23 /*******************************************************************
26 * Create a single string from many substrings
28 char *str_create(size_t num_str
, ...)
31 size_t len
= 1, i
= 0;
34 va_start (args
, num_str
);
35 for (i
= 0; i
< num_str
; i
++)
36 if ((t
= va_arg(args
, char *)))
40 if (!(tmp
= (char *) malloc (len
)))
41 fatal ("Out of memory");
45 va_start (args
, num_str
);
46 for (i
= 0; i
< num_str
; i
++)
47 if ((t
= va_arg(args
, char *)))
54 /*******************************************************************
57 * Create a single string from many substrings, terminating in a number
59 char *str_create_num(size_t num_str
, int num
, ...)
62 size_t len
= 8, i
= 0;
66 for (i
= 0; i
< num_str
; i
++)
67 if ((t
= va_arg(args
, char *)))
71 if (!(tmp
= (char *) malloc (len
)))
72 fatal ("Out of memory");
77 for (i
= 0; i
< num_str
; i
++)
78 if ((t
= va_arg(args
, char *)))
81 sprintf (tmp
+ len
- 8, "%d", num
);
86 /*******************************************************************
89 * Create a new substring from a string
91 char *str_substring(const char *start
, const char *end
)
95 assert (start
&& end
&& end
> start
);
97 if (!(newstr
= (char *) malloc (end
- start
+ 1)))
98 fatal ("Out of memory");
100 memcpy (newstr
, start
, end
- start
);
101 newstr
[end
- start
] = '\0';
107 /*******************************************************************
110 * Swap two strings in another string, in place
111 * Modified PD code from 'snippets'
113 char *str_replace (char *str
, const char *oldstr
, const char *newstr
)
118 if (!(p
= strstr(str
, oldstr
)))
120 oldlen
= strlen (oldstr
);
121 newlen
= strlen (newstr
);
122 memmove (q
= p
+ newlen
, p
+ oldlen
, strlen (p
+ oldlen
) + 1);
123 memcpy (p
, newstr
, newlen
);
128 /*******************************************************************
131 * Locate one string in another, ignoring spaces
133 const char *str_match (const char *str
, const char *match
, int *found
)
135 assert(str
&& match
&& found
);
137 while (*str
== ' ') str
++;
138 if (!strncmp (str
, match
, strlen (match
)))
141 str
+= strlen (match
);
142 while (*str
== ' ') str
++;
150 /*******************************************************************
153 * Locate the first occurrence of a set of characters in a string
155 const char *str_find_set (const char *str
, const char *findset
)
157 assert(str
&& findset
);
161 const char *p
= findset
;
171 /*******************************************************************
176 char *str_toupper (char *str
)
181 *str
= toupper (*str
);
188 /*******************************************************************
191 * Open a file returning only on success
193 FILE *open_file (const char *name
, const char *ext
, const char *mode
)
198 if (((unsigned)snprintf (fname
, sizeof (fname
), "%s%s%s",
199 *mode
== 'w' ? "./" : "", name
, ext
) > sizeof (fname
)))
200 fatal ("File name too long");
203 printf ("Open file %s\n", fname
);
205 fp
= fopen (fname
, mode
);
207 fatal ("Cant open file");
212 /*******************************************************************
215 * Fatal error handling
217 void fatal (const char *message
)