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

📄 inpdpar.c

📁 spice中支持多层次元件模型仿真的可单独运行的插件源码
💻 C
字号:
/**********Copyright 1990 Regents of the University of California.  All rights reserved.Author: 1985 Thomas L. Quarles**********/    /*     * INPdevParse()     *     *  parse a given input according to the standard rules - look     *  for the parameters given in the parmlists, In addition,      *  an optional leading numeric parameter is handled.     */#include "spice.h"#include <stdio.h>#include "util.h"#include "ifsim.h"#include "inpdefs.h"#include "iferrmsg.h"#include "cpdefs.h"#include "fteext.h"#include "suffix.h"char *INPdevParse(line,ckt,dev,fast,leading,waslead,tab)    char **line;    /* the line to parse */    GENERIC *ckt;/* the circuit this device is a member of */    int dev;        /* the device type code to the device being parsed */    GENERIC *fast;    /* direct pointer to device being parsed */    double *leading;/* the optional leading numeric parameter */    int *waslead;   /* flag - 1 if leading double given, 0 otherwise */    INPtables *tab;{    int error;  /* int to store evaluate error return codes in */    char *parm;    char *errbuf;    int i;    IFvalue *val;    /* check for leading value */    *waslead = 0;    *leading = INPevaluate(line,&error,1);    if(error == 0) { /* found a good leading number */        *waslead = 1;    } else *leading=0.0;    while (**line != (char) 0) {        error = INPgetTok(line,&parm,1);	if (!*parm)	    continue;        if(error) return(INPerror(error));        for(i=0;i<(*(*(ft_sim->devices)[dev]).numInstanceParms);i++) {            if(strcmp(parm,                    ((*(ft_sim->devices)[dev]).instanceParms[i].keyword)) ==0) {                val = INPgetValue(ckt,line,                        ((*(ft_sim->devices)[dev]).instanceParms[i].dataType),                        tab);        if (!val)            return (INPerror(E_PARMVAL));                error = (*(ft_sim->setInstanceParm))(ckt,fast,                        (*(ft_sim->devices)[dev]).instanceParms[i].id,                        val,(IFvalue*)NULL);                if(error) return(INPerror(error));                break;            }        }        if(i==(*(*(ft_sim->devices)[dev]).numInstanceParms)) {            errbuf = MALLOC(strlen(parm)+25);            (void)sprintf(errbuf," unknown parameter (%s) \n",parm);            return(errbuf);        }        FREE(parm);    }    return((char *)NULL);}

⌨️ 快捷键说明

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