11 |
|
#include <stdio.h> |
12 |
|
#include "parser.h" |
13 |
|
|
14 |
+ |
/* Number of entities for major versions */ |
15 |
+ |
short nentlist[MG_VMAJOR] = MG_NELIST; |
16 |
|
|
17 |
+ |
|
18 |
|
int |
19 |
|
put_entity(ac, av) /* general output routine */ |
20 |
|
register int ac; |
36 |
|
int i, en; |
37 |
|
|
38 |
|
if (argc < 2) { |
39 |
< |
fprintf(stderr, "Usage: %s entity,list [file ..]\n", argv[0]); |
39 |
> |
fprintf(stderr, |
40 |
> |
"Usage: %s { version | entity,list } [file ..]\n", |
41 |
> |
argv[0]); |
42 |
|
exit(1); |
43 |
|
} |
44 |
< |
for (cp1 = cp2 = argv[1]; *cp1; cp1 = cp2) { |
45 |
< |
while (*cp2) { |
46 |
< |
if (*cp2 == ',') { |
47 |
< |
*cp2++ = '\0'; |
48 |
< |
break; |
44 |
< |
} |
45 |
< |
cp2++; |
46 |
< |
} |
47 |
< |
en = mg_entity(cp1); |
48 |
< |
if (en < 0) { |
49 |
< |
fprintf(stderr, "%s: %s: no such entity\n", |
50 |
< |
argv[0], cp1); |
44 |
> |
if (isint(argv[1])) { |
45 |
> |
i = atoi(argv[1]); |
46 |
> |
if (i < 1 | i > MG_VMAJOR) { |
47 |
> |
fprintf(stderr, "%s: bad version number: %d\n", |
48 |
> |
argv[0], i); |
49 |
|
exit(1); |
50 |
|
} |
51 |
< |
mg_ehand[en] = put_entity; |
52 |
< |
} |
51 |
> |
for (en = nentlist[i-1]; en--; ) |
52 |
> |
mg_ehand[en] = put_entity; |
53 |
> |
mg_ehand[MG_E_INCLUDE] = NULL; /* expand include's */ |
54 |
> |
} else |
55 |
> |
for (cp1 = cp2 = argv[1]; *cp1; cp1 = cp2) { |
56 |
> |
while (*cp2) { |
57 |
> |
if (*cp2 == ',') { |
58 |
> |
*cp2++ = '\0'; |
59 |
> |
break; |
60 |
> |
} |
61 |
> |
cp2++; |
62 |
> |
} |
63 |
> |
en = mg_entity(cp1); |
64 |
> |
if (en < 0) { |
65 |
> |
fprintf(stderr, "%s: %s: no such entity\n", |
66 |
> |
argv[0], cp1); |
67 |
> |
exit(1); |
68 |
> |
} |
69 |
> |
mg_ehand[en] = put_entity; |
70 |
> |
} |
71 |
|
mg_init(); |
72 |
|
if (argc < 3) { |
73 |
|
if (mg_load((char *)NULL) != MG_OK) |