affbe5f5创建于 2025年3月25日历史提交
/**********
Copyright 1991 Regents of the University of California.  All rights reserved.
Author:	1987 Kartikeya Mayaram, U. C. Berkeley CAD Group
Author:	1991 David A. Gates, U. C. Berkeley CAD Group
**********/

#include "ngspice/ngspice.h"
#include "ngspice/gendev.h"
#include "ngspice/macros.h"
#include "ngspice/memory.h"
#include "ngspice/cidersupt.h"

void printCoordInfo(CoordInfo *pFirstCoord)
{
  CoordInfo *pCoord;
  
  for ( pCoord = pFirstCoord; pCoord != NULL;
      pCoord = pCoord->next ) {
    fprintf(stderr, "mesh number=%4d  location=%11.4e\n",
	    pCoord->number, pCoord->location );
  }
}

void killCoordInfo(CoordInfo *pFirstCoord)
{
  CoordInfo *pCoord, *pKill;
  
  for ( pCoord = pFirstCoord; pCoord != NULL; ) {
    pKill = pCoord;
    pCoord = pCoord->next;
    FREE( pKill );
  }
}

void ONEprintDomainInfo(DomainInfo *pFirstDomain)
{
  DomainInfo *pDomain;
  
  for ( pDomain = pFirstDomain; pDomain != NULL;
       pDomain = pDomain->next ) {
    fprintf( stderr, "domain id=%4d  mat=%4d  ixLo=%4d  ixHi=%4d\n",
	    pDomain->id, pDomain->material, pDomain->ixLo, pDomain->ixHi );
  }
}

void TWOprintDomainInfo(DomainInfo *pFirstDomain)
{
  DomainInfo *pDomain;
  
  for ( pDomain = pFirstDomain; pDomain != NULL;
       pDomain = pDomain->next ) {
    fprintf( stderr,
	    "domain id=%4d  mat=%4d  ixLo=%4d  ixHi=%4d  iyLo=%4d  iyHi=%4d\n",
	    pDomain->id, pDomain->material,
	    pDomain->ixLo, pDomain->ixHi,
	    pDomain->iyLo, pDomain->iyHi);
  }
}

void killDomainInfo(DomainInfo *pFirstDomain)
{
  DomainInfo *pDomain, *pKill;
  
  for ( pDomain = pFirstDomain; pDomain != NULL; ) {
    pKill = pDomain;
    pDomain = pDomain->next;
    FREE( pKill );
  }
}

void ONEprintBoundaryInfo(BoundaryInfo *pFirstBoundary)
{
  BoundaryInfo *pBoundary;
  
  for ( pBoundary = pFirstBoundary; pBoundary != NULL;
       pBoundary = pBoundary->next ) {
    fprintf( stderr,
	    "boundary dom=%4d  nbr=%4d  ixLo=%4d  ixHi=%4d\n",
	    pBoundary->domain, pBoundary->neighbor,
	    pBoundary->ixLo, pBoundary->ixHi );
  }
}

void TWOprintBoundaryInfo(BoundaryInfo *pFirstBoundary)
{
  BoundaryInfo *pBoundary;
  
  for ( pBoundary = pFirstBoundary; pBoundary != NULL;
       pBoundary = pBoundary->next ) {
    fprintf( stderr,
	    "boundary dom=%4d  nbr=%4d  ixLo=%4d  ixHi=%4d  iyLo=%4d  iyHi=%4d\n",
	    pBoundary->domain, pBoundary->neighbor,
	    pBoundary->ixLo, pBoundary->ixHi,
	    pBoundary->iyLo, pBoundary->iyHi);
  }
}

void killBoundaryInfo(BoundaryInfo *pFirstBoundary)
{
  BoundaryInfo *pBoundary, *pKill;
  
  for ( pBoundary = pFirstBoundary; pBoundary != NULL; ) {
    pKill = pBoundary;
    pBoundary = pBoundary->next;
    FREE( pKill );
  }
}

void TWOprintElectrodeInfo(ElectrodeInfo *pFirstElectrode)
{
  ElectrodeInfo *pElectrode;
  
  for ( pElectrode = pFirstElectrode; pElectrode != NULL;
       pElectrode = pElectrode->next ) {
    fprintf( stderr,
	"electrode id=%4d  ixLo=%4d  ixHi=%4d  iyLo=%4d  iyHi=%4d\n",
	pElectrode->id, pElectrode->ixLo, pElectrode->ixHi,
	pElectrode->iyLo, pElectrode->iyHi );
  }
}

void killElectrodeInfo(ElectrodeInfo *pFirstElectrode)
{
  ElectrodeInfo *pElectrode, *pKill;
  
  for ( pElectrode = pFirstElectrode; pElectrode != NULL; ) {
    pKill = pElectrode;
    pElectrode = pElectrode->next;
    FREE( pKill );
  }
}