--- src/main.c 2009-10-24 08:28:09.000000000 +0200 +++ main.c 2009-12-07 22:42:09.000000000 +0100 @@ -5,7 +5,7 @@ Author: 1985 Wayne A. Christopher The main routine for ngspice - $Id: main.c,v 1.58 2009/10/24 06:28:09 dwarning Exp $ + $Id: main.c,v 1.60 2009/12/07 21:42:09 h_vogt Exp $ */ #include "ngspice.h" @@ -53,6 +53,7 @@ #include "frontend/variable.h" #include "frontend/display.h" /* added by SDB to pick up Input() fcn */ #include "frontend/signal_handler.h" +#include "compatmode.h" /* saj xspice headers */ #ifdef XSPICE @@ -188,9 +189,14 @@ extern struct comm spcp_coms[ ]; struct comm *cp_coms = spcp_coms; -extern int OUTpBeginPlot(), OUTpData(), OUTwBeginPlot(), OUTwReference(); -extern int OUTwData(), OUTwEnd(), OUTendPlot(), OUTbeginDomain(); -extern int OUTendDomain(), OUTstopnow(), OUTerror(), OUTattributes(); +extern int OUTpBeginPlot(void *,void *,IFuid,IFuid,int,int,IFuid *,int,void **); +extern int OUTpData(void *,IFvalue *,IFvalue *); +extern int OUTwBeginPlot(void *,void *,IFuid,IFuid,int,int,IFuid *,int,void **); +extern int OUTwReference(void *,IFvalue *,void **); +extern int OUTwData(void *,int,IFvalue *,void *), OUTwEnd(void *), OUTendPlot(void *); +extern int OUTbeginDomain(void *,IFuid,int,IFvalue *); +extern int OUTendDomain(void *), OUTstopnow(void), OUTerror(int,char *,IFuid *); +extern int OUTattributes(void *,IFuid *,int,IFvalue *); IFfrontEnd nutmeginfo = { IFnewUid, @@ -347,6 +353,26 @@ int DEVmaxnum = 0; /* -------------------------------------------------------------------------- */ +/* Set a compatibility flag. + Currently available are flags for: + ngspice (standard) + HSPICE + Spice3 +*/ +COMPATMODE_T ngspice_compat_mode(void) +{ + char behaviour[80] ; + + if( cp_getvar("ngbehavior", VT_STRING, behaviour)){ + if (strcasecmp(behaviour,"hspice")==0) + return( COMPATMODE_HSPICE ) ; + if (strcasecmp(behaviour,"spice3")==0) + return( COMPATMODE_SPICE3 ) ; + } + return(COMPATMODE_NATIVE) ; +} /* end ngspice_compat_mode() */ + +/* -------------------------------------------------------------------------- */ int SIMinit(IFfrontEnd *frontEnd, IFsimulator **simulator) { @@ -553,6 +579,7 @@ " -i, --interactive run in interactive mode\n" " -n, --no-spiceinit don't load the local or user's config file\n" " -o, --output=FILE set the outputfile\n" + " -p, --pipe run in I/O pipe mode\n" " -q, --completion activate command completion\n" " -r, --rawfile=FILE set the rawfile output\n" " -s, --server run spice as a server process\n" @@ -759,6 +786,7 @@ {"interactive", 0, 0, 'i'}, {"no-spiceinit", 0, 0, 'n'}, {"output", 1, 0, 'o'}, + {"pipe", 0, 0, 'p'}, {"completion", 0, 0, 'q'}, {"rawfile", 1, 0, 'r'}, {"server", 0, 0, 's'}, @@ -766,7 +794,7 @@ {0, 0, 0, 0} }; - c = getopt_long (argc, argv, "hvbac:ihno:qr:st:", + c = getopt_long (argc, argv, "hvbac:ihno:pqr:st:", long_options, &option_index); if (c == -1) break; @@ -826,6 +854,11 @@ } break; + case 'p': /* Run in pipe mode */ + iflag = TRUE; + istty = TRUE; + break; + case 'q': /* Command completion */ qflag = TRUE; break;