-
Notifications
You must be signed in to change notification settings - Fork 1.1k
/
Copy pathmisc.c
68 lines (56 loc) · 1.3 KB
/
misc.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#include "defs.h"
#include "data.h"
#include "decl.h"
// Miscellaneous functions
// Copyright (c) 2019 Warren Toomey, GPL3
// Ensure that the current token is t,
// and fetch the next token. Otherwise
// throw an error
void match(int t, char *what) {
if (Token.token == t) {
scan(&Token);
} else {
fatals("Expected", what);
}
}
// Match a semicolon and fetch the next token
void semi(void) {
match(T_SEMI, ";");
}
// Match a left brace and fetch the next token
void lbrace(void) {
match(T_LBRACE, "{");
}
// Match a right brace and fetch the next token
void rbrace(void) {
match(T_RBRACE, "}");
}
// Match a left parenthesis and fetch the next token
void lparen(void) {
match(T_LPAREN, "(");
}
// Match a right parenthesis and fetch the next token
void rparen(void) {
match(T_RPAREN, ")");
}
// Match an identifier and fetch the next token
void ident(void) {
match(T_IDENT, "identifier");
}
// Print out fatal messages
void fatal(char *s) {
fprintf(stderr, "%s on line %d\n", s, Line);
exit(1);
}
void fatals(char *s1, char *s2) {
fprintf(stderr, "%s:%s on line %d\n", s1, s2, Line);
exit(1);
}
void fatald(char *s, int d) {
fprintf(stderr, "%s:%d on line %d\n", s, d, Line);
exit(1);
}
void fatalc(char *s, int c) {
fprintf(stderr, "%s:%c on line %d\n", s, c, Line);
exit(1);
}