annotate pkg-src/tree-x/input.c @ 185:3d6bfa290dbd r20-3b19

Import from CVS: tag r20-3b19
author cvs
date Mon, 13 Aug 2007 09:55:28 +0200
parents 8eaf7971accc
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
1 /* ----------------------------------------------------------------------------
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
2 * File : input.c
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
3 * Purpose : input routine to create a Tree from an input file
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
4 * ----------------------------------------------------------------------------
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
5 */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
6
173
8eaf7971accc Import from CVS: tag r20-3b13
cvs
parents: 169
diff changeset
7 /* SunOS 5.4+ way to ask for all functions in header files. */
8eaf7971accc Import from CVS: tag r20-3b13
cvs
parents: 169
diff changeset
8 #define __EXTENSIONS__ 1
8eaf7971accc Import from CVS: tag r20-3b13
cvs
parents: 169
diff changeset
9
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
10 #include <ctype.h>
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
11 #include <string.h>
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
12 #include <stdlib.h>
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
13 #include "defs.h"
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
14 #include "tree.h"
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
15 #include "input.h"
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
16 #include "dbl.h"
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
17 #include "intf.h"
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
18
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
19 char *EnvNm; /* Stores name of current Envir file */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
20 static int tokDepth = 0; /* Depth in tree of current token */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
21 static int prevTokDepth; /* Depth in tree of prev token */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
22
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
23 static void SaveSubtree(Tree *tree, int level, FILE *fp);
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
24
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
25 /* ----------------------------------------------------------------------------
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
26 *
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
27 * GetNextToken() reads the next token from the file indicated by 'fp' and
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
28 * returns a token. If the token is TOKEN_LABEL, the lexeme is returned
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
29 * in 'lexeme'. If memory could not be allocated for 'lexeme', it is NULL.
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
30 *
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
31 * The following tokens are supported:
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
32 *
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
33 * - TOKEN_LABEL: a string of characters, up to 'TOKEN-MAXSIZ'
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
34 * characters, delimited by number of leading spaces and newlines.
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
35 * If a label has more than this number of characters, the rest are
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
36 * ignored.
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
37 * - TOKEN_EOF
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
38 *
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
39 * ----------------------------------------------------------------------------
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
40 */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
41
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
42 static int
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
43 GetNextToken(FILE *fp, char **lexeme)
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
44 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
45 static char lexbuf[INPUT_BUFSIZ];
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
46 register char *curbuf = lexbuf;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
47 register int charct = 0;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
48 register int c;
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
49
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
50 prevTokDepth = tokDepth;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
51 tokDepth = 0;
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
52
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
53 c = getc(fp);
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
54
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
55 /* skip over leading whitespace */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
56 while (c == ' ')
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
57 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
58 tokDepth++;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
59 c = getc(fp);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
60 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
61 tokDepth /= 2;
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
62
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
63 while (1)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
64 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
65 switch (c)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
66 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
67 case EOF:
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
68 return TOKEN_EOF;
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
69 case '\n':
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
70 *curbuf = '\0';
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
71 *lexeme = strdup(lexbuf);
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
72 return TOKEN_LABEL;
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
73 default:
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
74 *curbuf++ = c;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
75 charct++;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
76 /* check for buffer overflow */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
77 if (charct >= TOKEN_MAXSIZ)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
78 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
79 *curbuf = '\0';
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
80 *lexeme = strdup(lexbuf);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
81 /* since buffer is full, skip over remaining chars */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
82 c = getc(fp);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
83 while (c != '\n' && c != EOF)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
84 c = getc(fp);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
85 if (c == EOF)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
86 ungetc(c, fp);
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
87 return TOKEN_LABEL;
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
88 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
89 else
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
90 c = getc(fp);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
91 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
92 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
93 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
94
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
95
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
96 /* ----------------------------------------------------------------------------
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
97 *
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
98 * SetNodeLabelAndValue() sets the label text of the specified node and
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
99 * stores any string value following the label and preceded by a "^^"
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
100 * delimiter.
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
101 *
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
102 * ----------------------------------------------------------------------------
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
103 */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
104
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
105 void
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
106 SetNodeLabelAndValue(Tree *node, char *label_and_value)
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
107 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
108 char* val;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
109
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
110 if ((val = strstr(label_and_value, "^^")))
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
111 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
112 /* Set node value to string following ^^ delimiter. */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
113 node->value = val+2;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
114 /* Erase value from input string, leaving only label. */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
115 *val = '\0';
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
116 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
117 else
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
118 { node->value = NULL; }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
119 SetNodeLabel(node, label_and_value);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
120 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
121
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
122
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
123 /* ----------------------------------------------------------------------------
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
124 *
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
125 * ReadTreeFromFile() takes a filename argument and constructs
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
126 * a Tree from the labels in the file. If a tree could be constructed,
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
127 * even partially, it is returned by the function. NULL is returned if
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
128 * the file could not be opened or there was insufficient memory for
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
129 * creating the tree.
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
130 *
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
131 * ----------------------------------------------------------------------------
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
132 */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
133
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
134 Tree*
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
135 ReadTreeFromFile(char *fname, ErrCode *error)
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
136 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
137 FILE *infile;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
138 int inside_list = 0; /* for semantic checking */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
139 int first_child = TRUE;
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
140
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
141 int token;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
142 char *label;
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
143
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
144 Tree *tree = NULL; /* the return value of this function */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
145 Tree *parent = NULL; /* parent of 'node' */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
146 Tree *node; /* current node */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
147 Tree *new_node; /* new node to add after current node */
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
148
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
149 *error = ERR_NONE;
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
150
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
151 infile = fopen(fname, "r");
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
152 if (infile == NULL)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
153 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
154 *error = ERR_OPENFAIL;
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
155 return NULL;
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
156 }
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
157
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
158 /* first line of file is Envir file name, save */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
159 token = GetNextToken(infile, &label);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
160 if (token == TOKEN_EOF)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
161 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
162 *error = ERR_EMPTYFILE;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
163 fclose(infile);
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
164 return NULL;
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
165 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
166 else if (token == TOKEN_LABEL)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
167 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
168 if (label == NULL)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
169 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
170 *error = ERR_MEMALLOC;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
171 fclose(infile);
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
172 return NULL;
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
173 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
174 EnvNm = strdup(label);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
175 }
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
176
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
177 /* set up root node */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
178 token = GetNextToken(infile, &label);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
179 if (token == TOKEN_EOF)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
180 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
181 *error = ERR_EMPTYFILE;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
182 fclose(infile);
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
183 return NULL;
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
184 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
185 else if (token == TOKEN_LABEL)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
186 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
187 if (label == NULL)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
188 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
189 *error = ERR_MEMALLOC;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
190 fclose(infile);
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
191 return NULL;
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
192 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
193 tree = MakeNode();
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
194 if (tree == NULL)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
195 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
196 *error = ERR_MEMALLOC;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
197 fclose(infile);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
198 free(label);
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
199 return NULL;
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
200 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
201 SetNodeLabelAndValue(tree, label);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
202 tree->parent = NULL;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
203 node = tree;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
204 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
205 else
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
206 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
207 *error = ERR_NOROOT;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
208 fclose(infile);
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
209 return NULL;
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
210 }
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
211
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
212 /* add children and siblings */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
213 while (1)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
214 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
215 token = GetNextToken(infile, &label);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
216 if (token == TOKEN_EOF)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
217 break;
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
218
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
219 if (tokDepth > prevTokDepth) /* then new subtree */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
220 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
221 inside_list++;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
222 first_child = TRUE;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
223 parent = node;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
224 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
225 else if (tokDepth < prevTokDepth) /* then end of subtree */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
226 if (!inside_list)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
227 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
228 *error = ERR_NOBEGIN;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
229 fclose(infile);
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
230 return tree;
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
231 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
232 else
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
233 while (tokDepth < inside_list)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
234 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
235 inside_list--;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
236 node = node->parent;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
237 parent = node->parent;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
238 }
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
239
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
240 if (label == NULL)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
241 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
242 *error = ERR_MEMALLOC;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
243 fclose(infile);
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
244 return tree;
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
245 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
246 if (parent == NULL)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
247 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
248 *error = ERR_MANYROOT;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
249 fclose(infile);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
250 free(label);
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
251 return tree;
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
252 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
253 else
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
254 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
255 new_node = MakeNode();
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
256 if (new_node == NULL)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
257 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
258 *error = ERR_MEMALLOC;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
259 fclose(infile);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
260 free(label);
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
261 return tree;
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
262 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
263 SetNodeLabelAndValue(new_node, label);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
264 new_node->parent = parent;
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
265
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
266 if (first_child)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
267 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
268 new_node->parent->child = new_node;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
269 first_child = FALSE;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
270 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
271 else
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
272 node->sibling = new_node;
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
273
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
274 node = new_node;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
275 /*
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
276 * printf("%3d tok: '%s'; tokDepth: %d; prevTokDepth: %d; inside_list: %d\n",
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
277 * NumNodes, node->label.text, tokDepth, prevTokDepth, inside_list);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
278 */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
279 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
280 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
281 fclose(infile);
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
282 return tree;
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
283 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
284
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
285
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
286 /* ----------------------------------------------------------------------------
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
287 *
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
288 * SaveTreeToFile() takes a tree and saves it to a file specified by 'fname.'
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
289 * If the file could not be opened for writing, False is returned. Otherwise,
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
290 * True is returned.
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
291 *
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
292 * ----------------------------------------------------------------------------
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
293 */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
294
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
295 int
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
296 SaveTreeToFile(Tree *tree, char *fname)
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
297 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
298 FILE *outfile;
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
299
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
300 outfile = fopen(fname, "w");
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
301 if (outfile == NULL)
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
302 return FALSE;
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
303
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
304 fprintf(outfile, "%s\n", EnvNm); /* Save Env File Name */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
305 fprintf(outfile, "%s\n", tree->label.text);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
306 if (tree->child)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
307 SaveSubtree(tree->child, 0, outfile);
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
308
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
309 fclose(outfile);
169
15872534500d Import from CVS: tag r20-3b11
cvs
parents: 167
diff changeset
310 return TRUE;
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
311 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
312
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
313
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
314 /* ----------------------------------------------------------------------------
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
315 *
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
316 * SaveSubtree() is the recursive procedure that supports SaveTreeToFile().
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
317 *
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
318 * ----------------------------------------------------------------------------
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
319 */
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
320
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
321 static void
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
322 SaveSubtree(Tree *tree, int level, FILE *fp)
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
323 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
324 int i;
167
85ec50267440 Import from CVS: tag r20-3b10
cvs
parents: 163
diff changeset
325
163
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
326 level++;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
327 for ( ; tree ; tree = tree->sibling)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
328 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
329 for (i = 0 ; i < level ; i++)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
330 {
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
331 putc(' ', fp);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
332 putc(' ', fp);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
333 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
334 fprintf(fp, "%s\n", tree->label.text);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
335 if (tree->child)
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
336 SaveSubtree(tree->child, level, fp);
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
337 }
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
338 level--;
0132846995bd Import from CVS: tag r20-3b8
cvs
parents:
diff changeset
339 }