| 
									
										
										
										
											1991-02-19 12:39:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | /* List a node on a file */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | #include "pgenheaders.h"
 | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | #include "token.h"
 | 
					
						
							|  |  |  | #include "node.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | /* Forward */ | 
					
						
							| 
									
										
										
										
											2000-07-09 03:09:57 +00:00
										 |  |  | static void list1node(FILE *, node *); | 
					
						
							|  |  |  | static void listnode(FILE *, node *); | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | void | 
					
						
							| 
									
										
										
										
											2000-07-22 19:20:54 +00:00
										 |  |  | PyNode_ListTree(node *n) | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-05-09 15:52:27 +00:00
										 |  |  |     listnode(stdout, n); | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | static int level, atbol; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1993-06-24 11:10:19 +00:00
										 |  |  | static void | 
					
						
							| 
									
										
										
										
											2000-07-22 19:20:54 +00:00
										 |  |  | listnode(FILE *fp, node *n) | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-05-09 15:52:27 +00:00
										 |  |  |     level = 0; | 
					
						
							|  |  |  |     atbol = 1; | 
					
						
							|  |  |  |     list1node(fp, n); | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | static void | 
					
						
							| 
									
										
										
										
											2000-07-22 19:20:54 +00:00
										 |  |  | list1node(FILE *fp, node *n) | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2017-03-23 17:53:47 +02:00
										 |  |  |     if (n == NULL) | 
					
						
							| 
									
										
										
										
											2010-05-09 15:52:27 +00:00
										 |  |  |         return; | 
					
						
							|  |  |  |     if (ISNONTERMINAL(TYPE(n))) { | 
					
						
							|  |  |  |         int i; | 
					
						
							|  |  |  |         for (i = 0; i < NCH(n); i++) | 
					
						
							|  |  |  |             list1node(fp, CHILD(n, i)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else if (ISTERMINAL(TYPE(n))) { | 
					
						
							|  |  |  |         switch (TYPE(n)) { | 
					
						
							|  |  |  |         case INDENT: | 
					
						
							|  |  |  |             ++level; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         case DEDENT: | 
					
						
							|  |  |  |             --level; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         default: | 
					
						
							|  |  |  |             if (atbol) { | 
					
						
							|  |  |  |                 int i; | 
					
						
							|  |  |  |                 for (i = 0; i < level; ++i) | 
					
						
							|  |  |  |                     fprintf(fp, "\t"); | 
					
						
							|  |  |  |                 atbol = 0; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (TYPE(n) == NEWLINE) { | 
					
						
							|  |  |  |                 if (STR(n) != NULL) | 
					
						
							|  |  |  |                     fprintf(fp, "%s", STR(n)); | 
					
						
							|  |  |  |                 fprintf(fp, "\n"); | 
					
						
							|  |  |  |                 atbol = 1; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             else | 
					
						
							|  |  |  |                 fprintf(fp, "%s ", STR(n)); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |         fprintf(fp, "? "); | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | } |