Compare commits
No commits in common. "12d39043ecc1eb30fbf3b5a073d58f52ced68816" and "aa1898fd6660b8df99cfac2ce23dfdef8a08e4a3" have entirely different histories.
12d39043ec
...
aa1898fd66
|
@ -1,3 +0,0 @@
|
||||||
*.h linguist-language=C
|
|
||||||
*.c linguist-language=C
|
|
||||||
Makefile -linguist-detectable
|
|
10
assembler.c
10
assembler.c
|
@ -238,7 +238,6 @@ void striplabels(ASSEMBLER* a) {
|
||||||
a->lns = curln->next;
|
a->lns = curln->next;
|
||||||
LINELIST* tmp = curln;
|
LINELIST* tmp = curln;
|
||||||
curln = curln->next;
|
curln = curln->next;
|
||||||
free(tmp->content);
|
|
||||||
free(tmp);
|
free(tmp);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -373,17 +372,8 @@ void translate(ASSEMBLER* a) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void freelns(LINELIST* lns) {
|
|
||||||
LINELIST* next = lns->next;
|
|
||||||
free(lns->content);
|
|
||||||
free(lns);
|
|
||||||
if(next != NULL)
|
|
||||||
freelns(next);
|
|
||||||
}
|
|
||||||
|
|
||||||
void freeassembler(ASSEMBLER* a) {
|
void freeassembler(ASSEMBLER* a) {
|
||||||
freesymbols(a->vars);
|
freesymbols(a->vars);
|
||||||
freesymbols(a->labels);
|
freesymbols(a->labels);
|
||||||
freelns(a->lns);
|
|
||||||
free(a);
|
free(a);
|
||||||
}
|
}
|
||||||
|
|
9
main.c
9
main.c
|
@ -12,6 +12,14 @@ char* getoutname(char* fname, int fnamelen) {
|
||||||
return outf;
|
return outf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void printlns(LINELIST* lns, FILE* stream) {
|
||||||
|
LINELIST* curln = lns;
|
||||||
|
while(curln != NULL) {
|
||||||
|
fprintf(stream, "%s\n", curln->content);
|
||||||
|
curln = curln->next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char* argv[]) {
|
int main(int argc, char* argv[]) {
|
||||||
if(argc < 2) {
|
if(argc < 2) {
|
||||||
printf("Usage: %s {input}\n", argv[0]);
|
printf("Usage: %s {input}\n", argv[0]);
|
||||||
|
@ -35,7 +43,6 @@ int main(int argc, char* argv[]) {
|
||||||
parse(p);
|
parse(p);
|
||||||
|
|
||||||
ASSEMBLER* a = mkassembler(p->output);
|
ASSEMBLER* a = mkassembler(p->output);
|
||||||
free(p);
|
|
||||||
|
|
||||||
// variable substitution
|
// variable substitution
|
||||||
preprocess(a);
|
preprocess(a);
|
||||||
|
|
1
parser.c
1
parser.c
|
@ -4,7 +4,6 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include "parser.h"
|
#include "parser.h"
|
||||||
#include "util.h"
|
|
||||||
|
|
||||||
void pushln(LINELIST** curln, char* tmpln, int lnind, int truen) {
|
void pushln(LINELIST** curln, char* tmpln, int lnind, int truen) {
|
||||||
int size = (lnind+1)*sizeof(char);
|
int size = (lnind+1)*sizeof(char);
|
||||||
|
|
7
parser.h
7
parser.h
|
@ -1,11 +1,14 @@
|
||||||
#ifndef PARSER_H
|
#ifndef PARSER_H
|
||||||
#define PARSER_H
|
#define PARSER_H
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include "util.h"
|
|
||||||
|
|
||||||
#define INST_LIMIT 1<<15
|
#define INST_LIMIT 1<<15
|
||||||
|
|
||||||
|
typedef struct lnls {
|
||||||
|
char* content;
|
||||||
|
int truen;
|
||||||
|
struct lnls* next;
|
||||||
|
} LINELIST;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
FILE* input;
|
FILE* input;
|
||||||
|
|
8
util.c
8
util.c
|
@ -22,11 +22,3 @@ int countplaces(int n) {
|
||||||
}
|
}
|
||||||
return places;
|
return places;
|
||||||
}
|
}
|
||||||
|
|
||||||
void printlns(LINELIST* lns, FILE* stream) {
|
|
||||||
LINELIST* curln = lns;
|
|
||||||
while(curln != NULL) {
|
|
||||||
fprintf(stream, "%s\n", curln->content);
|
|
||||||
curln = curln->next;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
11
util.h
11
util.h
|
@ -1,16 +1,5 @@
|
||||||
#ifndef UTIL_H
|
#ifndef UTIL_H
|
||||||
#define UTIL_H
|
#define UTIL_H
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
char* heapstr(const char* str, int len);
|
char* heapstr(const char* str, int len);
|
||||||
int countplaces(int n);
|
int countplaces(int n);
|
||||||
|
|
||||||
typedef struct lnls {
|
|
||||||
char* content;
|
|
||||||
int truen;
|
|
||||||
struct lnls* next;
|
|
||||||
} LINELIST;
|
|
||||||
|
|
||||||
void printlns(LINELIST* lns, FILE* stream);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue