150 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			150 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef NORCSID
 | |
| static char rcsid[] = "$Header$";
 | |
| #endif
 | |
| 
 | |
| #include "assert.h"
 | |
| #include "param.h"
 | |
| #include "tables.h"
 | |
| #include "types.h"
 | |
| #include <cg_pattern.h>
 | |
| #include "data.h"
 | |
| #include "result.h"
 | |
| #include "extern.h"
 | |
| 
 | |
| /*
 | |
|  * (c) copyright 1983 by the Vrije Universiteit, Amsterdam, The Netherlands.
 | |
|  *
 | |
|  *          This product is part of the Amsterdam Compiler Kit.
 | |
|  *
 | |
|  * Permission to use, sell, duplicate or disclose this software must be
 | |
|  * obtained in writing. Requests for such permissions may be sent to
 | |
|  *
 | |
|  *      Dr. Andrew S. Tanenbaum
 | |
|  *      Wiskundig Seminarium
 | |
|  *      Vrije Universiteit
 | |
|  *      Postbox 7161
 | |
|  *      1007 MC Amsterdam
 | |
|  *      The Netherlands
 | |
|  *
 | |
|  * Author: Hans van Staveren
 | |
|  */
 | |
| 
 | |
| /*
 | |
|  * Package for string allocation and garbage collection.
 | |
|  * Call salloc(size) to get room for string.
 | |
|  * Every now and then call garbage_collect() from toplevel.
 | |
|  */
 | |
| 
 | |
| #define MAXSTAB         500
 | |
| #define THRESHOLD       200
 | |
| 
 | |
| char *stab[MAXSTAB];
 | |
| int nstab=0;
 | |
| string malloc();
 | |
| 
 | |
| string myalloc(size) {
 | |
| 	register string p;
 | |
| 
 | |
| 	p = (string) malloc(size);
 | |
| 	if (p==0)
 | |
| 		fatal("Out of memory");
 | |
| 	return(p);
 | |
| }
 | |
| 
 | |
| myfree(p) string p; {
 | |
| 
 | |
| 	free(p);
 | |
| }
 | |
| 
 | |
| popstr(nnstab) {
 | |
| 	register i;
 | |
| 
 | |
| 	for (i=nnstab;i<nstab;i++)
 | |
| 		myfree(stab[i]);
 | |
| 	nstab = nnstab;
 | |
| }
 | |
| 
 | |
| char *salloc(size) {
 | |
| 	register char *p;
 | |
| 
 | |
| 	if (nstab==MAXSTAB)
 | |
| 		fatal("String table overflow");
 | |
| 	p = myalloc(size+1);    /* extra room for terminating zero */
 | |
| 	stab[nstab++] = p;
 | |
| 	return(p);
 | |
| }
 | |
| 
 | |
| compar(p1,p2) char **p1,**p2; {
 | |
| 
 | |
| 	assert(*p1 != *p2);
 | |
| 	if (*p1 < *p2)
 | |
| 		return(-1);
 | |
| 	return(1);
 | |
| }
 | |
| 
 | |
| garbage_collect() {
 | |
| 	register i;
 | |
| 	struct emline *emlp;
 | |
| 	token_p tp;
 | |
| 	tkdef_p tdp;
 | |
| 	struct reginfo *rp;
 | |
| 	register char **fillp,**scanp;
 | |
| 	char used[MAXSTAB];     /* could be bitarray */
 | |
| 
 | |
| 	if (nstab<THRESHOLD)
 | |
| 		return;
 | |
| 	qsort(stab,nstab,sizeof (char *),compar);
 | |
| 	for (i=0;i<nstab;i++)
 | |
| 		used[i]= FALSE;
 | |
| 	for(emlp=emlines;emlp<emlines+nemlines;emlp++)
 | |
| 		chkstr(emlp->em_soper,used);
 | |
| 	for (tp= fakestack;tp<&fakestack[stackheight];tp++) {
 | |
| 		if (tp->t_token== -1)
 | |
| 			continue;
 | |
| 		tdp = &tokens[tp->t_token];
 | |
| 		for (i=0;i<TOKENSIZE;i++)
 | |
| 			if (tdp->t_type[i] == EV_STR)
 | |
| 				chkstr(tp->t_att[i].as,used);
 | |
| 	}
 | |
| 	for (rp= machregs; rp<machregs+NREGS; rp++) {
 | |
| 		tp = &rp->r_contents;
 | |
| 		assert(tp->t_token != -1);
 | |
| 		tdp= &tokens[tp->t_token];
 | |
| 		for (i=0;i<TOKENSIZE;i++)
 | |
| 			if (tdp->t_type[i] == EV_STR)
 | |
| 				chkstr(tp->t_att[i].as,used);
 | |
| 	}
 | |
| 	for (i=0;i<nstab;i++)
 | |
| 		if (!used[i]) {
 | |
| 			myfree(stab[i]);
 | |
| 			stab[i]=0;
 | |
| 		}
 | |
| 	fillp=stab;
 | |
| 	for (scanp=stab;scanp<stab+nstab;scanp++)
 | |
| 		if (*scanp != 0)
 | |
| 			*fillp++ = *scanp;
 | |
| 	nstab = fillp-stab;
 | |
| }
 | |
| 
 | |
| chkstr(str,used) string str; char used[]; {
 | |
| 	register low,middle,high;
 | |
| 
 | |
| 	low=0; high=nstab-1;
 | |
| 	while (high>low) {
 | |
| 		middle= (low+high)>>1;
 | |
| 		if (str==stab[middle]) {
 | |
| 			used[middle]=1;
 | |
| 			return;
 | |
| 		}
 | |
| 		if (str<stab[middle])
 | |
| 			high = middle-1;
 | |
| 		else
 | |
| 			low = middle+1;
 | |
| 	}
 | |
| 	if (low==high) {
 | |
| 		if (str==stab[low]) {
 | |
| 			used[low]=1;
 | |
| 		}
 | |
| 		return;
 | |
| 	}
 | |
| }
 |