⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 inppas2.c

📁 spice中支持多层次元件模型仿真的可单独运行的插件源码
💻 C
字号:
/**********Copyright 1990 Regents of the University of California.  All rights reserved.Author: 1985 Thomas L. Quarles**********/#include "spice.h"#include "strext.h"#include <ctype.h>#include "ifsim.h"#include "cpdefs.h"#include "fteext.h"#include "ftedefs.h"#include "inpdefs.h"#include "util.h"#include "iferrmsg.h"#include "tskdefs.h"#include "inpmacs.h"#include "suffix.h"/* pass 2 - Scan through the lines.  ".model" cards have processed *  in pass1 and are ignored here. */voidINPpas2(ckt,data,tab,task)     GENERIC *ckt;    card *data;    INPtables *tab;    GENERIC *task;{card *current;char c;char * groundname="0";char * gname;GENERIC *gnode;int error;  /* used by the macros defined above */    error = INPgetTok(&groundname,&gname,1);    if(error) data->error = INPerrCat(data->error,INPmkTemp(            "can't read internal ground node name!\n"));    error = INPgndInsert(ckt,&gname,tab,&gnode);    if(error && error!=E_EXISTS)data->error = INPerrCat(data->error,INPmkTemp(            "can't insert internal ground node in symbol table!\n"));    for(current = data; current != NULL; current = current->nextcard) {        c = *(current->line);        c = islower(c) ? toupper(c) : c;	switch(c) {        case ' ':   /* blank line (space leading) */        case '\t':   /* blank line (tab leading) */            break;        case 'R':   /* Rname <node> <node> [<val>][<mname>][w=<val>][l=<val>] */            INP2R(ckt,tab,current);            break;        case 'C':   /* Cname <node> <node> <val> [IC=<val>] */            INP2C(ckt,tab,current);            break;        case 'L':   /* Lname <node> <node> <val> [IC=<val>] */            INP2L(ckt,tab,current);            break;        case 'G':   /* Gname <node> <node> <node> <node> <val> */            INP2G(ckt,tab,current);            break;        case 'E':   /* Ename <node> <node> <node> <node> <val> */            INP2E(ckt,tab,current);            break;        case 'F':   /* Fname <node> <node> <vname> <val> */            INP2F(ckt,tab,current);            break;        case 'H':   /* Hname <node> <node> <vname> <val> */            INP2H(ckt,tab,current);            break;        case 'D':   /* Dname <node> <node> <model> [<val>] [OFF] [IC=<val>] */            INP2D(ckt,tab,current);            break;        case 'J':   /* Jname <node> <node> <node> <model> [<val>] [OFF]                      *       [IC=<val>,<val>] */            INP2J(ckt,tab,current);            break;        case 'Z':   /* Zname <node> <node> <node> <model> [<val>] [OFF]                      *       [IC=<val>,<val>] */            INP2Z(ckt,tab,current);            break;        case 'M':   /* Mname <node> <node> <node> <node> <model> [L=<val>]                     *       [W=<val>] [AD=<val>] [AS=<val>] [PD=<val>]                     *       [PS=<val>] [NRD=<val>] [NRS=<val>] [OFF]                      *       [IC=<val>,<val>,<val>] */            INP2M(ckt,tab,current);            break;	case 'O':   /* Oname <node> <node> <node> <node> <model>	                      *       [IC=<val>,<val>,<val>,<val>] */	    INP2O(ckt,tab,current);	    break;        case 'V':   /* Vname <node> <node> [ [DC] <val>] [AC [<val> [<val> ] ] ]                     *       [<tran function>] */            INP2V(ckt,tab,current);            break;        case 'I':   /* Iname <node> <node> [ [DC] <val>] [AC [<val> [<val> ] ] ]                     *       [<tran function>] */            INP2I(ckt,tab,current);            break;        case 'Q':   /* Qname <node> <node> <node> [<node>] <model> [<val>] [OFF]                     *       [IC=<val>,<val>] */            INP2Q(ckt,tab,current,gnode);            break;        case 'T':   /* Tname <node> <node> <node> <node> [TD=<val>]                      *       [F=<val> [NL=<val>]][IC=<val>,<val>,<val>,<val>] */            INP2T(ckt,tab,current);            break;        case 'S':   /* Sname <node> <node> <node> <node> [<modname>] [IC] */            INP2S(ckt,tab,current);            break;        case 'W':   /* Wname <node> <node> <vctrl> [<modname>] [IC] */            /* CURRENT CONTROLLED SWITCH */            INP2W(ckt,tab,current);            break;        case 'U':   /* Uname <node> <node> <model> [l=<val>] [n=<val>] */            INP2U(ckt,tab,current);            break;        case 'K':   /* Kname Lname Lname <val> */            INP2K(ckt,tab,current);            break;        case '*':   /* *<anything> - a comment - ignore */            break;        case 'B':   /* Bname <node> <node> [V=expr] [I=expr] */            /* Arbitrary source. */            INP2B(ckt,tab,current);            break;        case '.':   /* .<something> Many possibilities */            if (INP2dot(ckt,tab,current,task,gnode)) goto end;            break;	case 0:	    break;        default:            /* the un-implemented device */            LITERR(" unknown device type - error \n")            break;        }    }end:    return;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -