Line | Source | Count |
1 | | - |
2 | | - |
3 | | - |
4 | | - |
5 | | - |
6 | | - |
7 | | - |
8 | | - |
9 | | - |
10 | | - |
11 | | - |
12 | | - |
13 | | - |
14 | | - |
15 | | - |
16 | | - |
17 | | - |
18 | | - |
19 | | - |
20 | | - |
21 | #include "config.h" | - |
22 | | - |
23 | #include "bashtypes.h" | - |
24 | | - |
25 | #if defined (HAVE_UNISTD_H) | - |
26 | # include <unistd.h> | - |
27 | #endif | - |
28 | | - |
29 | #include "bashansi.h" | - |
30 | #include <stdio.h> | - |
31 | #include "chartypes.h" | - |
32 | | - |
33 | #include "shell.h" | - |
34 | #include "pathexp.h" | - |
35 | | - |
36 | #include <glob/glob.h> | - |
37 | | - |
38 | #if defined (EXTENDED_GLOB) | - |
39 | # include <glob/strmatch.h> | - |
40 | #endif | - |
41 | | - |
42 | | - |
43 | | - |
44 | | - |
45 | | - |
46 | | - |
47 | | - |
48 | | - |
49 | | - |
50 | int | - |
51 | find_string_in_alist (string, alist, flags) | - |
52 | char *string; | - |
53 | STRING_INT_ALIST *alist; | - |
54 | int flags; | - |
55 | { | - |
56 | register int i; | - |
57 | int r; | - |
58 | | - |
59 | for (i = r = 0; alist[i].word; i++)TRUE | evaluated 1332030 times by 1 test | FALSE | evaluated 666015 times by 1 test |
| 666015-1332030 |
60 | { | - |
61 | #if defined (EXTENDED_GLOB) | - |
62 | if (flags)TRUE | evaluated 1332030 times by 1 test | FALSE | never evaluated |
| 0-1332030 |
63 | r = strmatch (alist[i].word, string, FNM_EXTMATCH) != FNM_NOMATCH;executed 1332030 times by 1 test: r = strmatch (alist[i].word, string, (1 << 5)) != 1; | 1332030 |
64 | else | - |
65 | #endif | - |
66 | r = STREQ (string, alist[i].word); never executed: r = ((string)[0] == (alist[i].word)[0] && __extension__ ({ size_t __s1_len, __s2_len; (__builtin_constant_p ( string ) && __builtin_constant_p ( alist[i].word ) && (__s1_len = __builtin_strlen ( string ), __s2_len = __builtin_strlen ( alist[i].word ), (!(...har *) (const char *) ( alist[i].word ))[2] - __s2[2]); if (__s2_len > 2 && __result == 0) __result = (((const unsigned char *) (const char *) ( alist[i].word ))[3] - __s2[3]); } } __result; }))) : __builtin_strcmp ( string , alist[i].word )))); }) == 0); never executed: __result = (((const unsigned char *) (const char *) ( string ))[3] - __s2[3]); never executed: end of block never executed: end of block never executed: __result = (((const unsigned char *) (const char *) ( alist[i].word ))[3] - __s2[3]); never executed: end of block never executed: end of block TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
67 | | - |
68 | if (r)TRUE | never evaluated | FALSE | evaluated 1332030 times by 1 test |
| 0-1332030 |
69 | return (alist[i].token); never executed: return (alist[i].token); | 0 |
70 | }executed 1332030 times by 1 test: end of block | 1332030 |
71 | return -1;executed 666015 times by 1 test: return -1; | 666015 |
72 | } | - |
73 | | - |
74 | | - |
75 | | - |
76 | | - |
77 | char * | - |
78 | find_token_in_alist (token, alist, flags) | - |
79 | int token; | - |
80 | STRING_INT_ALIST *alist; | - |
81 | int flags; | - |
82 | { | - |
83 | register int i; | - |
84 | | - |
85 | for (i = 0; alist[i].word; i++)TRUE | evaluated 1689 times by 1 test | FALSE | evaluated 40 times by 1 test |
| 40-1689 |
86 | { | - |
87 | if (alist[i].token == token)TRUE | evaluated 30 times by 1 test | FALSE | evaluated 1659 times by 1 test |
| 30-1659 |
88 | return (savestring (alist[i].word));executed 30 times by 1 test: return ((char *)strcpy (sh_xmalloc((1 + strlen (alist[i].word)), "stringlib.c", 88), (alist[i].word))); | 30 |
89 | }executed 1659 times by 1 test: end of block | 1659 |
90 | return ((char *)NULL);executed 40 times by 1 test: return ((char *) ((void *)0) ); | 40 |
91 | } | - |
92 | | - |
93 | int | - |
94 | find_index_in_alist (string, alist, flags) | - |
95 | char *string; | - |
96 | STRING_INT_ALIST *alist; | - |
97 | int flags; | - |
98 | { | - |
99 | register int i; | - |
100 | int r; | - |
101 | | - |
102 | for (i = r = 0; alist[i].word; i++)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
103 | { | - |
104 | #if defined (EXTENDED_GLOB) | - |
105 | if (flags)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
106 | r = strmatch (alist[i].word, string, FNM_EXTMATCH) != FNM_NOMATCH; never executed: r = strmatch (alist[i].word, string, (1 << 5)) != 1; | 0 |
107 | else | - |
108 | #endif | - |
109 | r = STREQ (string, alist[i].word); never executed: r = ((string)[0] == (alist[i].word)[0] && __extension__ ({ size_t __s1_len, __s2_len; (__builtin_constant_p ( string ) && __builtin_constant_p ( alist[i].word ) && (__s1_len = __builtin_strlen ( string ), __s2_len = __builtin_strlen ( alist[i].word ), (!(...har *) (const char *) ( alist[i].word ))[2] - __s2[2]); if (__s2_len > 2 && __result == 0) __result = (((const unsigned char *) (const char *) ( alist[i].word ))[3] - __s2[3]); } } __result; }))) : __builtin_strcmp ( string , alist[i].word )))); }) == 0); never executed: __result = (((const unsigned char *) (const char *) ( string ))[3] - __s2[3]); never executed: end of block never executed: end of block never executed: __result = (((const unsigned char *) (const char *) ( alist[i].word ))[3] - __s2[3]); never executed: end of block never executed: end of block TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
110 | | - |
111 | if (r)TRUE | never evaluated | FALSE | never evaluated |
| 0 |
112 | return (i); never executed: return (i); | 0 |
113 | } never executed: end of block | 0 |
114 | | - |
115 | return -1; never executed: return -1; | 0 |
116 | } | - |
117 | | - |
118 | | - |
119 | | - |
120 | | - |
121 | | - |
122 | | - |
123 | | - |
124 | | - |
125 | | - |
126 | char * | - |
127 | substring (string, start, end) | - |
128 | const char *string; | - |
129 | int start, end; | - |
130 | { | - |
131 | register int len; | - |
132 | register char *result; | - |
133 | | - |
134 | len = end - start; | - |
135 | result = (char *)xmalloc (len + 1); | - |
136 | memcpy (result, string + start, len); | - |
137 | result[len] = '\0'; | - |
138 | return (result);executed 121777313 times by 1 test: return (result); | 121777313 |
139 | } | - |
140 | | - |
141 | | - |
142 | | - |
143 | | - |
144 | char * | - |
145 | strsub (string, pat, rep, global) | - |
146 | char *string, *pat, *rep; | - |
147 | int global; | - |
148 | { | - |
149 | int patlen, replen, templen, tempsize, repl, i; | - |
150 | char *temp, *r; | - |
151 | | - |
152 | patlen = strlen (pat); | - |
153 | replen = strlen (rep); | - |
154 | for (temp = (char *)NULL, i = templen = tempsize = 0, repl = 1; string[i]; )TRUE | evaluated 39 times by 1 test | FALSE | evaluated 3 times by 1 test |
| 3-39 |
155 | { | - |
156 | if (repl && STREQN (string + i, pat, patlen)) never executed: __result = (((const unsigned char *) (const char *) ( string + i ))[3] - __s2[3]); never executed: end of block never executed: end of block never executed: __result = (((const unsigned char *) (const char *) ( pat ))[3] - __s2[3]); never executed: end of block never executed: end of block TRUE | never evaluated | FALSE | evaluated 39 times by 1 test |
TRUE | evaluated 39 times by 1 test | FALSE | never evaluated |
TRUE | evaluated 9 times by 1 test | FALSE | evaluated 30 times by 1 test |
TRUE | evaluated 9 times by 1 test | FALSE | evaluated 30 times by 1 test |
TRUE | evaluated 9 times by 1 test | FALSE | never evaluated |
TRUE | never evaluated | FALSE | evaluated 9 times by 1 test |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0-39 |
157 | { | - |
158 | if (replen)TRUE | evaluated 9 times by 1 test | FALSE | never evaluated |
| 0-9 |
159 | RESIZE_MALLOCED_BUFFER (temp, templen, replen, tempsize, (replen * 2)); never executed: tempsize += ((replen * 2)); never executed: end of block executed 9 times by 1 test: end of block TRUE | never evaluated | FALSE | evaluated 9 times by 1 test |
TRUE | never evaluated | FALSE | never evaluated |
| 0-9 |
160 | | - |
161 | for (r = rep; *r; ) TRUE | evaluated 9 times by 1 test | FALSE | evaluated 9 times by 1 test |
| 9 |
162 | temp[templen++] = *r++;executed 9 times by 1 test: temp[templen++] = *r++; | 9 |
163 | | - |
164 | i += patlen ? patlen : 1; TRUE | evaluated 9 times by 1 test | FALSE | never evaluated |
| 0-9 |
165 | repl = global != 0; | - |
166 | }executed 9 times by 1 test: end of block | 9 |
167 | else | - |
168 | { | - |
169 | RESIZE_MALLOCED_BUFFER (temp, templen, 1, tempsize, 16);executed 3 times by 1 test: tempsize += (16); executed 3 times by 1 test: end of block TRUE | evaluated 3 times by 1 test | FALSE | evaluated 27 times by 1 test |
TRUE | evaluated 3 times by 1 test | FALSE | evaluated 3 times by 1 test |
| 3-27 |
170 | temp[templen++] = string[i++]; | - |
171 | }executed 30 times by 1 test: end of block | 30 |
172 | } | - |
173 | if (temp)TRUE | evaluated 3 times by 1 test | FALSE | never evaluated |
| 0-3 |
174 | temp[templen] = 0;executed 3 times by 1 test: temp[templen] = 0; | 3 |
175 | else | - |
176 | temp = savestring (string); never executed: temp = (char *)strcpy (sh_xmalloc((1 + strlen (string)), "stringlib.c", 176), (string)); | 0 |
177 | return (temp);executed 3 times by 1 test: return (temp); | 3 |
178 | } | - |
179 | | - |
180 | | - |
181 | | - |
182 | | - |
183 | char * | - |
184 | strcreplace (string, c, text, do_glob) | - |
185 | char *string; | - |
186 | int c; | - |
187 | const char *text; | - |
188 | int do_glob; | - |
189 | { | - |
190 | char *ret, *p, *r, *t; | - |
191 | int len, rlen, ind, tlen; | - |
192 | | - |
193 | len = STRLEN (text);TRUE | evaluated 136 times by 1 test | FALSE | never evaluated |
TRUE | evaluated 136 times by 1 test | FALSE | never evaluated |
TRUE | evaluated 136 times by 1 test | FALSE | never evaluated |
TRUE | evaluated 136 times by 1 test | FALSE | never evaluated |
| 0-136 |
194 | rlen = len + strlen (string) + 2; | - |
195 | ret = (char *)xmalloc (rlen); | - |
196 | | - |
197 | for (p = string, r = ret; p && *p; )TRUE | evaluated 272 times by 1 test | FALSE | never evaluated |
TRUE | evaluated 136 times by 1 test | FALSE | evaluated 136 times by 1 test |
| 0-272 |
198 | { | - |
199 | if (*p == c)TRUE | evaluated 136 times by 1 test | FALSE | never evaluated |
| 0-136 |
200 | { | - |
201 | if (len)TRUE | evaluated 136 times by 1 test | FALSE | never evaluated |
| 0-136 |
202 | { | - |
203 | ind = r - ret; | - |
204 | if (do_glob && (glob_pattern_p (text) || strchr (text, '\\')))TRUE | evaluated 136 times by 1 test | FALSE | never evaluated |
TRUE | evaluated 1 time by 1 test | FALSE | evaluated 135 times by 1 test |
TRUE | evaluated 4 times by 1 test | FALSE | evaluated 131 times by 1 test |
TRUE | evaluated 135 times by 1 test | FALSE | never evaluated |
TRUE | evaluated 135 times by 1 test | FALSE | never evaluated |
TRUE | never evaluated | FALSE | evaluated 135 times by 1 test |
| 0-136 |
205 | { | - |
206 | t = quote_globbing_chars (text); | - |
207 | tlen = strlen (t); | - |
208 | RESIZE_MALLOCED_BUFFER (ret, ind, tlen, rlen, rlen); never executed: rlen += (rlen); never executed: end of block TRUE | never evaluated | FALSE | evaluated 5 times by 1 test |
TRUE | never evaluated | FALSE | never evaluated |
| 0-5 |
209 | r = ret + ind; | - |
210 | strcpy (r, t); | - |
211 | r += tlen; | - |
212 | free (t); | - |
213 | }executed 5 times by 1 test: end of block | 5 |
214 | else | - |
215 | { | - |
216 | RESIZE_MALLOCED_BUFFER (ret, ind, len, rlen, rlen); never executed: rlen += (rlen); never executed: end of block TRUE | never evaluated | FALSE | evaluated 131 times by 1 test |
TRUE | never evaluated | FALSE | never evaluated |
| 0-131 |
217 | r = ret + ind; | - |
218 | strcpy (r, text); | - |
219 | r += len; | - |
220 | }executed 131 times by 1 test: end of block | 131 |
221 | } | - |
222 | p++; | - |
223 | continue;executed 136 times by 1 test: continue; | 136 |
224 | } | - |
225 | | - |
226 | if (*p == '\\' && p[1] == c)TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
227 | p++; never executed: p++; | 0 |
228 | | - |
229 | ind = r - ret; | - |
230 | RESIZE_MALLOCED_BUFFER (ret, ind, 2, rlen, rlen); never executed: rlen += (rlen); never executed: end of block TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0 |
231 | r = ret + ind; | - |
232 | *r++ = *p++; | - |
233 | } never executed: end of block | 0 |
234 | *r = '\0'; | - |
235 | | - |
236 | return ret;executed 136 times by 1 test: return ret; | 136 |
237 | } | - |
238 | | - |
239 | #ifdef INCLUDE_UNUSED | - |
240 | | - |
241 | | - |
242 | void | - |
243 | strip_leading (string) | - |
244 | char *string; | - |
245 | { | - |
246 | char *start = string; | - |
247 | | - |
248 | while (*string && (whitespace (*string) || *string == '\n')) | - |
249 | string++; | - |
250 | | - |
251 | if (string != start) | - |
252 | { | - |
253 | int len = strlen (string); | - |
254 | FASTCOPY (string, start, len); | - |
255 | start[len] = '\0'; | - |
256 | } | - |
257 | } | - |
258 | #endif | - |
259 | | - |
260 | | - |
261 | | - |
262 | | - |
263 | void | - |
264 | strip_trailing (string, len, newlines_only) | - |
265 | char *string; | - |
266 | int len; | - |
267 | int newlines_only; | - |
268 | { | - |
269 | while (len >= 0)TRUE | evaluated 6505045 times by 1 test | FALSE | evaluated 67 times by 1 test |
| 67-6505045 |
270 | { | - |
271 | if ((newlines_only && string[len] == '\n') ||TRUE | evaluated 6505045 times by 1 test | FALSE | never evaluated |
TRUE | evaluated 3252361 times by 1 test | FALSE | evaluated 3252684 times by 1 test |
| 0-6505045 |
272 | (!newlines_only && whitespace (string[len])))TRUE | never evaluated | FALSE | evaluated 3252684 times by 1 test |
TRUE | never evaluated | FALSE | never evaluated |
TRUE | never evaluated | FALSE | never evaluated |
| 0-3252684 |
273 | len--;executed 3252361 times by 1 test: len--; | 3252361 |
274 | else | - |
275 | break;executed 3252684 times by 1 test: break; | 3252684 |
276 | } | - |
277 | string[len + 1] = '\0'; | - |
278 | }executed 3252751 times by 1 test: end of block | 3252751 |
279 | | - |
280 | | - |
281 | void | - |
282 | xbcopy (s, d, n) | - |
283 | char *s, *d; | - |
284 | int n; | - |
285 | { | - |
286 | FASTCOPY (s, d, n); | - |
287 | }executed 745028 times by 1 test: end of block | 745028 |
| | |