⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 symtab.c

📁 这是一个同样来自贝尔实验室的和UNIX有着渊源的操作系统, 其简洁的设计和实现易于我们学习和理解
💻 C
字号:
#include <stdio.h>#include <stdlib.h>#include <ctype.h>#include <string.h>#include "pic.h"#include "y.tab.h"YYSTYPE getvar(char *s)	/* return value of variable s (usually pointer) */{	struct symtab *p;	static YYSTYPE bug;	p = lookup(s);	if (p == NULL) {		if (islower(s[0]))			ERROR "no such variable as %s", s WARNING;		else			ERROR "no such place as %s", s WARNING;		return(bug);	}	return(p->s_val);}double getfval(char *s)	/* return float value of variable s */{	YYSTYPE y;	y = getvar(s);	return y.f;}void setfval(char *s, double f)	/* set variable s to f */{	struct symtab *p;	if ((p = lookup(s)) != NULL)		p->s_val.f = f;}struct symtab *makevar(char *s, int t, YYSTYPE v)	/* make variable named s in table */		/* assumes s is static or from tostring */{	struct symtab *p;	for (p = stack[nstack].p_symtab; p != NULL; p = p->s_next)		if (strcmp(s, p->s_name) == 0)			break;	if (p == NULL) {	/* it's a new one */		p = (struct symtab *) malloc(sizeof(struct symtab));		if (p == NULL)			ERROR "out of symtab space with %s", s FATAL;		p->s_next = stack[nstack].p_symtab;		stack[nstack].p_symtab = p;	/* stick it at front */	}	p->s_name = s;	p->s_type = t;	p->s_val = v;	return(p);}struct symtab *lookup(char *s)	/* find s in symtab */{	int i;	struct symtab *p;	for (i = nstack; i >= 0; i--)	/* look in each active symtab */		for (p = stack[i].p_symtab; p != NULL; p = p->s_next)			if (strcmp(s, p->s_name) == 0)				return(p);	return(NULL);}void freesymtab(struct symtab *p)	/* free space used by symtab at p */{	struct symtab *q;	for ( ; p != NULL; p = q) {		q = p->s_next;		free(p->s_name);	/* assumes done with tostring */		free((char *)p);	}}void freedef(char *s)	/* free definition for string s */{	struct symtab *p, *q, *op;	for (p = op = q = stack[nstack].p_symtab; p != NULL; p = p->s_next) {		if (strcmp(s, p->s_name) == 0) { 	/* got it */			if (p->s_type != DEFNAME)				break;			if (p == op)	/* 1st elem */				stack[nstack].p_symtab = p->s_next;			else				q->s_next = p->s_next;			free(p->s_name);			free(p->s_val.p);			free((char *)p);			return;		}		q = p;	}	/* ERROR "%s is not defined at this point", s WARNING; */}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -