-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsymtab.c
133 lines (119 loc) · 3.7 KB
/
symtab.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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
/****************************************************/
/* File: symtab.c */
/* Symbol table implementation for the TINY compiler*/
/* (allows only one symbol table) */
/* Symbol table is implemented as a chained */
/* hash table */
/* Compiler Construction: Principles and Practice */
/* Kenneth C. Louden */
/****************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "symtab.h"
#include "globals.h"
/* SHIFT is the power of two used as multiplier
in hash function */
#define SHIFT 4
/* the hash function */
static int hash ( char * key )
{ int temp = 0;
int i = 0;
while (key[i] != '\0')
{ temp = ((temp << SHIFT) + key[i]) % SIZE;
++i;
}
return temp;
}
/* Procedure st_insert inserts line numbers and
* memory locations into the symbol table
* loc = memory location is inserted only the
* first time, otherwise ignored
*/
void st_insert( char * name, int lineno, int loc,int sp ,int para)
{ int h = hash(name);
BucketList l = Scope[sp].hashTable[h];
while ((l != NULL) && (strcmp(name,l->name) != 0))
l = l->next;
if (l == NULL) /* variable not yet in table */
{ l = (BucketList) malloc(sizeof(struct BucketListRec));
l->name = name;
l->scope=sp; /* scope of variable */
l->isParam=para; /* parameter or not */
l->lines = (LineList) malloc(sizeof(struct LineListRec));
l->lines->lineno = lineno;
l->memloc = loc;
l->lines->next = NULL;
l->next = Scope[sp].hashTable[h];
Scope[sp].hashTable[h] = l; }
else /* found in table, so just add line number */
{ LineList t = l->lines;
while (t->next != NULL) t = t->next;
t->next = (LineList) malloc(sizeof(struct LineListRec));
t->next->lineno = lineno;
t->next->next = NULL;
}
} /* st_insert */
/* Function fun_lookup returns the bucket
* location of a funtion or NULL if not found
*/
BucketList fun_lookup ( char * name ,int sp)
{ int h = hash(name);
BucketList l = Scope[sp].hashTable[h];
while ((l != NULL) && (strcmp(name,l->name) != 0))
l = l->next;
if (l == NULL) return NULL;
else return l;
}
/* Function var_lookup returns the bucket
* location of a var or NULL if not found
*/
BucketList var_lookup ( char * name ,int sp)
{ int h = hash(name);
BucketList l = Scope[sp].hashTable[h];
while ((l != NULL) && (strcmp(name,l->name) != 0))
l = l->next;
if (l == NULL) return NULL;
else return l;
}
/* Function st_lookup returns the memory
* location of a variable or -1 if not found
*/
int st_lookup ( char * name ,int sp)
{ int h = hash(name);
BucketList l = Scope[sp].hashTable[h];
while ((l != NULL) && (strcmp(name,l->name) != 0))
l = l->next;
if (l == NULL) return -1;
else return l->memloc;
}
/* Procedure printSymTab prints a formatted
* listing of the symbol table contents
* to the listing file
*/
void printSymTab(FILE * listing)
{ int i,j;
for(j=0;j<=HighScope;j++)
{
fprintf(listing,"Scope Variable Name Location Line Numbers\n");
fprintf(listing,"----- ------------- -------- ------------\n");
for (i=0;i<SIZE;++i)
{ if (Scope[j].hashTable[i] != NULL)
{ BucketList l = Scope[j].hashTable[i];
while (l != NULL)
{ LineList t = l->lines;
fprintf(listing,"%-6d ",l->scope);
fprintf(listing,"%-14s ",l->name);
fprintf(listing,"%-8d ",l->memloc);
while (t != NULL)
{ fprintf(listing,"%4d ",t->lineno);
t = t->next;
}
fprintf(listing,"\n");
l = l->next;
}
}
}
fprintf(listing,"\n");
}
} /* printSymTab */