1985-01-08 15:34:54 +00:00
|
|
|
#ifndef NORCSID
|
1994-06-24 14:02:31 +00:00
|
|
|
static char rcsid[] = "$Id$";
|
1985-01-08 15:34:54 +00:00
|
|
|
#endif
|
|
|
|
|
2017-11-12 00:35:48 +00:00
|
|
|
#include <assert.h>
|
2013-05-07 23:48:48 +00:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <stdio.h>
|
1985-01-08 15:34:54 +00:00
|
|
|
#include "param.h"
|
|
|
|
#include "tables.h"
|
|
|
|
#include "types.h"
|
|
|
|
#include <cgg_cg.h>
|
|
|
|
#include "data.h"
|
|
|
|
#include "result.h"
|
|
|
|
#include "state.h"
|
|
|
|
#include "extern.h"
|
|
|
|
|
|
|
|
/*
|
1987-03-10 01:26:51 +00:00
|
|
|
* (c) copyright 1987 by the Vrije Universiteit, Amsterdam, The Netherlands.
|
|
|
|
* See the copyright notice in the ACK home directory, in the file "Copyright".
|
1985-01-08 15:34:54 +00:00
|
|
|
*
|
|
|
|
* Author: Hans van Staveren
|
|
|
|
*/
|
|
|
|
|
|
|
|
extern int nstab; /* salloc.c */
|
|
|
|
|
2017-11-13 17:44:17 +00:00
|
|
|
static void bmove(short *, short *, int);
|
2016-11-10 21:04:18 +00:00
|
|
|
|
2017-11-13 17:44:17 +00:00
|
|
|
void savestatus(state_p sp) {
|
1985-01-08 15:34:54 +00:00
|
|
|
|
|
|
|
sp->st_sh = stackheight;
|
|
|
|
bmove((short *)fakestack,(short *)sp->st_fs,stackheight*sizeof(token_t));
|
|
|
|
sp->st_na = nallreg;
|
|
|
|
bmove((short *)allreg,(short *)sp->st_ar,nallreg*sizeof(int));
|
|
|
|
sp->st_ct = curtoken;
|
|
|
|
bmove((short *)dollar,(short *)sp->st_do,LONGESTPATTERN*sizeof(result_t));
|
|
|
|
bmove((short *)machregs,(short *)sp->st_mr,NREGS*sizeof(struct reginfo));
|
|
|
|
sp->st_ne = nemlines;
|
|
|
|
bmove((short *)emlines,(short *)sp->st_el,nemlines*sizeof(struct emline));
|
|
|
|
sp->st_em = emp;
|
|
|
|
sp->st_se = saveemp;
|
|
|
|
sp->st_tl = tokpatlen;
|
|
|
|
sp->st_ns = nstab;
|
|
|
|
}
|
|
|
|
|
2017-11-13 17:44:17 +00:00
|
|
|
void restorestatus(state_p sp) {
|
1985-01-08 15:34:54 +00:00
|
|
|
|
|
|
|
stackheight = sp->st_sh;
|
|
|
|
bmove((short *)sp->st_fs,(short *)fakestack,stackheight*sizeof(token_t));
|
|
|
|
nallreg = sp->st_na;
|
|
|
|
bmove((short *)sp->st_ar,(short *)allreg,nallreg*sizeof(int));
|
|
|
|
curtoken = sp->st_ct;
|
|
|
|
bmove((short *)sp->st_do,(short *)dollar,LONGESTPATTERN*sizeof(result_t));
|
|
|
|
bmove((short *)sp->st_mr,(short *)machregs,NREGS*sizeof(struct reginfo));
|
|
|
|
nemlines = sp->st_ne;
|
|
|
|
bmove((short *)sp->st_el,(short *)emlines,nemlines*sizeof(struct emline));
|
|
|
|
emp = sp->st_em;
|
|
|
|
saveemp = sp->st_se;
|
|
|
|
tokpatlen = sp->st_tl;
|
|
|
|
popstr(sp->st_ns);
|
|
|
|
}
|
|
|
|
|
2017-11-13 17:44:17 +00:00
|
|
|
static void bmove(short *from, short *to, int nbytes) {
|
1985-01-08 15:34:54 +00:00
|
|
|
|
|
|
|
if (nbytes<=0)
|
|
|
|
return;
|
|
|
|
assert(sizeof(short)==2 && (nbytes&1)==0);
|
|
|
|
nbytes>>=1;
|
|
|
|
do
|
|
|
|
*to++ = *from++;
|
|
|
|
while (--nbytes);
|
|
|
|
}
|