| 
									
										
										
										
											1991-02-19 12:39:46 +00:00
										 |  |  | /***********************************************************
 | 
					
						
							| 
									
										
										
										
											1995-01-04 19:08:09 +00:00
										 |  |  | Copyright 1991-1995 by Stichting Mathematisch Centrum, Amsterdam, | 
					
						
							|  |  |  | The Netherlands. | 
					
						
							| 
									
										
										
										
											1991-02-19 12:39:46 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |                         All Rights Reserved | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1996-10-25 14:44:06 +00:00
										 |  |  | Permission to use, copy, modify, and distribute this software and its | 
					
						
							|  |  |  | documentation for any purpose and without fee is hereby granted, | 
					
						
							| 
									
										
										
										
											1991-02-19 12:39:46 +00:00
										 |  |  | provided that the above copyright notice appear in all copies and that | 
					
						
							| 
									
										
										
										
											1996-10-25 14:44:06 +00:00
										 |  |  | both that copyright notice and this permission notice appear in | 
					
						
							| 
									
										
										
										
											1991-02-19 12:39:46 +00:00
										 |  |  | supporting documentation, and that the names of Stichting Mathematisch | 
					
						
							| 
									
										
										
										
											1996-10-25 14:44:06 +00:00
										 |  |  | Centrum or CWI or Corporation for National Research Initiatives or | 
					
						
							|  |  |  | CNRI not be used in advertising or publicity pertaining to | 
					
						
							|  |  |  | distribution of the software without specific, written prior | 
					
						
							|  |  |  | permission. | 
					
						
							| 
									
										
										
										
											1991-02-19 12:39:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1996-10-25 14:44:06 +00:00
										 |  |  | While CWI is the initial source for this software, a modified version | 
					
						
							|  |  |  | is made available by the Corporation for National Research Initiatives | 
					
						
							|  |  |  | (CNRI) at the Internet address ftp://ftp.python.org.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | STICHTING MATHEMATISCH CENTRUM AND CNRI DISCLAIM ALL WARRANTIES WITH | 
					
						
							|  |  |  | REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF | 
					
						
							|  |  |  | MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL STICHTING MATHEMATISCH | 
					
						
							|  |  |  | CENTRUM OR CNRI BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL | 
					
						
							|  |  |  | DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR | 
					
						
							|  |  |  | PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER | 
					
						
							|  |  |  | TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR | 
					
						
							|  |  |  | PERFORMANCE OF THIS SOFTWARE. | 
					
						
							| 
									
										
										
										
											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 */ | 
					
						
							| 
									
										
										
										
											1997-04-29 21:03:06 +00:00
										 |  |  | static void list1node Py_PROTO((FILE *, node *)); | 
					
						
							|  |  |  | static void listnode Py_PROTO((FILE *, node *)); | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | void | 
					
						
							| 
									
										
										
										
											1997-04-29 21:03:06 +00:00
										 |  |  | PyNode_ListTree(n) | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | 	node *n; | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	listnode(stdout, n); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | static int level, atbol; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1993-06-24 11:10:19 +00:00
										 |  |  | static void | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | listnode(fp, n) | 
					
						
							|  |  |  | 	FILE *fp; | 
					
						
							|  |  |  | 	node *n; | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	level = 0; | 
					
						
							|  |  |  | 	atbol = 1; | 
					
						
							|  |  |  | 	list1node(fp, n); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | static void | 
					
						
							|  |  |  | list1node(fp, n) | 
					
						
							|  |  |  | 	FILE *fp; | 
					
						
							|  |  |  | 	node *n; | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (n == 0) | 
					
						
							|  |  |  | 		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, "? "); | 
					
						
							|  |  |  | } |