Added some code to debug breakpoints.
This commit is contained in:
parent
5df827ae4e
commit
f72fbdce74
|
|
@ -14,7 +14,8 @@ Author: 1985 Thomas L. Quarles
|
|||
#include "ifsim.h"
|
||||
#include "sperror.h"
|
||||
|
||||
|
||||
/* define to enable breakpoint trace code */
|
||||
/ *#define TRACE_BREAKPOINT */
|
||||
|
||||
int
|
||||
CKTsetBreak(CKTcircuit *ckt, double time)
|
||||
|
|
@ -22,6 +23,10 @@ CKTsetBreak(CKTcircuit *ckt, double time)
|
|||
double *tmp;
|
||||
int i,j;
|
||||
|
||||
#ifdef TRACE_BREAKPOINT
|
||||
printf("[t:%e] \t want breakpoint for t = %e\n", ckt->CKTtime, time);
|
||||
#endif
|
||||
|
||||
if(ckt->CKTtime > time) {
|
||||
(*(SPfrontEnd->IFerror))(ERR_PANIC,"breakpoint in the past - HELP!",
|
||||
(IFuid *)NULL);
|
||||
|
|
@ -31,11 +36,20 @@ CKTsetBreak(CKTcircuit *ckt, double time)
|
|||
if(*(ckt->CKTbreaks+i)>time) { /* passed */
|
||||
if((*(ckt->CKTbreaks+i)-time) <= ckt->CKTminBreak) {
|
||||
/* very close together - take earlier point */
|
||||
#ifdef TRACE_BREAKPOINT
|
||||
printf("[t:%e] \t %e replaces %e\n", ckt->CKTtime, time,
|
||||
*(ckt->CKTbreaks+i));
|
||||
CKTbreakDump(ckt);
|
||||
#endif
|
||||
*(ckt->CKTbreaks+i) = time;
|
||||
return(OK);
|
||||
}
|
||||
if(time-*(ckt->CKTbreaks+i-1) <= ckt->CKTminBreak) {
|
||||
/* very close together, but after, so skip */
|
||||
#ifdef TRACE_BREAKPOINT
|
||||
printf("[t:%e] \t %e skipped\n", ckt->CKTtime, time);
|
||||
CKTbreakDump(ckt);
|
||||
#endif
|
||||
return(OK);
|
||||
}
|
||||
/* fits in middle - new array & insert */
|
||||
|
|
@ -45,18 +59,27 @@ CKTsetBreak(CKTcircuit *ckt, double time)
|
|||
*(tmp+j) = *(ckt->CKTbreaks+j);
|
||||
}
|
||||
*(tmp+i)=time;
|
||||
#ifdef TRACE_BREAKPOINT
|
||||
printf("[t:%e] \t %e added\n", ckt->CKTtime, time);
|
||||
CKTbreakDump(ckt);
|
||||
#endif
|
||||
for(j=i;j<ckt->CKTbreakSize;j++) {
|
||||
*(tmp+j+1) = *(ckt->CKTbreaks+j);
|
||||
}
|
||||
FREE(ckt->CKTbreaks);
|
||||
ckt->CKTbreakSize++;
|
||||
ckt->CKTbreaks=tmp;
|
||||
|
||||
return(OK);
|
||||
}
|
||||
}
|
||||
/* never found it - beyond end of time - extend out idea of time */
|
||||
if(time-ckt->CKTbreaks[ckt->CKTbreakSize-1]<=ckt->CKTminBreak) {
|
||||
/* very close tegether - keep earlier, throw out new point */
|
||||
#ifdef TRACE_BREAKPOINT
|
||||
printf("[t:%e] \t %e skipped (at the end)\n", ckt->CKTtime, time);
|
||||
CKTbreakDump(ckt);
|
||||
#endif
|
||||
return(OK);
|
||||
}
|
||||
/* fits at end - grow array & add on */
|
||||
|
|
@ -64,5 +87,9 @@ CKTsetBreak(CKTcircuit *ckt, double time)
|
|||
(ckt->CKTbreakSize+1)*sizeof(double));
|
||||
ckt->CKTbreakSize++;
|
||||
ckt->CKTbreaks[ckt->CKTbreakSize-1]=time;
|
||||
#ifdef TRACE_BREAKPOINT
|
||||
printf("[t:%e] \t %e added at end\n", ckt->CKTtime, time);
|
||||
CKTbreakDump(ckt);
|
||||
#endif
|
||||
return(OK);
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue