annotate lisp/oobr/tree-x/input.c @ 58:8b0bdfdf0cf0 r19-16-pre4

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