| Guido van Rossum | f70e43a | 1991-02-19 12:39:46 +0000 | [diff] [blame] | 1 |  | 
| Guido van Rossum | 85a5fbb | 1990-10-14 12:07:46 +0000 | [diff] [blame] | 2 | /* List a node on a file */ | 
 | 3 |  | 
| Guido van Rossum | 3f5da24 | 1990-12-20 15:06:42 +0000 | [diff] [blame] | 4 | #include "pgenheaders.h" | 
| Guido van Rossum | 85a5fbb | 1990-10-14 12:07:46 +0000 | [diff] [blame] | 5 | #include "token.h" | 
 | 6 | #include "node.h" | 
 | 7 |  | 
| Guido van Rossum | 3f5da24 | 1990-12-20 15:06:42 +0000 | [diff] [blame] | 8 | /* Forward */ | 
| Tim Peters | dbd9ba6 | 2000-07-09 03:09:57 +0000 | [diff] [blame] | 9 | static void list1node(FILE *, node *); | 
 | 10 | static void listnode(FILE *, node *); | 
| Guido van Rossum | 3f5da24 | 1990-12-20 15:06:42 +0000 | [diff] [blame] | 11 |  | 
 | 12 | void | 
| Thomas Wouters | 23c9e00 | 2000-07-22 19:20:54 +0000 | [diff] [blame] | 13 | PyNode_ListTree(node *n) | 
| Guido van Rossum | 3f5da24 | 1990-12-20 15:06:42 +0000 | [diff] [blame] | 14 | { | 
 | 15 | 	listnode(stdout, n); | 
 | 16 | } | 
 | 17 |  | 
| Guido van Rossum | 85a5fbb | 1990-10-14 12:07:46 +0000 | [diff] [blame] | 18 | static int level, atbol; | 
 | 19 |  | 
| Guido van Rossum | 9e90a67 | 1993-06-24 11:10:19 +0000 | [diff] [blame] | 20 | static void | 
| Thomas Wouters | 23c9e00 | 2000-07-22 19:20:54 +0000 | [diff] [blame] | 21 | listnode(FILE *fp, node *n) | 
| Guido van Rossum | 3f5da24 | 1990-12-20 15:06:42 +0000 | [diff] [blame] | 22 | { | 
 | 23 | 	level = 0; | 
 | 24 | 	atbol = 1; | 
 | 25 | 	list1node(fp, n); | 
 | 26 | } | 
 | 27 |  | 
| Guido van Rossum | 85a5fbb | 1990-10-14 12:07:46 +0000 | [diff] [blame] | 28 | static void | 
| Thomas Wouters | 23c9e00 | 2000-07-22 19:20:54 +0000 | [diff] [blame] | 29 | list1node(FILE *fp, node *n) | 
| Guido van Rossum | 85a5fbb | 1990-10-14 12:07:46 +0000 | [diff] [blame] | 30 | { | 
 | 31 | 	if (n == 0) | 
 | 32 | 		return; | 
 | 33 | 	if (ISNONTERMINAL(TYPE(n))) { | 
 | 34 | 		int i; | 
 | 35 | 		for (i = 0; i < NCH(n); i++) | 
 | 36 | 			list1node(fp, CHILD(n, i)); | 
 | 37 | 	} | 
 | 38 | 	else if (ISTERMINAL(TYPE(n))) { | 
 | 39 | 		switch (TYPE(n)) { | 
 | 40 | 		case INDENT: | 
 | 41 | 			++level; | 
 | 42 | 			break; | 
 | 43 | 		case DEDENT: | 
 | 44 | 			--level; | 
 | 45 | 			break; | 
 | 46 | 		default: | 
 | 47 | 			if (atbol) { | 
 | 48 | 				int i; | 
 | 49 | 				for (i = 0; i < level; ++i) | 
 | 50 | 					fprintf(fp, "\t"); | 
 | 51 | 				atbol = 0; | 
 | 52 | 			} | 
 | 53 | 			if (TYPE(n) == NEWLINE) { | 
 | 54 | 				if (STR(n) != NULL) | 
 | 55 | 					fprintf(fp, "%s", STR(n)); | 
 | 56 | 				fprintf(fp, "\n"); | 
 | 57 | 				atbol = 1; | 
 | 58 | 			} | 
 | 59 | 			else | 
 | 60 | 				fprintf(fp, "%s ", STR(n)); | 
 | 61 | 			break; | 
 | 62 | 		} | 
 | 63 | 	} | 
 | 64 | 	else | 
 | 65 | 		fprintf(fp, "? "); | 
 | 66 | } |