ELF support for RMAC.
[rmac] / 68kgen.c
1 //
2 // RMAC - Reboot's Macro Assembler for the Atari Jaguar Console System
3 // 68KGEN.C - Tool to Generate 68000 Opcode Table
4 // Copyright (C) 199x Landon Dyer, 2017 Reboot and Friends
5 // RMAC derived from MADMAC v1.07 Written by Landon Dyer, 1986
6 // Source utilised with the kind permission of Landon Dyer
7 //
8
9 #include <stdio.h>
10 #include <ctype.h>
11 #include <stdlib.h>
12
13
14 #define EOS     '\0'
15
16 int kwnum = 1;                  /* current op# for kwgen output */
17 FILE * kfp;                             /* keyword file */
18 int lineno = 0;
19
20 // Function prototypes
21 void error(char *, char *);
22 void procln(int, char **);
23
24
25 int main(int argc, char ** argv)
26 {
27         char * namv[256];
28         char * s;
29         int namcnt;
30         char ln[256];
31
32         if ((argc == 2) && ((kfp = fopen(argv[1], "w")) == NULL))
33                 error("Cannot create: %s", argv[1]);
34
35         while (fgets(ln, 256, stdin) != NULL)
36         {
37                 lineno++;                       /* bump line# */
38
39                 if (*ln == '#')         /* ignore comments */
40                         continue;
41
42                 /*
43                  *  Tokenize line (like the way "argc, argv" works)
44                  *  and pass it to the parser.
45                  */
46                 namcnt = 0;
47                 s = ln;
48
49                 while (*s)
50                 {
51                         if (isspace(*s))
52                                 ++s;
53                         else
54                         {
55                                 namv[namcnt++] = s;
56
57                                 while (*s && !isspace(*s))
58                                         s++;
59
60                                 if (isspace(*s))
61                                         *s++ = EOS;
62                         }
63                 }
64
65                 if (namcnt)
66                         procln(namcnt, namv);
67         }
68
69         return 0;
70 }
71
72
73 //
74 // Parse line
75 //
76 void procln(int namc, char ** namv)
77 {
78         int i, j;
79         char * s;
80
81         // alias for previous entry
82         if (namc == 1)
83         {
84                 fprintf(kfp, "%s\t%d\n", namv[0], kwnum-1+1000);
85                 return;
86         }
87
88         if (namc < 5)
89         {
90                 fprintf(stderr, "%d: missing fields\n", lineno);
91                 exit(1);
92         }
93
94         // output keyword name
95         if (*namv[0] != '-')
96                 fprintf(kfp, "%s\t%d\n", namv[0], kwnum + 1000);
97
98         printf("/*%4d %-6s*/  {", kwnum, namv[0]);
99
100         if (*namv[1] == '!')
101                 printf("CGSPECIAL");
102         else for (s = namv[1], i=0; *s; ++s)
103                 printf("%sSIZ%c", (i++ ? "|" : ""), *s);
104
105         printf(", %s, %s, ", namv[2], namv[3]);
106
107         // enforce little fascist percent signs
108         if (*namv[4] == '%')
109         {
110                 for(i=1, j=0; i<17; ++i)
111                 {
112                         j <<= 1;
113
114                         if (namv[4][i] == '1' || isupper(namv[4][i]))
115                                 ++j;
116                 }
117
118                 printf("0x%04x, ", j);
119         }
120         else
121                 printf("%s, ", namv[4]);
122
123         if (namc == 7 && *namv[6] == '+')
124                 printf("%d, ", kwnum+1);
125         else
126                 printf("0, ");
127
128         printf("%s},\n", namv[5]);
129
130         kwnum++;
131 }
132
133
134 void error(char * s, char * s1)
135 {
136         fprintf(stderr, s, s1);
137         fprintf(stderr, "\n");
138         exit(1);
139 }
140