ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/radiance/ray/src/common/wordfile.c
Revision: 2.22
Committed: Fri May 13 09:12:19 2016 UTC (8 years ago) by schorsch
Content type: text/plain
Branch: MAIN
Changes since 2.21: +4 -3 lines
Log Message:
no bug in windows read()

File Contents

# Content
1 #ifndef lint
2 static const char RCSid[] = "$Id: wordfile.c,v 2.21 2016/05/12 16:30:39 greg Exp $";
3 #endif
4 /*
5 * Load whitespace separated words from a file into an array.
6 *
7 * External symbols declared in rtio.h
8 */
9
10 #include "copyright.h"
11
12 #include <ctype.h>
13 #include <string.h>
14
15 #include "platform.h"
16 #include "rtio.h"
17 #include "rtmisc.h"
18
19
20 #define MAXWLEN 4096 /* words must be shorter than this */
21
22
23 int
24 wordfile( /* get words from fname, put in words */
25 char **words,
26 int nargs,
27 char *fname
28 )
29 {
30 int wrdcnt = 0;
31 int n = 0;
32 int dlen = 0;
33 int fd;
34 char buf[MAXWLEN];
35 /* load file into buffer */
36 if (fname == NULL || !*fname)
37 return(-1); /* no filename */
38 if (nargs <= 1)
39 return(-1);
40 if ((fd = open(fname, 0)) < 0)
41 return(-1); /* open error */
42 words[0] = NULL;
43 while (nargs > 1 && (n += read(fd, buf+n, MAXWLEN-n)) > 0) {
44 dlen = n;
45 int crem = 0;
46 if (n > MAXWLEN/2) /* check for mid-word end */
47 while (!isspace(buf[--n])) {
48 if (n <= 0) /* one long word! */
49 goto done;
50 ++crem;
51 }
52 buf[n] = '\0'; /* terminate & parse */
53 n = wordstring(words, nargs, buf);
54 if (n < 0) {
55 wrdcnt = -1; /* memory error */
56 break;
57 }
58 words += n; nargs -= n;
59 wrdcnt += n;
60 if ((n = crem) > 0) /* move remainder */
61 memmove(buf, buf+dlen-crem, crem);
62 }
63 done:
64 close(fd);
65 return(wrdcnt);
66 }
67
68
69 int
70 wordstring( /* allocate and load argument list */
71 char **avl,
72 int nargs,
73 char *str
74 )
75 {
76 char *cp, **ap;
77
78 if (str == NULL)
79 return(-1);
80 cp = bmalloc(strlen(str)+1);
81 if (cp == NULL) /* ENOMEM */
82 return(-1);
83 strcpy(cp, str);
84 /* parse into words */
85 for (ap = avl; ap-avl < nargs-1; ap++) {
86 while (isspace(*cp)) /* nullify spaces */
87 *cp++ = '\0';
88 if (!*cp) /* all done? */
89 break;
90 *ap = cp; /* add argument to list */
91 while (*++cp && !isspace(*cp))
92 ;
93 }
94 *cp = '\0'; /* terminates overflow */
95 *ap = NULL;
96 return(ap - avl);
97 }