annotate gui/util/string.c @ 36989:0b80003f6542

Relocate the cut functions. Put them into the string functions file.
author ib
date Thu, 27 Mar 2014 09:15:47 +0000
parents b33ff300128e
children fa8b6892b0bf
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
33048
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
1 /*
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
2 * This file is part of MPlayer.
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
3 *
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
4 * MPlayer is free software; you can redistribute it and/or modify
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
5 * it under the terms of the GNU General Public License as published by
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
6 * the Free Software Foundation; either version 2 of the License, or
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
7 * (at your option) any later version.
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
8 *
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
9 * MPlayer is distributed in the hope that it will be useful,
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
12 * GNU General Public License for more details.
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
13 *
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
14 * You should have received a copy of the GNU General Public License along
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
15 * with MPlayer; if not, write to the Free Software Foundation, Inc.,
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
16 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
17 */
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
18
35479
ab09ed2d181b Add doxygen comments to string.c.
ib
parents: 35475
diff changeset
19 /**
ab09ed2d181b Add doxygen comments to string.c.
ib
parents: 35475
diff changeset
20 * @file
ab09ed2d181b Add doxygen comments to string.c.
ib
parents: 35475
diff changeset
21 * @brief String utilities
ab09ed2d181b Add doxygen comments to string.c.
ib
parents: 35475
diff changeset
22 */
ab09ed2d181b Add doxygen comments to string.c.
ib
parents: 35475
diff changeset
23
33740
2c02269701bd Remove macros guiSetFilename() and guiSetDF() from interface.h.
ib
parents: 33737
diff changeset
24 #include <stdlib.h>
33737
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
25 #include <string.h>
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
26
33048
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
27 #include "string.h"
35525
e27855a45128 Rebuild GUI directory structure.
ib
parents: 35493
diff changeset
28 #include "gui/app/gui.h"
34175
a345e7162d0a Move TranslateFilename() to util/string.c.
ib
parents: 33982
diff changeset
29
33982
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
30 /**
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
31 * @brief Convert a string to lower case.
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
32 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
33 * @param string to be converted
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
34 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
35 * @return converted string
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
36 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
37 * @note Only characters from A to Z will be converted and this is an in-place conversion.
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
38 */
33052
956c67bb5198 Move strlower() into auxiliary string function file.
ib
parents: 33051
diff changeset
39 char *strlower(char *in)
956c67bb5198 Move strlower() into auxiliary string function file.
ib
parents: 33051
diff changeset
40 {
956c67bb5198 Move strlower() into auxiliary string function file.
ib
parents: 33051
diff changeset
41 char *p = in;
956c67bb5198 Move strlower() into auxiliary string function file.
ib
parents: 33051
diff changeset
42
956c67bb5198 Move strlower() into auxiliary string function file.
ib
parents: 33051
diff changeset
43 while (*p) {
956c67bb5198 Move strlower() into auxiliary string function file.
ib
parents: 33051
diff changeset
44 if (*p >= 'A' && *p <= 'Z')
36986
575e1612c53a Simplify the expression.
ib
parents: 36984
diff changeset
45 *p += 0x20;
33052
956c67bb5198 Move strlower() into auxiliary string function file.
ib
parents: 33051
diff changeset
46
956c67bb5198 Move strlower() into auxiliary string function file.
ib
parents: 33051
diff changeset
47 p++;
956c67bb5198 Move strlower() into auxiliary string function file.
ib
parents: 33051
diff changeset
48 }
956c67bb5198 Move strlower() into auxiliary string function file.
ib
parents: 33051
diff changeset
49
956c67bb5198 Move strlower() into auxiliary string function file.
ib
parents: 33051
diff changeset
50 return in;
956c67bb5198 Move strlower() into auxiliary string function file.
ib
parents: 33051
diff changeset
51 }
956c67bb5198 Move strlower() into auxiliary string function file.
ib
parents: 33051
diff changeset
52
33982
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
53 /**
36987
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
54 * @brief Convert a string to upper case.
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
55 *
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
56 * @param string to be converted
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
57 *
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
58 * @return converted string
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
59 *
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
60 * @note Only characters from a to z will be converted and this is an in-place conversion.
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
61 */
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
62 char *strupper(char *in)
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
63 {
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
64 char *p = in;
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
65
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
66 while (*p) {
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
67 if (*p >= 'a' && *p <= 'z')
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
68 *p -= 0x20;
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
69
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
70 p++;
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
71 }
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
72
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
73 return in;
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
74 }
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
75
b33ff300128e Add new string function strupper().
ib
parents: 36986
diff changeset
76 /**
33982
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
77 * @brief Swap characters in a string.
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
78 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
79 * @param in string to be processed
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
80 * @param from character to be swapped
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
81 * @param to character to swap in
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
82 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
83 * @return processed string
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
84 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
85 * @note All occurrences will be swapped and this is an in-place processing.
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
86 */
33048
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
87 char *strswap(char *in, char from, char to)
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
88 {
33049
fc7a3f9f74f8 Simplify strswap().
ib
parents: 33048
diff changeset
89 char *p = in;
33048
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
90
33049
fc7a3f9f74f8 Simplify strswap().
ib
parents: 33048
diff changeset
91 while (*p) {
fc7a3f9f74f8 Simplify strswap().
ib
parents: 33048
diff changeset
92 if (*p == from)
fc7a3f9f74f8 Simplify strswap().
ib
parents: 33048
diff changeset
93 *p = to;
33048
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
94
33049
fc7a3f9f74f8 Simplify strswap().
ib
parents: 33048
diff changeset
95 p++;
fc7a3f9f74f8 Simplify strswap().
ib
parents: 33048
diff changeset
96 }
33048
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
97
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
98 return in;
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
99 }
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
100
33982
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
101 /**
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
102 * @brief Remove all space characters from a string,
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
103 * but leave text enclosed in quotation marks untouched.
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
104 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
105 * @param in string to be processed
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
106 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
107 * @return processed string
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
108 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
109 * @note This is an in-place processing.
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
110 */
33048
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
111 char *trim(char *in)
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
112 {
33051
cec61c9f27f4 Simplify trim().
ib
parents: 33049
diff changeset
113 char *src, *dest;
35493
411875efca3f Introduce boolean symbolic constants.
ib
parents: 35482
diff changeset
114 int freeze = False;
33048
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
115
33051
cec61c9f27f4 Simplify trim().
ib
parents: 33049
diff changeset
116 src = dest = in;
33048
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
117
33051
cec61c9f27f4 Simplify trim().
ib
parents: 33049
diff changeset
118 while (*src) {
cec61c9f27f4 Simplify trim().
ib
parents: 33049
diff changeset
119 if (*src == '"')
cec61c9f27f4 Simplify trim().
ib
parents: 33049
diff changeset
120 freeze = !freeze;
33048
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
121
33051
cec61c9f27f4 Simplify trim().
ib
parents: 33049
diff changeset
122 if (freeze || (*src != ' '))
cec61c9f27f4 Simplify trim().
ib
parents: 33049
diff changeset
123 *dest++ = *src;
cec61c9f27f4 Simplify trim().
ib
parents: 33049
diff changeset
124
cec61c9f27f4 Simplify trim().
ib
parents: 33049
diff changeset
125 src++;
33048
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
126 }
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
127
33051
cec61c9f27f4 Simplify trim().
ib
parents: 33049
diff changeset
128 *dest = 0;
cec61c9f27f4 Simplify trim().
ib
parents: 33049
diff changeset
129
33048
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
130 return in;
c6d0adf896ea Move auxiliary string functions into separate file.
ib
parents:
diff changeset
131 }
33073
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
132
33982
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
133 /**
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
134 * @brief Remove a comment from a string,
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
135 * but leave text enclosed in quotation marks untouched.
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
136 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
137 * A comment starts either with a semicolon anywhere in the string
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
138 * or with a number sign character at the very beginning.
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
139 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
140 * @param in string to be processed
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
141 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
142 * @return string without comment
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
143 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
144 * @note This is an in-place processing, i.e. @a in will be shortened.
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
145 */
33073
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
146 char *decomment(char *in)
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
147 {
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
148 char *p;
35493
411875efca3f Introduce boolean symbolic constants.
ib
parents: 35482
diff changeset
149 int nap = False;
33073
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
150
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
151 p = in;
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
152
33080
60b2e408bd78 Allow number sign as comment character.
ib
parents: 33073
diff changeset
153 if (*p == '#')
60b2e408bd78 Allow number sign as comment character.
ib
parents: 33073
diff changeset
154 *p = 0;
60b2e408bd78 Allow number sign as comment character.
ib
parents: 33073
diff changeset
155
33073
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
156 while (*p) {
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
157 if (*p == '"')
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
158 nap = !nap;
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
159
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
160 if ((*p == ';') && !nap) {
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
161 *p = 0;
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
162 break;
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
163 }
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
164
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
165 p++;
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
166 }
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
167
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
168 return in;
334e19411421 Improve handling of the comment character.
ib
parents: 33052
diff changeset
169 }
33737
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
170
35479
ab09ed2d181b Add doxygen comments to string.c.
ib
parents: 35475
diff changeset
171 /**
36989
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
172 * @brief Extract a part of a string delimited by a separator character.
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
173 *
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
174 * @param in string to be analyzed
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
175 * @param out pointer suitable to store the extracted part
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
176 * @param sep separator character
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
177 * @param num number of separator characters to be skipped before extraction starts
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
178 * @param maxout maximum length of extracted part (including the trailing null byte)
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
179 */
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
180 void cutItemString(char *in, char *out, char sep, int num, size_t maxout)
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
181 {
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
182 int n;
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
183 unsigned int i, c;
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
184
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
185 for (c = 0, n = 0, i = 0; in[i]; i++) {
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
186 if (in[i] == sep)
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
187 n++;
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
188 if (n >= num && in[i] != sep && c + 1 < maxout)
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
189 out[c++] = in[i];
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
190 if (n >= num && in[i + 1] == sep)
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
191 break;
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
192 }
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
193
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
194 if (c < maxout)
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
195 out[c] = 0;
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
196 }
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
197
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
198 /**
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
199 * @brief Extract a numeric part of a string delimited by a separator character.
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
200 *
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
201 * @param in string to be analyzed
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
202 * @param sep separator character
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
203 * @param num number of separator characters to be skipped before extraction starts
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
204 *
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
205 * @return extracted number (numeric part)
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
206 */
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
207 int cutItemToInt(char *in, char sep, int num)
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
208 {
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
209 char tmp[64];
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
210
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
211 cutItem(in, tmp, sep, num);
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
212
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
213 return atoi(tmp);
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
214 }
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
215
0b80003f6542 Relocate the cut functions.
ib
parents: 36987
diff changeset
216 /**
35479
ab09ed2d181b Add doxygen comments to string.c.
ib
parents: 35475
diff changeset
217 * @brief A strchr() that can handle NULL pointers.
ab09ed2d181b Add doxygen comments to string.c.
ib
parents: 35475
diff changeset
218 *
ab09ed2d181b Add doxygen comments to string.c.
ib
parents: 35475
diff changeset
219 * @param str string to examine
ab09ed2d181b Add doxygen comments to string.c.
ib
parents: 35475
diff changeset
220 * @param c character to find
ab09ed2d181b Add doxygen comments to string.c.
ib
parents: 35475
diff changeset
221 *
ab09ed2d181b Add doxygen comments to string.c.
ib
parents: 35475
diff changeset
222 * @return return value of strchr() or NULL, if @a str is NULL
ab09ed2d181b Add doxygen comments to string.c.
ib
parents: 35475
diff changeset
223 */
33737
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
224 char *gstrchr(const char *str, int c)
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
225 {
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
226 if (!str)
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
227 return NULL;
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
228
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
229 return strchr(str, c);
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
230 }
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
231
35459
1edb306bc754 Add doxygen comment.
ib
parents: 34685
diff changeset
232 /**
1edb306bc754 Add doxygen comment.
ib
parents: 34685
diff changeset
233 * @brief A strcmp() that can handle NULL pointers.
1edb306bc754 Add doxygen comment.
ib
parents: 34685
diff changeset
234 *
1edb306bc754 Add doxygen comment.
ib
parents: 34685
diff changeset
235 * @param a string to be compared
1edb306bc754 Add doxygen comment.
ib
parents: 34685
diff changeset
236 * @param b string which is compared
1edb306bc754 Add doxygen comment.
ib
parents: 34685
diff changeset
237 *
35479
ab09ed2d181b Add doxygen comments to string.c.
ib
parents: 35475
diff changeset
238 * @return return value of strcmp() or -1, if @a a or @a b are NULL
35459
1edb306bc754 Add doxygen comment.
ib
parents: 34685
diff changeset
239 */
33737
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
240 int gstrcmp(const char *a, const char *b)
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
241 {
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
242 if (!a && !b)
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
243 return 0;
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
244 if (!a || !b)
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
245 return -1;
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
246
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
247 return strcmp(a, b);
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
248 }
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
249
34628
ee78c9c66508 Add doxgen comment to gstrncmp().
ib
parents: 34560
diff changeset
250 /**
ee78c9c66508 Add doxgen comment to gstrncmp().
ib
parents: 34560
diff changeset
251 * @brief A strncmp() that can handle NULL pointers.
ee78c9c66508 Add doxgen comment to gstrncmp().
ib
parents: 34560
diff changeset
252 *
ee78c9c66508 Add doxgen comment to gstrncmp().
ib
parents: 34560
diff changeset
253 * @param a string to be compared
ee78c9c66508 Add doxgen comment to gstrncmp().
ib
parents: 34560
diff changeset
254 * @param b string which is compared
ee78c9c66508 Add doxgen comment to gstrncmp().
ib
parents: 34560
diff changeset
255 * @param n number of characters compared at the most
ee78c9c66508 Add doxgen comment to gstrncmp().
ib
parents: 34560
diff changeset
256 *
35479
ab09ed2d181b Add doxygen comments to string.c.
ib
parents: 35475
diff changeset
257 * @return return value of strncmp() or -1, if @a a or @a b are NULL
34628
ee78c9c66508 Add doxgen comment to gstrncmp().
ib
parents: 34560
diff changeset
258 */
ee78c9c66508 Add doxgen comment to gstrncmp().
ib
parents: 34560
diff changeset
259 int gstrncmp(const char *a, const char *b, size_t n)
33737
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
260 {
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
261 if (!a && !b)
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
262 return 0;
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
263 if (!a || !b)
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
264 return -1;
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
265
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
266 return strncmp(a, b, n);
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
267 }
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
268
33982
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
269 /**
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
270 * @brief Duplicate a string.
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
271 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
272 * If @a str is NULL, it returns NULL.
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
273 * The string is duplicated by calling strdup().
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
274 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
275 * @param str string to be duplicated
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
276 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
277 * @return duplicated string (newly allocated)
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
278 */
33737
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
279 char *gstrdup(const char *str)
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
280 {
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
281 if (!str)
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
282 return NULL;
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
283
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
284 return strdup(str);
71c29e8ec68f Move string functions from interface.c to string.c.
ib
parents: 33080
diff changeset
285 }
33740
2c02269701bd Remove macros guiSetFilename() and guiSetDF() from interface.h.
ib
parents: 33737
diff changeset
286
33982
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
287 /**
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
288 * @brief Assign a duplicated string.
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
289 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
290 * The string is duplicated by calling #gstrdup().
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
291 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
292 * @param old pointer to a variable suitable to store the new pointer
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
293 * @param str string to be duplicated
35475
49f29de2ff10 Cosmetic: Place doxygen note at the end of the comment.
ib
parents: 35459
diff changeset
294 *
49f29de2ff10 Cosmetic: Place doxygen note at the end of the comment.
ib
parents: 35459
diff changeset
295 * @note @a *old is freed prior to the assignment.
33982
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
296 */
33740
2c02269701bd Remove macros guiSetFilename() and guiSetDF() from interface.h.
ib
parents: 33737
diff changeset
297 void setdup(char **old, const char *str)
2c02269701bd Remove macros guiSetFilename() and guiSetDF() from interface.h.
ib
parents: 33737
diff changeset
298 {
2c02269701bd Remove macros guiSetFilename() and guiSetDF() from interface.h.
ib
parents: 33737
diff changeset
299 free(*old);
2c02269701bd Remove macros guiSetFilename() and guiSetDF() from interface.h.
ib
parents: 33737
diff changeset
300 *old = gstrdup(str);
2c02269701bd Remove macros guiSetFilename() and guiSetDF() from interface.h.
ib
parents: 33737
diff changeset
301 }
2c02269701bd Remove macros guiSetFilename() and guiSetDF() from interface.h.
ib
parents: 33737
diff changeset
302
33982
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
303 /**
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
304 * @brief Assign a newly allocated string
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
305 * containing the path created from a directory and a filename.
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
306 *
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
307 * @param old pointer to a variable suitable to store the new pointer
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
308 * @param dir directory
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
309 * @param name filename
35475
49f29de2ff10 Cosmetic: Place doxygen note at the end of the comment.
ib
parents: 35459
diff changeset
310 *
49f29de2ff10 Cosmetic: Place doxygen note at the end of the comment.
ib
parents: 35459
diff changeset
311 * @note @a *old is freed prior to the assignment.
33982
d7527ee45784 Add doxygen comments to string.c.
ib
parents: 33786
diff changeset
312 */
33740
2c02269701bd Remove macros guiSetFilename() and guiSetDF() from interface.h.
ib
parents: 33737
diff changeset
313 void setddup(char **old, const char *dir, const char *name)
2c02269701bd Remove macros guiSetFilename() and guiSetDF() from interface.h.
ib
parents: 33737
diff changeset
314 {
2c02269701bd Remove macros guiSetFilename() and guiSetDF() from interface.h.
ib
parents: 33737
diff changeset
315 free(*old);
2c02269701bd Remove macros guiSetFilename() and guiSetDF() from interface.h.
ib
parents: 33737
diff changeset
316 *old = malloc(strlen(dir) + strlen(name) + 2);
2c02269701bd Remove macros guiSetFilename() and guiSetDF() from interface.h.
ib
parents: 33737
diff changeset
317 if (*old)
2c02269701bd Remove macros guiSetFilename() and guiSetDF() from interface.h.
ib
parents: 33737
diff changeset
318 sprintf(*old, "%s/%s", dir, name);
2c02269701bd Remove macros guiSetFilename() and guiSetDF() from interface.h.
ib
parents: 33737
diff changeset
319 }
34175
a345e7162d0a Move TranslateFilename() to util/string.c.
ib
parents: 33982
diff changeset
320
34176
d52b0ad317d5 Cosmetic: Rename TranslateFilename()'s parameter names.
ib
parents: 34175
diff changeset
321 /**
34560
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
322 * @brief Read characters from @a file.
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
323 *
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
324 * @param str pointer to a buffer to receive the read characters
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
325 * @param size number of characters read at the most (including a terminating null-character)
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
326 * @param file file to read from
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
327 *
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
328 * @return str (success) or NULL (error)
35475
49f29de2ff10 Cosmetic: Place doxygen note at the end of the comment.
ib
parents: 35459
diff changeset
329 *
49f29de2ff10 Cosmetic: Place doxygen note at the end of the comment.
ib
parents: 35459
diff changeset
330 * @note Reading stops with an end-of-line character or at end of file.
34560
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
331 */
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
332 char *fgetstr(char *str, int size, FILE *file)
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
333 {
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
334 char *s;
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
335
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
336 s = fgets(str, size, file);
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
337
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
338 if (s)
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
339 s[strcspn(s, "\n\r")] = 0;
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
340
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
341 return s;
abcf26dcec6b Add fgetstr() to read from files without end-of-line characters.
ib
parents: 34454
diff changeset
342 }