4.3BSD/usr/contrib/B/src/bsmall/b2tar.c

Compare this file to the similar file:
Show the results in this format:

/* Copyright (c) Stichting Mathematisch Centrum, Amsterdam, 1984. */
/* $Header: b2tar.c,v 1.1 84/06/28 00:49:23 timo Exp $ */

/* B target locating */
#include "b.h"
#include "b1obj.h"
#include "b2env.h"
#include "b2syn.h"
#include "b2sem.h"

Visible loc statrimloc(l, v) loc l; value v; {
	/* temporary, while no static type check */
	return (loc) mk_elt();
}

Visible loc statbseloc(l, k) loc l; value k; {
	/* temporary, while no static type check */
	return (loc) mk_elt();
}

Visible loc targ(q) txptr q; {
	value c; loc l; txptr i, j; intlet len, k;
	if ((len= 1+count(",", q)) == 1) return bastarg(q);
	c= mk_compound(len);
	k_Overfields {
		if (!Lastfield(k)) req(",", q, &i, &j);
		else i= q;
		l= bastarg(i);
		put_in_field(l, &c, k);
		if (!Lastfield(k)) tx= j;
	}
	return (loc) c;
}

Visible loc bastarg(q) txptr q; {
	loc l; txptr i, j; value k;
	Skipsp(tx);
	nothing(q, "target");
	if (Char(tx) == '(') {
		tx++; req(")", q, &i, &j);
		l= targ(i); tx= j;
	} else if (Letter(Char(tx))) {
		value t= tag(), *aa;
		aa= lookup(t);
		if (aa == Pnil) l= local_loc(t);
		else if (Is_refinement(*aa))
			pprerr("refined targets are not allowed", "");
		else if (Is_formal(*aa)) {
			l= loc_formal(*aa);
		} else if (Is_shared(*aa))
			l= global_loc(t);
		else l= local_loc(t);
		release(t);
	} else parerr("no target where expected", "");
	Skipsp(tx);
	while (tx < q && Char(tx) == '[') {
		if (xeq) check_location(l);
		tx++; req("]", q, &i, &j);
		k= expr(i); tx= j;
		if (xeq) {
			loc ll= l;
			l= tbsel_loc(l, k);
			release(k); release(ll);
		} else l= statbseloc(l, k);
		Skipsp(tx);
	}
	if (tx < q && (Char(tx) == '@' || Char(tx) == '|')) {
		value v= xeq ? content(l) : Vnil; intlet B, C;
		if (xeq && !Is_text(v))
		  error("in the target t@p or t|p, t does not contain a text");
		trimbc(q, xeq ? length(v) : 0, &B, &C);
		release(v);
		if (xeq) l= trim_loc(l, B, C);
		else l= statrimloc(l, k);
		Skipsp(tx);
	}
	if (tx < q) parerr(Char(tx) == ',' ? "comma not allowed here" :
					"garbage following target", "");
	return l;
}