7 static struct option longopts[] = {
8 {"trace", no_argument, NULL, 't'},
9 {"tracearithmetic", no_argument, NULL, 't'},
10 {"tracelogical", no_argument, NULL, 'T'},
11 {"dump", no_argument, NULL, 'd'},
12 {"memorysize", required_argument, NULL, 'M'},
13 {"clocks", required_argument, NULL, 'C'},
14 {"help", no_argument, NULL, 'h'},
19 CERRARRAY cerr_comet2[] = {
20 { 201, "Load object file - full of COMET II memory" },
22 bool addcerrlist_comet2()
24 return addcerrlist(ARRAYSIZE(cerr_comet2), cerr_comet2);
27 /* 指定されたファイルからアセンブル結果を読込 */
28 bool loadassemble(char *file) {
31 if((fp = fopen(file, "r")) == NULL) {
35 if((endptr = startptr + fread(memory, sizeof(WORD), memsize-startptr, fp)) == memsize) {
36 setcerr(201, NULL); /* Load object file - full of COMET II memory */
37 fprintf(stderr, "Execute error - %d: %s\n", cerrno, cerrmsg);
45 int main(int argc, char *argv[])
48 const char *usage = "Usage: %s [-tTdh] [-M <memorysize>] [-C <clocks>] FILE\n";
51 while((opt = getopt_long(argc, argv, "tTdM:C:h", longopts, NULL)) != -1) {
54 execmode.trace = true;
57 execmode.trace = true;
58 execmode.logical = true;
64 memsize = atoi(optarg);
67 clocks = atoi(optarg);
70 fprintf(stdout, usage, argv[0]);
73 fprintf(stderr, usage, argv[0]);
79 if(loadassemble(argv[optind]) == true) {