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
|
/* $Id: exopen.c,v 1.1.1.1 2004/12/23 04:05:04 ellson Exp $ $Revision: 1.1.1.1 $ */
/* vim:set shiftwidth=4 ts=8: */
/**********************************************************
* This software is part of the graphviz package *
* http://www.graphviz.org/ *
* *
* Copyright (c) 1994-2004 AT&T Corp. *
* and is licensed under the *
* Common Public License, Version 1.0 *
* by AT&T Corp. *
* *
* Information and Software Systems Research *
* AT&T Research, Florham Park NJ *
**********************************************************/
/*
* Glenn Fowler
* AT&T Research
*
* expression library
*/
#include <exlib.h>
#include <string.h>
/*
* allocate a new expression program environment
*/
Expr_t *exopen(register Exdisc_t * disc)
{
register Expr_t *program;
register Exid_t *sym;
int debug;
if (!(program = newof(0, Expr_t, 1, 0)))
return 0;
program->symdisc.key = offsetof(Exid_t, name);
debug = getenv("VMDEBUG") != 0;
if (!(program->symbols = dtopen(&program->symdisc, Dtset)) ||
!(program->tmp = sfstropen()) ||
!(program->vm =
(debug ? vmopen(Vmdcsbrk, Vmdebug, VM_DBCHECK | VM_DBABORT) :
vmopen(Vmdcheap, Vmbest, 0)))
|| !(program->ve =
(debug ? vmopen(Vmdcsbrk, Vmdebug, VM_DBCHECK | VM_DBABORT) :
vmopen(Vmdcheap, Vmbest, 0)))) {
exclose(program, 1);
return 0;
}
program->vc = program->ve;
program->id = "libexpr:expr";
program->disc = disc;
setcontext(program);
program->file[0] = sfstdin;
program->file[1] = sfstdout;
program->file[2] = sfstderr;
strcpy(program->main.name, "main");
program->main.lex = PROCEDURE;
program->main.index = PROCEDURE;
dtinsert(program->symbols, &program->main);
if (!(disc->flags & EX_PURE))
for (sym = exbuiltin; *sym->name; sym++)
dtinsert(program->symbols, sym);
if ((sym = disc->symbols))
for (; *sym->name; sym++)
dtinsert(program->symbols, sym);
return program;
}
|