summaryrefslogtreecommitdiff
path: root/symbol.c
blob: 55e3f15bec790628ff37e2c34be15587112ca6bf (plain) (blame)
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
#include <u.h>
#include <libc.h>
#include <bio.h>

#include "apl9.h"

Symtab *globalsymtab;
Symtab *currentsymtab;

Symbol *
getsym(Symtab *tab, Rune *name)
{
	for(int i = 0; i < tab->nsyms; i++)
		if(runestrcmp(tab->syms[i]->name, name) == 0)
			return tab->syms[i];
	
	tab->nsyms++;
	tab->syms = realloc(tab->syms, sizeof(Symbol *) * tab->nsyms);
	tab->syms[tab->nsyms-1] = malloc(sizeof(Symbol));
	tab->syms[tab->nsyms-1]->name = runestrdup(name);
	tab->syms[tab->nsyms-1]->undefined = 1;
	return tab->syms[tab->nsyms-1];
}

Symtab *
newsymtab(void)
{
	Symtab *tab = malloc(sizeof(Symtab));
	tab->nsyms = 0;
	tab->syms = nil;

	Symbol *io = getsym(tab, L"⎕IO");
	io->value.tag = ArrayTag;
	io->value.array = mkscalarint(currentsymtab ? globalIO() : 1);
	io->value.shy = 0;
	io->undefined = 0;

	return tab;
}

vlong
globalIO(void)
{
	Symbol *s = getsym(currentsymtab, L"⎕IO");
	return s->value.array->intdata[0];
}