bitwise: more work on ion

This commit is contained in:
Kyle Isom 2018-03-27 15:59:34 -07:00
parent c242894f94
commit 2404595738
3 changed files with 141 additions and 7 deletions

View File

@ -5,7 +5,8 @@ CFLAGS := -g -std=c99 -Wall -Werror
.PHONY: all run .PHONY: all run
all: run all: run
run:$(TARGET) run: $(TARGET)
@echo "running $(TARGET)"
./$(TARGET) ./$(TARGET)
$(TARGET): $(OBJS) $(TARGET): $(OBJS)

View File

@ -2,10 +2,16 @@
#include <ctype.h> #include <ctype.h>
#include <stdbool.h> #include <stdbool.h>
#include <stddef.h> #include <stddef.h>
#include <stdint.h>
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#ifndef NDEBUG
#define tprint(...) do { fprintf( stderr, __VA_ARGS__ ); } while( false )
#else
#define tprint(x) {}
#endif
#define MAX(a, b) ((a) < (b) ? (b) : (a)) #define MAX(a, b) ((a) < (b) ? (b) : (a))
// stretchy buffers // stretchy buffers
@ -25,7 +31,7 @@ void *buf__grow(const void *, size_t, size_t);
#define buf_push(b, x) (buf__fit((b), 1), (b)[buf_len((b))] = (x), buf__hdr((b))->len++) #define buf_push(b, x) (buf__fit((b), 1), (b)[buf_len((b))] = (x), buf__hdr((b))->len++)
#define buf_free(b) ((b) ? free(buf__hdr((b))) : 0) #define buf_free(b) ((b) ? free(buf__hdr((b))) : 0)
#define prlu(m, v) (printf("%s: %lu\n", m, (unsigned long)(v))) #define prlu(m, v) (tprint("%s: %lu\n", m, (unsigned long)(v)))
void * void *
buf__grow(const void *buf, size_t nlen, size_t esize) buf__grow(const void *buf, size_t nlen, size_t esize)
@ -51,6 +57,8 @@ static void
buf_test(void) buf_test(void)
{ {
int *stretchy = NULL; int *stretchy = NULL;
tprint("buf_test\n");
for (int i = 0; i < 1024; i++) { for (int i = 0; i < 1024; i++) {
buf_push(stretchy, i); buf_push(stretchy, i);
} }
@ -60,7 +68,7 @@ buf_test(void)
} }
buf_free(stretchy); buf_free(stretchy);
printf("OK\n"); tprint("OK\n");
} }
typedef enum TokenKind { typedef enum TokenKind {
TOKEN_INT = 128, TOKEN_INT = 128,
@ -70,6 +78,13 @@ typedef enum TokenKind {
typedef struct Token { typedef struct Token {
TokenKind kind; TokenKind kind;
union {
uint64_t val;
struct {
const char *start;
const char *end;
};
};
// ... // ...
} Token; } Token;
@ -78,6 +93,7 @@ const char *stream;
Token token; Token token;
void next_token(void) { void next_token(void) {
switch (*stream) { switch (*stream) {
/* Numeric literal */
case '0': case '0':
case '1': case '1':
case '2': case '2':
@ -87,27 +103,122 @@ void next_token(void) {
case '6': case '6':
case '7': case '7':
case '8': case '8':
case '9': case '9': {
uint64_t val = 0; /* reset the token's value */
while (isdigit(*stream)) { while (isdigit(*stream)) {
val *= 10;
val += (*stream - '0');
stream++; stream++;
} }
token.kind = TOKEN_INT; token.kind = TOKEN_INT;
token.val = val;
break; break;
}
/* Identifier */
case 'a':
case 'b':
case 'c':
case 'd':
case 'e':
case 'f':
case 'g':
case 'h':
case 'i':
case 'j':
case 'k':
case 'l':
case 'm':
case 'n':
case 'o':
case 'p':
case 'q':
case 'r':
case 's':
case 't':
case 'u':
case 'v':
case 'w':
case 'x':
case 'y':
case 'z':
case 'A':
case 'B':
case 'C':
case 'D':
case 'E':
case 'F':
case 'G':
case 'H':
case 'I':
case 'J':
case 'K':
case 'L':
case 'M':
case 'N':
case 'O':
case 'P':
case 'Q':
case 'R':
case 'S':
case 'T':
case 'U':
case 'V':
case 'W':
case 'X':
case 'Y':
case 'Z':
case '_': {
const char *start = stream++;
while (isalnum(*stream) || *stream == '_') {
stream++;
}
token.kind = TOKEN_NAME;
token.start = start;
token.end = stream;
break;
}
default: default:
token.kind = *stream++; token.kind = *stream++;
break; break;
} }
} }
void lex_test() void
print_token(void)
{
tprint("TOKEN: %d", token.kind);
switch (token.kind) {
case TOKEN_INT:
tprint(" VALUE: %lu", token.val);
break;
case TOKEN_NAME:
break;
default:
break;
}
}
void
lex_test(void)
{ {
char source[] = "+()123456+994"; char source[] = "+()123456+994";
tprint("lex_test\n");
stream = source; stream = source;
next_token(); next_token();
while (token.kind) { while (token.kind) {
printf("TOKEN: %d\n", token.kind); tprint("TOKEN: %d\n", token.kind);
switch (token.kind) {
case TOKEN_INT:
tprint("\tvalue: %lu\n", (long unsigned)token.val);
break;
default:
break;
}
next_token(); next_token();
} }
tprint("OK\n");
} }
int int

View File

@ -17,4 +17,26 @@ stretch buffers:
+ ex. '1234 (x+y)' translates to '1234' '(' 'x' '+' 'y' ')' + ex. '1234 (x+y)' translates to '1234' '(' 'x' '+' 'y' ')'
+ no semantics yet + no semantics yet
+ simple hand-written approach + simple hand-written approach
+ mark: 1:09:11 + mark: 1:17:34
dev log:
+ you can use a union with an anonymous struct to add fields to a struct maybe
struct Thing {
int type;
union {
uint64_t val;
struct {
int start;
int end;
};
};
};
+ C99 variadic debug macro:
#ifndef NDEBUG
#define tprint(...) do { fprintf(stderr, __VA_ARGS__); } while (false)
#else
#define tprint(...) do {} while (false)
#endif