From b70e61502044c6739354f2acfcedaa6c45bfbe7a Mon Sep 17 00:00:00 2001 From: Krasilnikov Sergey Date: Sun, 15 Jan 2023 01:17:09 +0300 Subject: [PATCH] replace foreach macro --- qucs-activefilter/filter.cpp | 61 +- qucs-activefilter/transferfuncdialog.cpp | 6 +- qucs/components/EKV26MOS.cpp | 2 +- qucs/components/ampere_ac.cpp | 2 +- qucs/components/bjt.cpp | 6 +- qucs/components/bjtsub.cpp | 2 +- qucs/components/component.cpp | 87 +- qucs/components/diode.cpp | 2 +- qucs/components/ecvs.cpp | 2 +- qucs/components/eqndefined.cpp | 2 +- qucs/components/equation.cpp | 4 +- qucs/components/hic0_full.cpp | 2 +- qucs/components/hicumL0V1p2.cpp | 2 +- qucs/components/hicumL0V1p2g.cpp | 31 +- qucs/components/hicumL0V1p3.cpp | 2 +- qucs/components/iexp.cpp | 2 +- qucs/components/ifile.cpp | 2 +- qucs/components/ipulse.cpp | 2 +- qucs/components/irect.cpp | 2 +- qucs/components/jfet.cpp | 2 +- qucs/components/libcomp.cpp | 8 +- qucs/components/mosfet.cpp | 6 +- qucs/components/mosfet_sub.cpp | 4 +- qucs/components/mutualx.cpp | 2 +- qucs/components/param_sweep.cpp | 2 +- qucs/components/relais.cpp | 2 +- qucs/components/rfedd.cpp | 2 +- qucs/components/rfedd2p.cpp | 2 +- qucs/components/source_ac.cpp | 4 +- qucs/components/sparamfile.cpp | 2 +- qucs/components/spicedialog.cpp | 2 +- qucs/components/spicefile.cpp | 8 +- qucs/components/subcircuit.cpp | 4 +- qucs/components/vccs.cpp | 2 +- qucs/components/vcvs.cpp | 2 +- qucs/components/vexp.cpp | 2 +- qucs/components/vfile.cpp | 2 +- qucs/components/volt_ac.cpp | 2 +- qucs/components/volt_dc.cpp | 2 +- qucs/components/vpulse.cpp | 2 +- qucs/components/vrect.cpp | 2 +- qucs/diagrams/diagram.cpp | 3202 ++++++++++---------- qucs/diagrams/diagramdialog.cpp | 4 +- qucs/diagrams/graph.cpp | 4 +- qucs/diagrams/rect3ddiagram.cpp | 8 +- qucs/diagrams/tabdiagram.cpp | 6 +- qucs/diagrams/timingdiagram.cpp | 10 +- qucs/diagrams/truthdiagram.cpp | 2 +- qucs/dialogs/librarydialog.cpp | 4 +- qucs/dialogs/qucssettingsdialog.cpp | 4 +- qucs/extsimkernels/abstractspicekernel.cpp | 55 +- qucs/extsimkernels/codemodelgen.cpp | 32 +- qucs/extsimkernels/customsimdialog.cpp | 6 +- qucs/extsimkernels/ngspice.cpp | 6 +- qucs/extsimkernels/qucs2spice.cpp | 46 +- qucs/extsimkernels/spicecompat.cpp | 8 +- qucs/extsimkernels/spicecompat.h | 4 +- qucs/extsimkernels/verilogawriter.cpp | 2 +- qucs/extsimkernels/xspice_cmbuilder.cpp | 26 +- qucs/extsimkernels/xspice_cmbuilder.h | 2 +- qucs/extsimkernels/xyce.cpp | 6 +- qucs/imagewriter.cpp | 23 +- qucs/imagewriter.h | 4 +- qucs/main.cpp | 30 +- qucs/mouseactions.cpp | 15 +- qucs/paintings/id_dialog.cpp | 2 +- qucs/qucs.cpp | 60 +- qucs/qucs.h | 2 +- qucs/schematic.cpp | 443 ++- qucs/schematic.h | 10 +- qucs/schematic_element.cpp | 90 +- qucs/schematic_file.cpp | 8 +- qucs/spicecomponents/C_SPICE.cpp | 2 +- qucs/spicecomponents/DIODE_SPICE.cpp | 2 +- qucs/spicecomponents/K_SPICE.cpp | 2 +- qucs/spicecomponents/LTL_SPICE.cpp | 2 +- qucs/spicecomponents/LTRA_SPICE.cpp | 2 +- qucs/spicecomponents/L_SPICE.cpp | 2 +- qucs/spicecomponents/MESFET_SPICE.cpp | 2 +- qucs/spicecomponents/MOS_SPICE.cpp | 2 +- qucs/spicecomponents/NJF_SPICE.cpp | 2 +- qucs/spicecomponents/NMOS_SPICE.cpp | 2 +- qucs/spicecomponents/NPN_SPICE.cpp | 2 +- qucs/spicecomponents/PJF_SPICE.cpp | 2 +- qucs/spicecomponents/PMF_MESFET_SPICE.cpp | 2 +- qucs/spicecomponents/PMOS_SPICE.cpp | 2 +- qucs/spicecomponents/PNP_SPICE.cpp | 2 +- qucs/spicecomponents/R_SPICE.cpp | 2 +- qucs/spicecomponents/S4Q_I.cpp | 2 +- qucs/spicecomponents/S4Q_Ieqndef.cpp | 2 +- qucs/spicecomponents/S4Q_S.cpp | 2 +- qucs/spicecomponents/S4Q_V.cpp | 2 +- qucs/spicecomponents/S4Q_W.cpp | 2 +- qucs/spicecomponents/UDRCTL_SPICE.cpp | 2 +- qucs/spicecomponents/eNL.cpp | 2 +- qucs/spicecomponents/gNL.cpp | 2 +- qucs/spicecomponents/iAmpMod.cpp | 2 +- qucs/spicecomponents/iPWL.cpp | 2 +- qucs/spicecomponents/iTRNOISE.cpp | 2 +- qucs/spicecomponents/isffm.cpp | 2 +- qucs/spicecomponents/sp_func.cpp | 2 +- qucs/spicecomponents/sp_globalpar.cpp | 2 +- qucs/spicecomponents/sp_ic.cpp | 2 +- qucs/spicecomponents/sp_include.cpp | 2 +- qucs/spicecomponents/sp_model.cpp | 2 +- qucs/spicecomponents/sp_nodeset.cpp | 2 +- qucs/spicecomponents/sp_parameter.cpp | 2 +- qucs/spicecomponents/spicegeneric.cpp | 4 +- qucs/spicecomponents/spicelibcomp.cpp | 4 +- qucs/spicecomponents/src_eqndef.cpp | 2 +- qucs/spicecomponents/vAmpMod.cpp | 2 +- qucs/spicecomponents/vPWL.cpp | 2 +- qucs/spicecomponents/vTRNOISE.cpp | 2 +- qucs/spicecomponents/vTRRANDOM.cpp | 2 +- qucs/spicecomponents/volt_ac_SPICE.cpp | 2 +- qucs/spicecomponents/vsffm.cpp | 2 +- qucs/spicecomponents/xsp_cmlib.cpp | 2 +- qucs/spicecomponents/xspicegeneric.cpp | 4 +- qucs/syntax.cpp | 35 +- 119 files changed, 2235 insertions(+), 2309 deletions(-) diff --git a/qucs-activefilter/filter.cpp b/qucs-activefilter/filter.cpp index aeb7c313..c9d719ce 100644 --- a/qucs-activefilter/filter.cpp +++ b/qucs-activefilter/filter.cpp @@ -229,46 +229,48 @@ void Filter::calcFirstOrder() } -void Filter::createPartList(QStringList &lst) -{ - lst< zero; - foreach(zero,Zeros) { - lst< zero: Zeros) { + lst << QString::number(zero.real()) + " + j*" + QString::number(zero.imag()); } } - if ((ftype==Filter::BandPass)||(ftype==Filter::BandStop)) { - lst<<""< pole; - foreach(pole,Poles) { - lst< pole: Poles) { + lst << QString::number(pole.real()) + " + j*" + QString::number(pole.imag()); } - lst<<""; + lst << ""; } void Filter::createFirstOrderComponentsHPF(QString &s,RC_elements stage,int dx) @@ -341,8 +343,7 @@ double Filter::autoscaleCapacitor(double C, QString &suffix) bool Filter::checkRCL() { - RC_elements sec; - foreach (sec,Sections) { + for (auto &sec : Sections) { if (std::isnan(sec.R1)|| std::isnan(sec.R2)|| std::isnan(sec.R3)|| diff --git a/qucs-activefilter/transferfuncdialog.cpp b/qucs-activefilter/transferfuncdialog.cpp index cf948c77..1df17601 100644 --- a/qucs-activefilter/transferfuncdialog.cpp +++ b/qucs-activefilter/transferfuncdialog.cpp @@ -47,10 +47,9 @@ TransferFuncDialog::TransferFuncDialog(QVector &a, QVectorsetFixedWidth(150); if (!a.isEmpty()) { - long double num; int i = a.count()-1; - foreach (num,a) { + for (auto& num : a) { QTableWidgetItem *it = new QTableWidgetItem(QString::number((double)num)); tblA->setItem(i,0,it); i--; @@ -68,10 +67,9 @@ TransferFuncDialog::TransferFuncDialog(QVector &a, QVectorsetFixedWidth(150); if (!b.isEmpty()) { - long double num; int i = b.count()-1; - foreach (num,b) { + for (auto& num :b) { QTableWidgetItem *it = new QTableWidgetItem(QString::number((double)num)); tblB->setItem(i,0,it); i--; diff --git a/qucs/components/EKV26MOS.cpp b/qucs/components/EKV26MOS.cpp index 25a5a40d..f3fa53f9 100644 --- a/qucs/components/EKV26MOS.cpp +++ b/qucs/components/EKV26MOS.cpp @@ -275,7 +275,7 @@ QString EKV26MOS::netlist() QString s = Model+":"+Name; // output all node names - foreach(Port *p1, Ports) + for (Port *p1 : Ports) s += " "+p1->Connection->Name; // node names // output type npn/pnp property diff --git a/qucs/components/ampere_ac.cpp b/qucs/components/ampere_ac.cpp index bf8b4c14..544bd551 100644 --- a/qucs/components/ampere_ac.cpp +++ b/qucs/components/ampere_ac.cpp @@ -80,7 +80,7 @@ Element* Ampere_ac::info(QString& Name, char* &BitmapFile, bool getNewOne) QString Ampere_ac::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/components/bjt.cpp b/qucs/components/bjt.cpp index d3de48c3..40b49394 100644 --- a/qucs/components/bjt.cpp +++ b/qucs/components/bjt.cpp @@ -46,7 +46,7 @@ QString BJT::spice_netlist(bool) QList pin_seq; pin_seq<<1<<0<<2; // Pin sequence: CBE // output all node names - foreach(int pin, pin_seq) { + for (int pin : pin_seq) { QString nam = Ports.at(pin)->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names @@ -123,12 +123,12 @@ QString BJT::netlist() QString s = "BJT:"+Name; // output all node names - foreach(Port *p1, Ports) + for (Port *p1 : Ports) s += " "+p1->Connection->Name; // node names s += " "+Ports.at(1)->Connection->Name; // connect substrate to collector // output all properties - for(Property *p2 = Props.first(); p2 != 0; p2 = Props.next()) + for(Property *p2 = Props.first(); p2 != nullptr; p2 = Props.next()) s += " "+p2->Name+"=\""+p2->Value+"\""; return s + '\n'; diff --git a/qucs/components/bjtsub.cpp b/qucs/components/bjtsub.cpp index 262b23de..ee517587 100644 --- a/qucs/components/bjtsub.cpp +++ b/qucs/components/bjtsub.cpp @@ -204,7 +204,7 @@ QString BJTsub::spice_netlist(bool) QList pin_seq; pin_seq<<1<<0<<2<<3; // Pin sequence: CBE // output all node names - foreach(int pin, pin_seq) { + for (int pin : pin_seq) { QString nam = Ports.at(pin)->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/components/component.cpp b/qucs/components/component.cpp index 25b8595a..b1196f37 100644 --- a/qucs/components/component.cpp +++ b/qucs/components/component.cpp @@ -210,7 +210,7 @@ void Component::paint(ViewPainter *p) a = b = 0; QRect r, t; - foreach(Text *pt, Texts) { + for (Text *pt : Texts) { t.setRect(x, y+b, 0, 0); p->Painter->drawText(t, Qt::AlignLeft|Qt::TextDontClip, pt->s, &r); b += r.height(); @@ -234,26 +234,26 @@ void Component::paint(ViewPainter *p) else { // normal components go here // paint all lines - foreach(qucs::Line *p1, Lines) { + for (qucs::Line *p1 : Lines) { p->Painter->setPen(p1->style); p->drawLine(cx+p1->x1, cy+p1->y1, cx+p1->x2, cy+p1->y2); } // paint all arcs - foreach(qucs::Arc *p3, Arcs) { + for (qucs::Arc *p3 : Arcs) { p->Painter->setPen(p3->style); p->drawArc(cx+p3->x, cy+p3->y, p3->w, p3->h, p3->angle, p3->arclen); } // paint all rectangles - foreach(qucs::Area *pa, Rects) { + for (qucs::Area *pa : Rects) { p->Painter->setPen(pa->Pen); p->Painter->setBrush(pa->Brush); p->drawRect(cx+pa->x, cy+pa->y, pa->w, pa->h); } // paint all ellipses - foreach(qucs::Area *pa, Ellips) { + for (qucs::Area *pa : Ellips) { p->Painter->setPen(pa->Pen); p->Painter->setBrush(pa->Brush); p->drawEllipse(cx+pa->x, cy+pa->y, pa->w, pa->h); @@ -267,7 +267,7 @@ void Component::paint(ViewPainter *p) QTransform wm = p->Painter->worldTransform(); // write all text - foreach(Text *pt, Texts) { + for (Text *pt : Texts) { p->Painter->setWorldTransform( QTransform(pt->mCos, -pt->mSin, pt->mSin, pt->mCos, p->DX + float(cx+pt->x) * p->Scale, @@ -277,13 +277,10 @@ void Component::paint(ViewPainter *p) newFont.setUnderline(pt->under); p->Painter->setFont(newFont); p->Painter->setPen(pt->Color); - if (0) { - p->Painter->drawText(0, 0, 0, 0, Qt::AlignLeft|Qt::TextDontClip, pt->s); - } else { - int w, h; - w = p->drawTextMapped (pt->s, 0, 0, &h); - Q_UNUSED(w); - } + int w, h; + w = p->drawTextMapped(pt->s, 0, 0, &h); + Q_UNUSED(w); + Q_UNUSED(w) } p->Painter->setWorldTransform(wm); p->Painter->setWorldMatrixEnabled(false); @@ -344,7 +341,7 @@ void Component::paintScheme(Schematic *p) a = b = 0; QSize r; - foreach(Text *pt, Texts) { + for (Text *pt : Texts) { r = metrics.size(0, pt->s); b += r.height(); if(a < r.width()) a = r.width(); @@ -365,21 +362,21 @@ void Component::paintScheme(Schematic *p) } // paint all lines - foreach(qucs::Line *p1, Lines) + for(qucs::Line *p1 : Lines) p->PostPaintEvent(_Line,cx+p1->x1, cy+p1->y1, cx+p1->x2, cy+p1->y2); // paint all ports - foreach(Port *p2, Ports) + for (Port *p2 : Ports) if(p2->avail) p->PostPaintEvent(_Ellipse,cx+p2->x-4, cy+p2->y-4, 8, 8); - foreach(qucs::Arc *p3, Arcs) // paint all arcs + for (qucs::Arc *p3 : Arcs) // paint all arcs p->PostPaintEvent(_Arc,cx+p3->x, cy+p3->y, p3->w, p3->h, p3->angle, p3->arclen); - foreach(qucs::Area *pa, Rects) // paint all rectangles + for (qucs::Area *pa : Rects) // paint all rectangles p->PostPaintEvent(_Rect,cx+pa->x, cy+pa->y, pa->w, pa->h); - foreach(qucs::Area *pa, Ellips) // paint all ellipses + for (qucs::Area *pa : Ellips) // paint all ellipses p->PostPaintEvent(_Ellipse,cx+pa->x, cy+pa->y, pa->w, pa->h); } @@ -387,12 +384,12 @@ void Component::paintScheme(Schematic *p) // For output on a printer device. void Component::print(ViewPainter *p, float FontScale) { - foreach(Text *pt, Texts) + for (Text *pt : Texts) pt->Size *= FontScale; paint(p); - foreach(Text *pt, Texts) + for (Text *pt : Texts) pt->Size /= FontScale; } @@ -407,7 +404,7 @@ void Component::rotate() int tmp, dx, dy; // rotate all lines - foreach(qucs::Line *p1, Lines) { + for (qucs::Line *p1 : Lines) { tmp = -p1->x1; p1->x1 = p1->y1; p1->y1 = tmp; @@ -417,14 +414,14 @@ void Component::rotate() } // rotate all ports - foreach(Port *p2, Ports) { + for (Port *p2 : Ports) { tmp = -p2->x; p2->x = p2->y; p2->y = tmp; } // rotate all arcs - foreach(qucs::Arc *p3, Arcs) { + for (qucs::Arc *p3 : Arcs) { tmp = -p3->x; p3->x = p3->y; p3->y = tmp - p3->w; @@ -436,7 +433,7 @@ void Component::rotate() } // rotate all rectangles - foreach(qucs::Area *pa, Rects) { + for(qucs::Area *pa : Rects) { tmp = -pa->x; pa->x = pa->y; pa->y = tmp - pa->w; @@ -446,7 +443,7 @@ void Component::rotate() } // rotate all ellipses - foreach(qucs::Area *pa, Ellips) { + for (qucs::Area *pa : Ellips) { tmp = -pa->x; pa->x = pa->y; pa->y = tmp - pa->w; @@ -457,7 +454,7 @@ void Component::rotate() // rotate all text float ftmp; - foreach(Text *pt, Texts) { + for (Text *pt : Texts) { tmp = -pt->x; pt->x = pt->y; pt->y = tmp; @@ -507,17 +504,17 @@ void Component::mirrorX() if(Ports.count() < 1) return; // do not rotate components without ports // mirror all lines - foreach(qucs::Line *p1, Lines) { + for (qucs::Line *p1 : Lines) { p1->y1 = -p1->y1; p1->y2 = -p1->y2; } // mirror all ports - foreach(Port *p2, Ports) + for (Port *p2 : Ports) p2->y = -p2->y; // mirror all arcs - foreach(qucs::Arc *p3, Arcs) { + for (qucs::Arc *p3 : Arcs) { p3->y = -p3->y - p3->h; if(p3->angle > 16*180) p3->angle -= 16*360; p3->angle = -p3->angle; // mirror @@ -526,16 +523,16 @@ void Component::mirrorX() } // mirror all rectangles - foreach(qucs::Area *pa, Rects) + for (qucs::Area *pa : Rects) pa->y = -pa->y - pa->h; // mirror all ellipses - foreach(qucs::Area *pa, Ellips) + for (qucs::Area *pa : Ellips) pa->y = -pa->y - pa->h; QFont f = QucsSettings.font; // mirror all text - foreach(Text *pt, Texts) { + for (Text *pt : Texts) { f.setPointSizeF(pt->Size); // use the screen-compatible metric QFontMetrics smallMetrics(f, 0); @@ -546,11 +543,11 @@ void Component::mirrorX() int tmp = y1; y1 = -y2; y2 = -tmp; // mirror boundings // use the screen-compatible metric - QFontMetrics metrics(QucsSettings.font, 0); // get size of text + QFontMetrics metrics(QucsSettings.font, nullptr); // get size of text int dy = 0; if(showName) dy = metrics.lineSpacing(); // for "Name" - for(Property *pp = Props.first(); pp != 0; pp = Props.next()) + for(Property *pp = Props.first(); pp != nullptr; pp = Props.next()) if(pp->display) dy += metrics.lineSpacing(); if((tx > x1) && (tx < x2)) ty = -ty-dy; // mirror text position else ty = y1+ty+y2; @@ -570,34 +567,34 @@ void Component::mirrorY() if(Ports.count() < 1) return; // do not rotate components without ports // mirror all lines - foreach(qucs::Line *p1, Lines) { + for (qucs::Line *p1 : Lines) { p1->x1 = -p1->x1; p1->x2 = -p1->x2; } // mirror all ports - foreach(Port *p2, Ports) + for (Port *p2 : Ports) p2->x = -p2->x; // mirror all arcs - foreach(qucs::Arc *p3, Arcs) { + for (qucs::Arc *p3 : Arcs) { p3->x = -p3->x - p3->w; p3->angle = 16*180 - p3->angle - p3->arclen; // mirror if(p3->angle < 0) p3->angle += 16*360; // angle has to be > 0 } // mirror all rectangles - foreach(qucs::Area *pa, Rects) + for (qucs::Area *pa : Rects) pa->x = -pa->x - pa->w; // mirror all ellipses - foreach(qucs::Area *pa, Ellips) + for (qucs::Area *pa : Ellips) pa->x = -pa->x - pa->w; int tmp; QFont f = QucsSettings.font; // mirror all text - foreach(Text *pt, Texts) { + for (Text *pt : Texts) { f.setPointSizeF(pt->Size); // use the screen-compatible metric QFontMetrics smallMetrics(f, 0); @@ -633,11 +630,11 @@ QString Component::netlist() QString s = Model+":"+Name; // output all node names - foreach(Port *p1, Ports) + for (Port *p1 : Ports) s += " "+p1->Connection->Name; // node names // output all properties - for(Property *p2 = Props.first(); p2 != 0; p2 = Props.next()) + for(Property *p2 = Props.first(); p2 != nullptr; p2 = Props.next()) if(p2->Name != "Symbol") s += " "+p2->Name+"=\""+p2->Value+"\""; @@ -1460,7 +1457,7 @@ QString GateComponent::netlist() QString s = Model+":"+Name; // output all node names - foreach(Port *pp, Ports) + for (Port *pp : Ports) s += " "+pp->Connection->Name; // node names // output all properties @@ -1475,7 +1472,7 @@ QString GateComponent::netlist() QString GateComponent::spice_netlist(bool isXyce) { - if (isXyce) return QString(""); + if (isXyce) return {""}; QString s = SpiceModel + Name; QString tmp_model = "model_" + Name; diff --git a/qucs/components/diode.cpp b/qucs/components/diode.cpp index ae900d00..7bb9ab5b 100644 --- a/qucs/components/diode.cpp +++ b/qucs/components/diode.cpp @@ -104,7 +104,7 @@ QString Diode::spice_netlist(bool isXyce) QList pin_seq; pin_seq<<1<<0; // Pin sequence: CBE // output all node names - foreach(int pin, pin_seq) { + for (int pin : pin_seq) { QString nam = Ports.at(pin)->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/components/ecvs.cpp b/qucs/components/ecvs.cpp index 9d053071..7204c33b 100644 --- a/qucs/components/ecvs.cpp +++ b/qucs/components/ecvs.cpp @@ -95,7 +95,7 @@ QString ecvs::netlist() QString s = Model+":"+Name; // output all node names - foreach(Port *p1, Ports) + for (Port *p1 : Ports) s += " "+p1->Connection->Name; // node names // output all properties diff --git a/qucs/components/eqndefined.cpp b/qucs/components/eqndefined.cpp index 2711d125..2ad2297f 100644 --- a/qucs/components/eqndefined.cpp +++ b/qucs/components/eqndefined.cpp @@ -84,7 +84,7 @@ QString EqnDefined::netlist() QString e = "\n"; // output all node names - foreach(Port *p1, Ports) + for (Port *p1 : Ports) s += " "+p1->Connection->Name; // node names // output all properties diff --git a/qucs/components/equation.cpp b/qucs/components/equation.cpp index 87fc6a05..a9d60ccb 100644 --- a/qucs/components/equation.cpp +++ b/qucs/components/equation.cpp @@ -250,7 +250,7 @@ void Equation::getNgnutmegVars(QStringList &vars, QStringList &sims) } } } - foreach (QString var,vars) { + for (const QString& var : vars) { QString sim; int idx = vars.indexOf(var); if (idx>=0) sim = sims.at(idx); @@ -258,7 +258,7 @@ void Equation::getNgnutmegVars(QStringList &vars, QStringList &sims) QString eqn = getProperty(var)->Value; QStringList tokens; spicecompat::splitEqn(eqn,tokens); - foreach (QString tok,tokens) { + for (const QString& tok : tokens) { int idx1 = vars.indexOf(tok); if ((idx1>=0)&&(sims[idx1]!="all")) sims[idx]=sims[idx1]; } diff --git a/qucs/components/hic0_full.cpp b/qucs/components/hic0_full.cpp index e1fdee79..b0606318 100644 --- a/qucs/components/hic0_full.cpp +++ b/qucs/components/hic0_full.cpp @@ -347,7 +347,7 @@ QString hic0_full::netlist() QString s = "hic0_full:"+Name; // output all node names - foreach(Port *pp, Ports) + for (Port *pp : Ports) s += " "+pp->Connection->Name; // node names // output type npn/pnp property diff --git a/qucs/components/hicumL0V1p2.cpp b/qucs/components/hicumL0V1p2.cpp index 0a6a20ff..f98d59cd 100644 --- a/qucs/components/hicumL0V1p2.cpp +++ b/qucs/components/hicumL0V1p2.cpp @@ -365,7 +365,7 @@ QString hicumL0V1p2::netlist() QString s = "hicumL0V1p2:"+Name; // output all node names - foreach(Port *pp, Ports) + for (Port *pp : Ports) s += " "+pp->Connection->Name; // node names // output type npn/pnp property diff --git a/qucs/components/hicumL0V1p2g.cpp b/qucs/components/hicumL0V1p2g.cpp index 8c29b196..369e2d32 100644 --- a/qucs/components/hicumL0V1p2g.cpp +++ b/qucs/components/hicumL0V1p2g.cpp @@ -371,24 +371,23 @@ void hicumL0V1p2g::createSymbol() x2 = 30; y2 = 30; } -QString hicumL0V1p2g::netlist() -{ - QString s = "hicumL0V1p2g:"+Name; +QString hicumL0V1p2g::netlist() { + QString s = "hicumL0V1p2g:" + Name; - // output all node names - foreach(Port *pp, Ports) - s += " "+pp->Connection->Name; // node names + // output all node names + for (Port *pp: Ports) + s += " " + pp->Connection->Name; // node names - // output type npn/pnp property - Property *p2 = Props.first(); - if(p2->Value == "npn") - s += " npn=\"1\""; - else - s += " pnp=\"1\""; + // output type npn/pnp property + Property *p2 = Props.first(); + if (p2->Value == "npn") + s += " npn=\"1\""; + else + s += " pnp=\"1\""; - // output all remaining properties - for(p2 = Props.next(); p2 != 0; p2 = Props.next()) - s += " "+p2->Name+"=\""+p2->Value+"\""; + // output all remaining properties + for (p2 = Props.next(); p2 != 0; p2 = Props.next()) + s += " " + p2->Name + "=\"" + p2->Value + "\""; - return s + '\n'; + return s + '\n'; } diff --git a/qucs/components/hicumL0V1p3.cpp b/qucs/components/hicumL0V1p3.cpp index 11b2cbc9..f7476d9d 100644 --- a/qucs/components/hicumL0V1p3.cpp +++ b/qucs/components/hicumL0V1p3.cpp @@ -383,7 +383,7 @@ QString hicumL0V1p3::netlist() QString s = "hicumL0V1p3:"+Name; // output all node names - foreach(Port *pp, Ports) + for (Port *pp : Ports) s += " "+pp->Connection->Name; // node names // output type npn/pnp property diff --git a/qucs/components/iexp.cpp b/qucs/components/iexp.cpp index 6db2afa0..0e9c0c00 100644 --- a/qucs/components/iexp.cpp +++ b/qucs/components/iexp.cpp @@ -97,7 +97,7 @@ Element* iExp::info(QString& Name, char* &BitmapFile, bool getNewOne) QString iExp::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/components/ifile.cpp b/qucs/components/ifile.cpp index c7a058d3..02533836 100644 --- a/qucs/components/ifile.cpp +++ b/qucs/components/ifile.cpp @@ -93,7 +93,7 @@ QString iFile::netlist() QString s = Model+":"+Name; // output all node names - foreach(Port *p1, Ports) + for (Port *p1 : Ports) s += " "+p1->Connection->Name; // node names // output file properties diff --git a/qucs/components/ipulse.cpp b/qucs/components/ipulse.cpp index b2ad919d..08d67336 100644 --- a/qucs/components/ipulse.cpp +++ b/qucs/components/ipulse.cpp @@ -91,7 +91,7 @@ QString iPulse::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/components/irect.cpp b/qucs/components/irect.cpp index e57fea16..22e3cd75 100644 --- a/qucs/components/irect.cpp +++ b/qucs/components/irect.cpp @@ -81,7 +81,7 @@ QString iRect::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/components/jfet.cpp b/qucs/components/jfet.cpp index 0883c49d..51651785 100644 --- a/qucs/components/jfet.cpp +++ b/qucs/components/jfet.cpp @@ -97,7 +97,7 @@ QString JFET::spice_netlist(bool isXyce) QList pin_seq; pin_seq<<1<<0<<2; // Pin sequence: DGS // output all node names - foreach(int pin, pin_seq) { + for (int pin : pin_seq) { QString nam = Ports.at(pin)->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/components/libcomp.cpp b/qucs/components/libcomp.cpp index 3eb2c9cf..17593461 100644 --- a/qucs/components/libcomp.cpp +++ b/qucs/components/libcomp.cpp @@ -317,7 +317,7 @@ QString LibComp::netlist() QString s = "Sub:"+Name; // output as subcircuit // output all node names - foreach(Port *p1, Ports) + for (Port *p1 : Ports) s += " "+p1->Connection->Name; // node names // output property @@ -369,7 +369,7 @@ QString LibComp::vhdlCode(int) QString LibComp::spice_netlist(bool) { QString s = SpiceModel + Name + " 0 "; // connect ground of subckt to circuit ground - foreach(Port *p1, Ports) + for (Port *p1 : Ports) s += " "+p1->Connection->Name; // node names s += " " + createType(); @@ -391,7 +391,7 @@ QStringList LibComp::getAttachedIFS() int r = loadSection("Spice",content,&includes,&attach); if (r<0) return ifs_lst; - foreach(QString file,attach) { + for (const QString& file : attach) { if (file.endsWith(".ifs")) ifs_lst.append(getSubcircuitFile()+'/'+file); } return ifs_lst; @@ -405,7 +405,7 @@ QStringList LibComp::getAttachedMOD() int r = loadSection("Spice",content,&includes,&attach); if (r<0) return mod_lst; - foreach(QString file,attach) { + for (const QString& file : attach) { if (file.endsWith(".mod")) mod_lst.append(getSubcircuitFile()+'/'+file); } return mod_lst; diff --git a/qucs/components/mosfet.cpp b/qucs/components/mosfet.cpp index a95bc554..fb05813a 100644 --- a/qucs/components/mosfet.cpp +++ b/qucs/components/mosfet.cpp @@ -127,7 +127,7 @@ QString MOSFET::netlist() QString s = "MOSFET:"+Name; // output all node names - foreach(Port *p1, Ports) + for (Port *p1 : Ports) s += " "+p1->Connection->Name; // node names s += " "+Ports.at(2)->Connection->Name; // connect substrate to source @@ -144,7 +144,7 @@ QString MOSFET::spice_netlist(bool isXyce) QList pin_seq; pin_seq<<1<<0<<2<<2; // Pin sequence: DGS; coonect substrate to source // output all node names - foreach(int pin, pin_seq) { + for (int pin : pin_seq) { QString nam = Ports.at(pin)->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names @@ -164,7 +164,7 @@ QString MOSFET::spice_netlist(bool isXyce) QStringList check_defaults_list; QString unit; check_defaults_list<<"Nsub"<<"Nss"; - foreach (QString parnam,check_defaults_list) { // Check some parameters for default value (zero) + for (const QString& parnam : check_defaults_list) { // Check some parameters for default value (zero) double val,fac; // And reduce parameter list misc::str2num(getProperty(parnam)->Value,val,unit,fac); if ((val *= fac)==0.0) { diff --git a/qucs/components/mosfet_sub.cpp b/qucs/components/mosfet_sub.cpp index 4623047f..e24c0343 100644 --- a/qucs/components/mosfet_sub.cpp +++ b/qucs/components/mosfet_sub.cpp @@ -151,7 +151,7 @@ QString MOSFET_sub::spice_netlist(bool isXyce) QList pin_seq; pin_seq<<1<<0<<2<<3; // Pin sequence: DGS // output all node names - foreach(int pin, pin_seq) { + for (int pin : pin_seq) { QString nam = Ports.at(pin)->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names @@ -170,7 +170,7 @@ QString MOSFET_sub::spice_netlist(bool isXyce) QStringList check_defaults_list; QString unit; check_defaults_list<<"Nsub"<<"Nss"; - foreach (QString parnam,check_defaults_list) { // Check some parameters for default value (zero) + for (const QString& parnam : check_defaults_list) { // Check some parameters for default value (zero) double val,fac; // And reduce parameter list misc::str2num(getProperty(parnam)->Value,val,unit,fac); if ((val *= fac)==0.0) { diff --git a/qucs/components/mutualx.cpp b/qucs/components/mutualx.cpp index fb4ef94a..1fda4d19 100644 --- a/qucs/components/mutualx.cpp +++ b/qucs/components/mutualx.cpp @@ -77,7 +77,7 @@ QString MutualX::netlist() QString s = Model + ":" + Name; // output all node names - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { s += " "+p1->Connection->Name; // node names } diff --git a/qucs/components/param_sweep.cpp b/qucs/components/param_sweep.cpp index b62a2ab9..35209821 100644 --- a/qucs/components/param_sweep.cpp +++ b/qucs/components/param_sweep.cpp @@ -268,7 +268,7 @@ QString Param_Sweep::netlist() QString s = Model+":"+Name; // output all node names - foreach(Port *p1, Ports) + for (Port *p1 : Ports) s += " "+p1->Connection->Name; // node names // output all properties diff --git a/qucs/components/relais.cpp b/qucs/components/relais.cpp index ad84ca5f..2a82c68a 100644 --- a/qucs/components/relais.cpp +++ b/qucs/components/relais.cpp @@ -90,7 +90,7 @@ QString Relais::spice_netlist(bool isXyce) QList seq; // nodes sequence seq<<1<<2<<0<<3; // output all node names - foreach(int i, seq) { + for (int i : seq) { QString nam = Ports.at(i)->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/components/rfedd.cpp b/qucs/components/rfedd.cpp index 61075e69..3f3ffcc1 100644 --- a/qucs/components/rfedd.cpp +++ b/qucs/components/rfedd.cpp @@ -84,7 +84,7 @@ QString RFedd::netlist() QString n, p; // output all node names - foreach(Port *p1, Ports) + for (Port *p1 : Ports) s += " "+p1->Connection->Name; // node names // output all properties diff --git a/qucs/components/rfedd2p.cpp b/qucs/components/rfedd2p.cpp index 50ee83a7..bf4998d8 100644 --- a/qucs/components/rfedd2p.cpp +++ b/qucs/components/rfedd2p.cpp @@ -81,7 +81,7 @@ QString RFedd2P::netlist() QString n, p; // output all node names - foreach(Port *p1, Ports) + for (Port *p1 : Ports) s += " "+p1->Connection->Name; // node names // output all properties diff --git a/qucs/components/source_ac.cpp b/qucs/components/source_ac.cpp index 5b7951e1..655c102f 100644 --- a/qucs/components/source_ac.cpp +++ b/qucs/components/source_ac.cpp @@ -95,7 +95,7 @@ Element* Source_ac::info(QString& Name, char* &BitmapFile, bool getNewOne) QString Source_ac::ngspice_netlist() { QString s = QString("V%1").arg(Name); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names @@ -117,7 +117,7 @@ QString Source_ac::ngspice_netlist() QString Source_ac::xyce_netlist() { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/components/sparamfile.cpp b/qucs/components/sparamfile.cpp index ff747fe6..5bfebe7d 100644 --- a/qucs/components/sparamfile.cpp +++ b/qucs/components/sparamfile.cpp @@ -112,7 +112,7 @@ QString SParamFile::netlist() QString s = Model+":"+Name; // output all node names - foreach(Port *p1, Ports) + for (Port *p1 : Ports) s += " "+p1->Connection->Name; // node names // output all properties diff --git a/qucs/components/spicedialog.cpp b/qucs/components/spicedialog.cpp index b0d6e0ce..534af3e8 100644 --- a/qucs/components/spicedialog.cpp +++ b/qucs/components/spicedialog.cpp @@ -473,7 +473,7 @@ bool SpiceDialog::loadSpiceNetList(const QString& s) { PortsList->clear(); QStringList ports = pp->Value.split(','); - foreach(QString port, ports) { + for (const QString& port : ports) { PortsList->addItem(port); } } diff --git a/qucs/components/spicefile.cpp b/qucs/components/spicefile.cpp index 540b7b15..809861b2 100644 --- a/qucs/components/spicefile.cpp +++ b/qucs/components/spicefile.cpp @@ -157,7 +157,7 @@ QString SpiceFile::netlist() return QString(""); // no ports, no subcircuit instance QString s = "Sub:"+Name; // SPICE netlist is subcircuit - foreach(Port *pp, Ports) + for (Port *pp : Ports) s += " "+pp->Connection->Name; // output all node names QString f = misc::properFileName(Props.first()->Value); @@ -583,8 +583,8 @@ void SpiceFile::slotExited() QString SpiceFile::spice_netlist(bool) { QStringList ports_lst = Props.at(1)->Value.split(","); - for (QStringList::iterator it = ports_lst.begin();it != ports_lst.end();it++) { - if (it->startsWith("_net")) (*it).remove(0,4); + for (auto & it : ports_lst) { + if (it.startsWith("_net")) it.remove(0,4); } QStringList nod_lst; QString compname = spicecompat::getSubcktName(getSubcircuitFile()); @@ -598,7 +598,7 @@ QString SpiceFile::spice_netlist(bool) QString s = spicecompat::check_refdes(Name,SpiceModel); //foreach(Port *p1, Ports) { - foreach(int i,seq) { + for (int i : seq) { s += " "+Ports.at(i)->Connection->Name; // node names } diff --git a/qucs/components/subcircuit.cpp b/qucs/components/subcircuit.cpp index 92760749..687af636 100644 --- a/qucs/components/subcircuit.cpp +++ b/qucs/components/subcircuit.cpp @@ -209,7 +209,7 @@ QString Subcircuit::netlist() QString s = Model+":"+Name; // output all node names - foreach(Port *p1, Ports) + for (Port *p1 : Ports) s += " "+p1->Connection->Name; // node names // type for subcircuit @@ -227,7 +227,7 @@ QString Subcircuit::spice_netlist(bool) QString s; QString f = misc::properFileName(Props.first()->Value); s += spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+nam; // node names diff --git a/qucs/components/vccs.cpp b/qucs/components/vccs.cpp index 08c72eb2..253b974b 100644 --- a/qucs/components/vccs.cpp +++ b/qucs/components/vccs.cpp @@ -114,7 +114,7 @@ QString VCCS::spice_netlist(bool) QList seq; // nodes sequence seq<<1<<2<<0<<3; // output all node names - foreach(int i, seq) { + for (int i : seq) { QString nam = Ports.at(i)->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/components/vcvs.cpp b/qucs/components/vcvs.cpp index 474753ea..b96cace6 100644 --- a/qucs/components/vcvs.cpp +++ b/qucs/components/vcvs.cpp @@ -113,7 +113,7 @@ QString VCVS::spice_netlist(bool) QList seq; // nodes sequence seq<<1<<2<<0<<3; // output all node names - foreach(int i, seq) { + for (int i : seq) { QString nam = Ports.at(i)->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/components/vexp.cpp b/qucs/components/vexp.cpp index e32ec174..9aafdd9a 100644 --- a/qucs/components/vexp.cpp +++ b/qucs/components/vexp.cpp @@ -98,7 +98,7 @@ Element* vExp::info(QString& Name, char* &BitmapFile, bool getNewOne) QString vExp::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/components/vfile.cpp b/qucs/components/vfile.cpp index 107f737a..c70e72dd 100644 --- a/qucs/components/vfile.cpp +++ b/qucs/components/vfile.cpp @@ -95,7 +95,7 @@ QString vFile::netlist() QString s = Model+":"+Name; // output all node names - foreach(Port *p1, Ports) + for (Port *p1 : Ports) s += " "+p1->Connection->Name; // node names // output file properties diff --git a/qucs/components/volt_ac.cpp b/qucs/components/volt_ac.cpp index 6cfc5e69..f09ec3df 100644 --- a/qucs/components/volt_ac.cpp +++ b/qucs/components/volt_ac.cpp @@ -79,7 +79,7 @@ Element* Volt_ac::info(QString& Name, char* &BitmapFile, bool getNewOne) QString Volt_ac::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/components/volt_dc.cpp b/qucs/components/volt_dc.cpp index e797fcb6..d3cf703f 100644 --- a/qucs/components/volt_dc.cpp +++ b/qucs/components/volt_dc.cpp @@ -63,7 +63,7 @@ Component* Volt_dc::newOne() QString Volt_dc::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/components/vpulse.cpp b/qucs/components/vpulse.cpp index 8b336bbc..b0efe9ac 100644 --- a/qucs/components/vpulse.cpp +++ b/qucs/components/vpulse.cpp @@ -77,7 +77,7 @@ QString vPulse::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/components/vrect.cpp b/qucs/components/vrect.cpp index c9ced4a3..53150d9f 100644 --- a/qucs/components/vrect.cpp +++ b/qucs/components/vrect.cpp @@ -76,7 +76,7 @@ QString vRect::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/diagrams/diagram.cpp b/qucs/diagrams/diagram.cpp index 4d0fc431..ef033ad0 100644 --- a/qucs/diagrams/diagram.cpp +++ b/qucs/diagrams/diagram.cpp @@ -25,14 +25,19 @@ */ #if HAVE_CONFIG_H + # include + #endif + #include #include #include + #if HAVE_IEEEFP_H # include #endif + #include #include "diagram.h" @@ -50,87 +55,84 @@ #include #include -Diagram::Diagram(int _cx, int _cy) -{ - cx = _cx; cy = _cy; - - // x1, x2, y1, y2 are the selectable boundings of the diagram, but these - // are the real boundings. They are set in "createAxisLabels()". - Bounding_x1 = Bounding_x2 = Bounding_y1 = Bounding_y2 = 0; +Diagram::Diagram(int _cx, int _cy) { + cx = _cx; + cy = _cy; - xAxis.numGraphs = yAxis.numGraphs = zAxis.numGraphs = 0; - xAxis.min = xAxis.low = - yAxis.min = yAxis.low = zAxis.min = zAxis.low = 0.0; - xAxis.max = xAxis.up = - yAxis.max = yAxis.up = zAxis.max = zAxis.up = 1.0; - xAxis.GridOn = yAxis.GridOn = true; - zAxis.GridOn = false; - xAxis.log = yAxis.log = zAxis.log = false; - xAxis.Units = Axis::NoUnits; - yAxis.Units = Axis::NoUnits; - zAxis.Units = Axis::NoUnits; + // x1, x2, y1, y2 are the selectable boundings of the diagram, but these + // are the real boundings. They are set in "createAxisLabels()". + Bounding_x1 = Bounding_x2 = Bounding_y1 = Bounding_y2 = 0; - xAxis.limit_min = yAxis.limit_min = zAxis.limit_min = 0.0; - xAxis.limit_max = yAxis.limit_max = zAxis.limit_max = 1.0; - xAxis.step = yAxis.step = zAxis.step = 1.0; - xAxis.autoScale = yAxis.autoScale = zAxis.autoScale = true; + xAxis.numGraphs = yAxis.numGraphs = zAxis.numGraphs = 0; + xAxis.min = xAxis.low = + yAxis.min = yAxis.low = zAxis.min = zAxis.low = 0.0; + xAxis.max = xAxis.up = + yAxis.max = yAxis.up = zAxis.max = zAxis.up = 1.0; + xAxis.GridOn = yAxis.GridOn = true; + zAxis.GridOn = false; + xAxis.log = yAxis.log = zAxis.log = false; + xAxis.Units = Axis::NoUnits; + yAxis.Units = Axis::NoUnits; + zAxis.Units = Axis::NoUnits; - rotX = 315; // for 3D diagram - rotY = 0; - rotZ = 225; - hideLines = true; // hide invisible lines + xAxis.limit_min = yAxis.limit_min = zAxis.limit_min = 0.0; + xAxis.limit_max = yAxis.limit_max = zAxis.limit_max = 1.0; + xAxis.step = yAxis.step = zAxis.step = 1.0; + xAxis.autoScale = yAxis.autoScale = zAxis.autoScale = true; - engineeringNotation = false; + rotX = 315; // for 3D diagram + rotY = 0; + rotZ = 225; + hideLines = true; // hide invisible lines - Type = isDiagram; - isSelected = false; - GridPen = QPen(Qt::lightGray,0); + engineeringNotation = false; + + Type = isDiagram; + isSelected = false; + GridPen = QPen(Qt::lightGray, 0); } -Diagram::~Diagram() -{ +Diagram::~Diagram() { } /*! Paint function for most diagrams (cartesian, smith, polar, ...) */ -void Diagram::paint(ViewPainter *p) -{ +void Diagram::paint(ViewPainter *p) { paintDiagram(p); paintMarkers(p); } -void Diagram::paintDiagram(ViewPainter *p) -{ +void Diagram::paintDiagram(ViewPainter *p) { // paint all lines - foreach(qucs::Line *pl, Lines) { - p->Painter->setPen(pl->style); - p->drawLine(cx+pl->x1, cy-pl->y1, cx+pl->x2, cy-pl->y2); + for (qucs::Line *pl: Lines) { + p->Painter->setPen(pl->style); + p->drawLine(cx + pl->x1, cy - pl->y1, cx + pl->x2, cy - pl->y2); } // paint all arcs (1 pixel larger to compensate for strange circle method) - foreach(qucs::Arc *pa, Arcs) { - p->Painter->setPen(pa->style); - p->drawArc(cx+pa->x, cy-pa->y, pa->w, pa->h, pa->angle, pa->arclen); + for (qucs::Arc *pa: Arcs) { + p->Painter->setPen(pa->style); + p->drawArc(cx + pa->x, cy - pa->y, pa->w, pa->h, pa->angle, pa->arclen); } // draw all graphs - foreach(Graph *pg, Graphs) - pg->paint(p, cx, cy); + for (Graph *pg: Graphs) + pg->paint(p, cx, cy); // keep track of painter state p->Painter->save(); // write whole text (axis label inclusively) QTransform wm = p->Painter->worldTransform(); - foreach(Text *pt, Texts) { - p->Painter->setWorldTransform( - QTransform(pt->mCos, -pt->mSin, pt->mSin, pt->mCos, - p->DX + float(cx+pt->x) * p->Scale, - p->DY + float(cy-pt->y) * p->Scale)); + for (Text *pt: Texts) { + p->Painter->setWorldTransform( + QTransform(pt->mCos, -pt->mSin, pt->mSin, pt->mCos, + p->DX + float(cx + pt->x) * p->Scale, + p->DY + float(cy - pt->y) * p->Scale)); - p->Painter->setPen(pt->Color); - p->Painter->drawText(0, 0, pt->s); + p->Painter->setPen(pt->Color); + p->Painter->drawText(0, 0, pt->s); } p->Painter->setWorldTransform(wm); p->Painter->setWorldMatrixEnabled(false); @@ -139,380 +141,363 @@ void Diagram::paintDiagram(ViewPainter *p) p->Painter->restore(); - if(isSelected) { - int x_, y_; - float fx_, fy_; - p->map(cx, cy-y2, x_, y_); - fx_ = float(x2)*p->Scale + 10; - fy_ = float(y2)*p->Scale + 10; + if (isSelected) { + int x_, y_; + float fx_, fy_; + p->map(cx, cy - y2, x_, y_); + fx_ = float(x2) * p->Scale + 10; + fy_ = float(y2) * p->Scale + 10; - p->Painter->setPen(QPen(Qt::darkGray,3)); - p->Painter->drawRect(x_-5, y_-5, TO_INT(fx_), TO_INT(fy_)); - p->Painter->setPen(QPen(Qt::darkRed,2)); - p->drawResizeRect(cx, cy-y2); // markers for changing the size - p->drawResizeRect(cx, cy); - p->drawResizeRect(cx+x2, cy-y2); - p->drawResizeRect(cx+x2, cy); + p->Painter->setPen(QPen(Qt::darkGray, 3)); + p->Painter->drawRect(x_ - 5, y_ - 5, TO_INT(fx_), TO_INT(fy_)); + p->Painter->setPen(QPen(Qt::darkRed, 2)); + p->drawResizeRect(cx, cy - y2); // markers for changing the size + p->drawResizeRect(cx, cy); + p->drawResizeRect(cx + x2, cy - y2); + p->drawResizeRect(cx + x2, cy); } } -void Diagram::paintMarkers(ViewPainter *p, bool paintAll) -{ +void Diagram::paintMarkers(ViewPainter *p, bool paintAll) { // draw markers last, so they are at the top of painting layers - foreach(Graph *pg, Graphs) - foreach(Marker *pm, pg->Markers) - if ((pm->Type & 1)||paintAll) pm->paint(p, cx, cy); + for (Graph *pg: Graphs) + for (Marker *pm: pg->Markers) + if (paintAll || (pm->Type & 1)) { + pm->paint(p, cx, cy); + } } // ------------------------------------------------------------ -void Diagram::paintScheme(Schematic *p) -{ - p->PostPaintEvent(_Rect, cx, cy-y2, x2, y2); +void Diagram::paintScheme(Schematic *p) { + p->PostPaintEvent(_Rect, cx, cy - y2, x2, y2); } /*! Put axis labels into the text list. */ -void Diagram::createAxisLabels() -{ - int x, y, w, wmax = 0; - QString Str; - // get size of text using the screen-compatible metric - QFontMetrics metrics(QucsSettings.font, 0); - int LineSpacing = metrics.lineSpacing(); +void Diagram::createAxisLabels() { + int x, y, w, wmax = 0; + QString Str; + // get size of text using the screen-compatible metric + QFontMetrics metrics(QucsSettings.font, 0); + int LineSpacing = metrics.lineSpacing(); - x = (x2>>1); - y = -y1; - if(xAxis.Label.isEmpty()) { - // write all x labels ---------------------------------------- - foreach(Graph *pg, Graphs) { - DataX const *pD = pg->axis(0); - if(!pD) continue; - y -= LineSpacing; - if(Name[0] != 'C') { // locus curve ? - w = metrics.boundingRect(pD->Var).width() >> 1; - if(w > wmax) wmax = w; - Texts.append(new Text(x-w, y, pD->Var, pg->Color, 12.0)); - } - else { - w = metrics.boundingRect("real("+pg->Var+")").width() >> 1; - if(w > wmax) wmax = w; - Texts.append(new Text(x-w, y, "real("+pg->Var+")", - pg->Color, 12.0)); - } + x = (x2 >> 1); + y = -y1; + if (xAxis.Label.isEmpty()) { + // write all x labels ---------------------------------------- + for (Graph *pg: Graphs) { + DataX const *pD = pg->axis(0); + if (!pD) continue; + y -= LineSpacing; + if (Name[0] != 'C') { // locus curve ? + w = metrics.boundingRect(pD->Var).width() >> 1; + if (w > wmax) wmax = w; + Texts.append(new Text(x - w, y, pD->Var, pg->Color, 12.0)); + } else { + w = metrics.boundingRect("real(" + pg->Var + ")").width() >> 1; + if (w > wmax) wmax = w; + Texts.append(new Text(x - w, y, "real(" + pg->Var + ")", + pg->Color, 12.0)); + } + } + } else { + y -= LineSpacing; + encode_String(xAxis.Label, Str); + w = metrics.boundingRect(Str).width() >> 1; + if (w > wmax) wmax = w; + Texts.append(new Text(x - w, y, Str, Qt::black, 12.0)); } - } - else { - y -= LineSpacing; - encode_String(xAxis.Label, Str); - w = metrics.boundingRect(Str).width() >> 1; - if(w > wmax) wmax = w; - Texts.append(new Text(x-w, y, Str, Qt::black, 12.0)); - } - Bounding_y2 = 0; - Bounding_y1 = y - LineSpacing; - Bounding_x2 = wmax - (x2 >> 1); - if(Bounding_x2 < 0) Bounding_x2 = 0; - Bounding_x1 = Bounding_x2; + Bounding_y2 = 0; + Bounding_y1 = y - LineSpacing; + Bounding_x2 = wmax - (x2 >> 1); + if (Bounding_x2 < 0) Bounding_x2 = 0; + Bounding_x1 = Bounding_x2; - wmax = 0; - x = -x1; - y = y2>>1; - if(yAxis.Label.isEmpty()) { - // draw left y-label for all graphs ------------------------------ + wmax = 0; + x = -x1; + y = y2 >> 1; + if (yAxis.Label.isEmpty()) { + // draw left y-label for all graphs ------------------------------ - // strip simulator name and simulation name like ngspice/ac. - // if all graphs are from the same simulator and simulation - QStringList used_kernels, used_simulations; - for (const auto pg : Graphs) { - QString kernel_name = pg->Var.section('/',0,0); - QString var_name = pg->Var; - auto p = var_name.indexOf('/'); - var_name = var_name.mid(p+1); - QString sim_name = var_name.section('.',0,0); - if (!used_simulations.contains(sim_name)) - used_simulations.append(sim_name); - if (!used_kernels.contains(kernel_name)) - used_kernels.append(kernel_name); - } - - foreach(Graph *pg, Graphs) { - if(pg->yAxisNo != 0) continue; - if(pg->cPointsY) { - QString var_name = pg->Var; - if (!QucsSettings.fullTraceName) { - if (used_kernels.count() == 1) { + // strip simulator name and simulation name like ngspice/ac. + // if all graphs are from the same simulator and simulation + QStringList used_kernels, used_simulations; + for (const auto pg: Graphs) { + QString kernel_name = pg->Var.section('/', 0, 0); + QString var_name = pg->Var; auto p = var_name.indexOf('/'); - var_name = var_name.mid(p+1); + var_name = var_name.mid(p + 1); + QString sim_name = var_name.section('.', 0, 0); + if (!used_simulations.contains(sim_name)) + used_simulations.append(sim_name); + if (!used_kernels.contains(kernel_name)) + used_kernels.append(kernel_name); } - if (used_simulations.count() == 1) { - auto p = var_name.indexOf('.'); - var_name = var_name.mid(p+1); + + for (Graph *pg: Graphs) { + if (pg->yAxisNo != 0) continue; + if (pg->cPointsY) { + QString var_name = pg->Var; + if (!QucsSettings.fullTraceName) { + if (used_kernels.count() == 1) { + auto p = var_name.indexOf('/'); + var_name = var_name.mid(p + 1); + } + if (used_simulations.count() == 1) { + auto p = var_name.indexOf('.'); + var_name = var_name.mid(p + 1); + } + } + if (Name[0] != 'C') { // location curve ? + w = metrics.boundingRect(var_name).width() >> 1; + if (w > wmax) wmax = w; + Texts.append(new Text(x, y - w, var_name, pg->Color, 12.0, 0.0, 1.0)); + } else { + w = metrics.boundingRect("imag(" + var_name + ")").width() >> 1; + if (w > wmax) wmax = w; + Texts.append(new Text(x, y - w, "imag(" + var_name + ")", + pg->Color, 12.0, 0.0, 1.0)); + } + } else { // if no data => + w = metrics.boundingRect(pg->Var + INVALID_STR).width() >> 1; + if (w > wmax) wmax = w; + Texts.append(new Text(x, y - w, pg->Var + INVALID_STR, + pg->Color, 12.0, 0.0, 1.0)); + } + x -= LineSpacing; } + } else { + encode_String(yAxis.Label, Str); + w = metrics.boundingRect(Str).width() >> 1; + if (w > wmax) wmax = w; + Texts.append(new Text(x, y - w, Str, Qt::black, 12.0, 0.0, 1.0)); + x -= LineSpacing; } - if(Name[0] != 'C') { // location curve ? - w = metrics.boundingRect(var_name).width() >> 1; - if(w > wmax) wmax = w; - Texts.append(new Text(x, y-w, var_name, pg->Color, 12.0, 0.0, 1.0)); - } - else { - w = metrics.boundingRect("imag("+var_name+")").width() >> 1; - if(w > wmax) wmax = w; - Texts.append(new Text(x, y-w, "imag("+var_name+")", - pg->Color, 12.0, 0.0, 1.0)); - } - } - else { // if no data => - w = metrics.boundingRect(pg->Var+INVALID_STR).width() >> 1; - if(w > wmax) wmax = w; - Texts.append(new Text(x, y-w, pg->Var+INVALID_STR, - pg->Color, 12.0, 0.0, 1.0)); - } - x -= LineSpacing; - } - } - else { - encode_String(yAxis.Label, Str); - w = metrics.boundingRect(Str).width() >> 1; - if(w > wmax) wmax = w; - Texts.append(new Text(x, y-w, Str, Qt::black, 12.0, 0.0, 1.0)); - x -= LineSpacing; - } - if(Bounding_x1 < -x) Bounding_x1 = -x; + if (Bounding_x1 < -x) Bounding_x1 = -x; - x = x3; - y = y2>>1; - if(zAxis.Label.isEmpty()) { - // draw right y-label for all graphs ------------------------------ - foreach(Graph *pg, Graphs) { - if(pg->yAxisNo != 1) continue; - if(pg->cPointsY) { - if(Name[0] != 'C') { // location curve ? - w = metrics.boundingRect(pg->Var).width() >> 1; - if(w > wmax) wmax = w; - Texts.append(new Text(x, y+w, pg->Var, - pg->Color, 12.0, 0.0, -1.0)); - } - else { - w = metrics.boundingRect("imag("+pg->Var+")").width() >> 1; - if(w > wmax) wmax = w; - Texts.append(new Text(x, y+w, "imag("+pg->Var+")", - pg->Color, 12.0, 0.0, -1.0)); - } - } - else { // if no data => - w = metrics.boundingRect(pg->Var+INVALID_STR).width() >> 1; - if(w > wmax) wmax = w; - Texts.append(new Text(x, y+w, pg->Var+INVALID_STR, - pg->Color, 12.0, 0.0, -1.0)); - } - x += LineSpacing; + x = x3; + y = y2 >> 1; + if (zAxis.Label.isEmpty()) { + // draw right y-label for all graphs ------------------------------ + for (Graph *pg: Graphs) { + if (pg->yAxisNo != 1) continue; + if (pg->cPointsY) { + if (Name[0] != 'C') { // location curve ? + w = metrics.boundingRect(pg->Var).width() >> 1; + if (w > wmax) wmax = w; + Texts.append(new Text(x, y + w, pg->Var, + pg->Color, 12.0, 0.0, -1.0)); + } else { + w = metrics.boundingRect("imag(" + pg->Var + ")").width() >> 1; + if (w > wmax) wmax = w; + Texts.append(new Text(x, y + w, "imag(" + pg->Var + ")", + pg->Color, 12.0, 0.0, -1.0)); + } + } else { // if no data => + w = metrics.boundingRect(pg->Var + INVALID_STR).width() >> 1; + if (w > wmax) wmax = w; + Texts.append(new Text(x, y + w, pg->Var + INVALID_STR, + pg->Color, 12.0, 0.0, -1.0)); + } + x += LineSpacing; + } + } else { + encode_String(zAxis.Label, Str); + w = metrics.boundingRect(Str).width() >> 1; + if (w > wmax) wmax = w; + Texts.append(new Text(x, y + w, Str, Qt::black, 12.0, 0.0, -1.0)); } - } - else { - encode_String(zAxis.Label, Str); - w = metrics.boundingRect(Str).width() >> 1; - if(w > wmax) wmax = w; - Texts.append(new Text(x, y+w, Str, Qt::black, 12.0, 0.0, -1.0)); - } - x -= x2; - if(Bounding_x2 < x) Bounding_x2 = x; + x -= x2; + if (Bounding_x2 < x) Bounding_x2 = x; - wmax -= y2 >> 1; - if(wmax > 0) { - Bounding_y2 = wmax; - wmax *= -1; - if(wmax < Bounding_y1) Bounding_y1 = wmax; - } + wmax -= y2 >> 1; + if (wmax > 0) { + Bounding_y2 = wmax; + wmax *= -1; + if (wmax < Bounding_y1) Bounding_y1 = wmax; + } } // ------------------------------------------------------------ -int Diagram::regionCode(float x, float y) const -{ - int code=0; // code for clipping - if(x < 0.0) - code |= 1; - else if(x > float(x2)) // compare as float to avoid integer overflow - code |= 2; +int Diagram::regionCode(float x, float y) const { + int code = 0; // code for clipping + if (x < 0.0) + code |= 1; + else if (x > float(x2)) // compare as float to avoid integer overflow + code |= 2; - if(y < 0.0) - code |= 4; - else if(y > float(y2)) // compare as float to avoid integer overflow - code |= 8; + if (y < 0.0) + code |= 4; + else if (y > float(y2)) // compare as float to avoid integer overflow + code |= 8; - return code; + return code; } // ------------------------------------------------------------ // Is virtual. This one is for round diagrams only. -bool Diagram::insideDiagram(float x, float y) const -{ - float R = float(x2)/2.0 + 1.0; // +1 seems better (graph sometimes little outside) - x -= R; - y -= R; - return ((x*x + y*y) <= R*R); +bool Diagram::insideDiagram(float x, float y) const { + float R = float(x2) / 2.0 + 1.0; // +1 seems better (graph sometimes little outside) + x -= R; + y -= R; + return ((x * x + y * y) <= R * R); } /*! (try to) set a Marker to a diagram */ -Marker* Diagram::setMarker(int x, int y) -{ - if(getSelected(x, y)) { - // test all graphs of the diagram - foreach(Graph *pg,Graphs) { - int n = pg->getSelected(x-cx, cy-y); // sic! - if(n >= 0) { - assert(pg->parentDiagram() == this); - Marker *pm = new Marker(pg, n, x-cx, y-cy); - pg->Markers.append(pm); - return pm; - } +Marker *Diagram::setMarker(int x, int y) { + if (getSelected(x, y)) { + // test all graphs of the diagram + for (Graph *pg: Graphs) { + int n = pg->getSelected(x - cx, cy - y); // sic! + if (n >= 0) { + assert(pg->parentDiagram() == this); + Marker *pm = new Marker(pg, n, x - cx, y - cy); + pg->Markers.append(pm); + return pm; + } + } } - } - return NULL; + return nullptr; } /*! Cohen-Sutherland clipping algorithm */ -void Diagram::rectClip(Graph::iterator &p) const -{ - int code, z=0; - float x=0, y=0, dx, dy; - float x_1 = (p-2)->getScrX(), y_1 = (p-2)->getScrY(); - float x_2 = (p-1)->getScrX(), y_2 = (p-1)->getScrY(); +void Diagram::rectClip(Graph::iterator &p) const { + int code, z = 0; + float x = 0, y = 0, dx, dy; + float x_1 = (p - 2)->getScrX(), y_1 = (p - 2)->getScrY(); + float x_2 = (p - 1)->getScrX(), y_2 = (p - 1)->getScrY(); - int code1 = regionCode(x_1, y_1); - int code2 = regionCode(x_2, y_2); - if((code1 | code2) == 0) return; // line completely inside ? + int code1 = regionCode(x_1, y_1); + int code2 = regionCode(x_2, y_2); + if ((code1 | code2) == 0) return; // line completely inside ? - if(code1 != 0) if((p-3)->isPt()) { - p++; - (p-3)->setStrokeEnd(); - } - if(code1 & code2) // line not visible at all ? - goto endWithHidden; + if (code1 != 0) + if ((p - 3)->isPt()) { + p++; + (p - 3)->setStrokeEnd(); + } + if (code1 & code2) // line not visible at all ? + goto endWithHidden; - if(code2 != 0) { - p->setStrokeEnd(); - (p+1)->setScr(x_2, y_2); - z += 2; - } - - - for(;;) { - if((code1 | code2) == 0) break; // line completely inside ? - - if(code1) code = code1; - else code = code2; - - dx = x_2 - x_1; // dx and dy never equals zero ! - dy = y_2 - y_1; - if(code & 1) { - y = y_1 - dy * x_1 / dx; - x = 0.0; - } - else if(code & 2) { - y = y_1 + dy * (x2-x_1) / dx; - x = float(x2); - } - else if(code & 4) { - x = x_1 - dx * y_1 / dy; - y = 0.0; - } - else if(code & 8) { - x = x_1 + dx * (y2-y_1) / dy; - y = float(y2); + if (code2 != 0) { + p->setStrokeEnd(); + (p + 1)->setScr(x_2, y_2); + z += 2; } - if(code == code1) { - x_1 = x; - y_1 = y; - code1 = regionCode(x, y); - } - else { - x_2 = x; - y_2 = y; - code2 = regionCode(x, y); - } - if(code1 & code2) - goto endWithHidden; // line not visible at all ? - } - (p-2)->setScr(x_1, y_1); - (p-1)->setScr(x_2, y_2); - p += z; - return; + for (;;) { + if ((code1 | code2) == 0) break; // line completely inside ? -endWithHidden: - (p-2)->setScr(x_2, y_2); + if (code1) code = code1; + else code = code2; + + dx = x_2 - x_1; // dx and dy never equals zero ! + dy = y_2 - y_1; + if (code & 1) { + y = y_1 - dy * x_1 / dx; + x = 0.0; + } else if (code & 2) { + y = y_1 + dy * (x2 - x_1) / dx; + x = float(x2); + } else if (code & 4) { + x = x_1 - dx * y_1 / dy; + y = 0.0; + } else if (code & 8) { + x = x_1 + dx * (y2 - y_1) / dy; + y = float(y2); + } + + if (code == code1) { + x_1 = x; + y_1 = y; + code1 = regionCode(x, y); + } else { + x_2 = x; + y_2 = y; + code2 = regionCode(x, y); + } + if (code1 & code2) + goto endWithHidden; // line not visible at all ? + } + + (p - 2)->setScr(x_1, y_1); + (p - 1)->setScr(x_2, y_2); + p += z; + return; + + endWithHidden: + (p - 2)->setScr(x_2, y_2); p -= 1; } /*! Clipping for round diagrams (smith, polar, ...) */ -void Diagram::clip(Graph::iterator &p) const -{ - float R = float(x2) / 2.0; - float x_1 = (p-2)->getScrX() - R, y_1 = (p-2)->getScrY() - R; - float x_2 = (p-1)->getScrX() - R, y_2 = (p-1)->getScrY() - R; +void Diagram::clip(Graph::iterator &p) const { + float R = float(x2) / 2.0; + float x_1 = (p - 2)->getScrX() - R, y_1 = (p - 2)->getScrY() - R; + float x_2 = (p - 1)->getScrX() - R, y_2 = (p - 1)->getScrY() - R; - float dt1 = R*R; // square of radius - float dt2 = dt1 - x_2*x_2 - y_2*y_2; - dt1 -= x_1*x_1 + y_1*y_1; + float dt1 = R * R; // square of radius + float dt2 = dt1 - x_2 * x_2 - y_2 * y_2; + dt1 -= x_1 * x_1 + y_1 * y_1; - if(dt1 >= 0.0) if(dt2 >= 0.0) return; // line completely inside ? + if (dt1 >= 0.0) if (dt2 >= 0.0) return; // line completely inside ? - if(dt1 < 0.0) if((p-3)->isPt()) { // is there already a line end flag ? - p++; - (p-3)->setStrokeEnd(); - } + if (dt1 < 0.0) + if ((p - 3)->isPt()) { // is there already a line end flag ? + p++; + (p - 3)->setStrokeEnd(); + } - float x = x_1-x_2; - float y = y_1-y_2; - float C = x_1*x + y_1*y; - float D = x*x + y*y; - float F = C*C + dt1*D; + float x = x_1 - x_2; + float y = y_1 - y_2; + float C = x_1 * x + y_1 * y; + float D = x * x + y * y; + float F = C * C + dt1 * D; - x_1 += R; - y_1 += R; - x_2 += R; - y_2 += R; - if(F <= 0.0) { // line not visible at all ? - (p-2)->setScr(x_2, y_2); - p -= 1; - return; - } + x_1 += R; + y_1 += R; + x_2 += R; + y_2 += R; + if (F <= 0.0) { // line not visible at all ? + (p - 2)->setScr(x_2, y_2); + p -= 1; + return; + } - int code = 0; - R = sqrt(F); - dt1 = C - R; - if((dt1 > 0.0) && (dt1 < D)) { // intersection outside start/end point ? - (p-2)->setScr(x_1 - x*dt1 / D, y_1 - y*dt1 / D); - code |= 1; - } - else { - (p-2)->setScr(x_1, y_1); - } + int code = 0; + R = sqrt(F); + dt1 = C - R; + if ((dt1 > 0.0) && (dt1 < D)) { // intersection outside start/end point ? + (p - 2)->setScr(x_1 - x * dt1 / D, y_1 - y * dt1 / D); + code |= 1; + } else { + (p - 2)->setScr(x_1, y_1); + } - dt2 = C + R; - if((dt2 > 0.0) && (dt2 < D)) { // intersection outside start/end point ? - (p-1)->setScr(x_1 - x*dt2 / D, y_1 - y*dt2 / D); - p->setStrokeEnd(); - p += 2; - code |= 2; - } - (p-1)->setScr(x_2, y_2); + dt2 = C + R; + if ((dt2 > 0.0) && (dt2 < D)) { // intersection outside start/end point ? + (p - 1)->setScr(x_1 - x * dt2 / D, y_1 - y * dt2 / D); + p->setStrokeEnd(); + p += 2; + code |= 2; + } + (p - 1)->setScr(x_2, y_2); - if(code == 0) { // intersections both lie outside ? - (p-2)->setScr(x_2, y_2); - --p; - } + if (code == 0) { // intersections both lie outside ? + (p - 2)->setScr(x_2, y_2); + --p; + } } @@ -520,298 +505,298 @@ void Diagram::clip(Graph::iterator &p) const // ------------------------------------------------------------ // g->Points must already be empty!!! // is this a Graph Member? -void Diagram::calcData(Graph *g) -{ - double *px; - double *pz = g->cPointsY; - if(!pz) return; - if(g->numAxes() < 1) return; +void Diagram::calcData(Graph *g) { + double *px; + double *pz = g->cPointsY; + if (!pz) return; + if (g->numAxes() < 1) return; - int i, z, Counter=2; - int Size = ((2*(g->count(0)) + 1) * g->countY) + 10; - - if(xAxis.autoScale) if(yAxis.autoScale) if(zAxis.autoScale) - Counter = -50000; + int i, z, Counter = 2; + int Size = ((2 * (g->count(0)) + 1) * g->countY) + 10; - double Dummy = 0.0; // not used - double *py = &Dummy; + if (xAxis.autoScale) + if (yAxis.autoScale) + if (zAxis.autoScale) + Counter = -50000; - g->resizeScrPoints(Size); - auto p = g->begin(); - auto p_end = g->begin(); - p_end += Size - 9; // limit of buffer - p->setStrokeEnd(); - ++p; - assert(p!=g->end()); + double Dummy = 0.0; // not used + double *py = &Dummy; - Axis *pa; - if(g->yAxisNo == 0) pa = &yAxis; - else pa = &zAxis; + g->resizeScrPoints(Size); + auto p = g->begin(); + auto p_end = g->begin(); + p_end += Size - 9; // limit of buffer + p->setStrokeEnd(); + ++p; + assert(p != g->end()); - switch(g->Style) { - case GRAPHSTYLE_SOLID: // ***** solid line **************************** - case GRAPHSTYLE_DASH: - case GRAPHSTYLE_DOT: - case GRAPHSTYLE_LONGDASH: + Axis *pa; + if (g->yAxisNo == 0) pa = &yAxis; + else pa = &zAxis; - for(i=g->countY; i>0; i--) { // every branch of curves - px = g->axis(0)->Points; - calcCoordinateP(px, pz, py, p, pa); - ++px; - pz += 2; - ++p; - for(z=g->axis(0)->count-1; z>0; z--) { // every point - FIT_MEMORY_SIZE; // need to enlarge memory block ? - calcCoordinateP(px, pz, py, p, pa); - ++px; - pz += 2; - ++p; - if(Counter >= 2) // clipping only if an axis is manual - clip(p); - } - if((p-3)->isStrokeEnd() && !(p-3)->isBranchEnd()) - p -= 3; // no single point after "no stroke" - else if((p-2)->isBranchEnd() && !(p-1)->isGraphEnd()) { - if((!(p-1)->isPt())) - --p; // erase last hidden point - } - (p++)->setBranchEnd(); - } + switch (g->Style) { + case GRAPHSTYLE_SOLID: // ***** solid line **************************** + case GRAPHSTYLE_DASH: + case GRAPHSTYLE_DOT: + case GRAPHSTYLE_LONGDASH: - p->setGraphEnd(); + for (i = g->countY; i > 0; i--) { // every branch of curves + px = g->axis(0)->Points; + calcCoordinateP(px, pz, py, p, pa); + ++px; + pz += 2; + ++p; + for (z = g->axis(0)->count - 1; z > 0; z--) { // every point + FIT_MEMORY_SIZE; // need to enlarge memory block ? + calcCoordinateP(px, pz, py, p, pa); + ++px; + pz += 2; + ++p; + if (Counter >= 2) // clipping only if an axis is manual + clip(p); + } + if ((p - 3)->isStrokeEnd() && !(p - 3)->isBranchEnd()) + p -= 3; // no single point after "no stroke" + else if ((p - 2)->isBranchEnd() && !(p - 1)->isGraphEnd()) { + if ((!(p - 1)->isPt())) + --p; // erase last hidden point + } + (p++)->setBranchEnd(); + } + + p->setGraphEnd(); /*z = p-g->Points+1; p = g->Points; qDebug("\n****** p=%p", p); for(int zz=0; zzcountY; i>0; i--) { // every branch of curves - px = g->axis(0)->Points; - for(z=g->axis(0)->count; z>0; z--) { // every point - calcCoordinateP(px, pz, py, p, pa); - ++px; - pz += 2; - if(insideDiagramP(p)) // within diagram ? - ++p; - } - (p++)->setBranchEnd(); - assert(p!=g->end()); - } - (p++)->setGraphEnd(); + default: // symbol (e.g. star) at each point ********************** + for (i = g->countY; i > 0; i--) { // every branch of curves + px = g->axis(0)->Points; + for (z = g->axis(0)->count; z > 0; z--) { // every point + calcCoordinateP(px, pz, py, p, pa); + ++px; + pz += 2; + if (insideDiagramP(p)) // within diagram ? + ++p; + } + (p++)->setBranchEnd(); + assert(p != g->end()); + } + (p++)->setGraphEnd(); /*qDebug("\n******"); for(int zz=0; zz<60; zz+=2) qDebug("c: %d/%d", *(g->Points+zz), *(g->Points+zz+1));*/ - return; - } + return; + } - // unreachable + // unreachable } // ------------------------------------------------------- -void Diagram::Bounding(int& _x1, int& _y1, int& _x2, int& _y2) -{ - _x1 = cx - Bounding_x1; - _y1 = cy - y2 - Bounding_y2; - _x2 = cx + x2 + Bounding_x2; - _y2 = cy - Bounding_y1; +void Diagram::Bounding(int &_x1, int &_y1, int &_x2, int &_y2) { + _x1 = cx - Bounding_x1; + _y1 = cy - y2 - Bounding_y2; + _x2 = cx + x2 + Bounding_x2; + _y2 = cy - Bounding_y1; } // ------------------------------------------------------- -bool Diagram::getSelected(int x_, int y_) -{ - if(x_ >= cx-x1) if(x_ <= cx+x3) if(y_ >= cy-y2) if(y_ <= cy+y1) - return true; +bool Diagram::getSelected(int x_, int y_) { + if (x_ >= cx - x1) + if (x_ <= cx + x3) + if (y_ >= cy - y2) + if (y_ <= cy + y1) + return true; - return false; + return false; } /*! Checks if the resize area was clicked. If so return "true" and sets x1/y1 and x2/y2 to the border coordinates to draw a rectangle. */ -bool Diagram::resizeTouched(float fX, float fY, float len) -{ - float fCX = float(cx), fCY = float(cy); - float fX2 = float(cx+x2), fY2 = float(cy-y2); - if(fX < fCX-len) return false; - if(fX > fX2+len) return false; - if(fY < fY2-len) return false; - if(fY > fCY+len) return false; +bool Diagram::resizeTouched(float fX, float fY, float len) { + float fCX = float(cx), fCY = float(cy); + float fX2 = float(cx + x2), fY2 = float(cy - y2); + if (fX < fCX - len) return false; + if (fX > fX2 + len) return false; + if (fY < fY2 - len) return false; + if (fY > fCY + len) return false; - State = 0; - if(fX < fCX+len) State = 1; - else if(fX <= fX2-len) return false; - if(fY > fCY-len) State |= 2; - else if(fY >= fY2+len) return false; + State = 0; + if (fX < fCX + len) State = 1; + else if (fX <= fX2 - len) return false; + if (fY > fCY - len) State |= 2; + else if (fY >= fY2 + len) return false; - return true; + return true; } // -------------------------------------------------------------------------- -void Diagram::getAxisLimits(Graph *pg) -{ - // FIXME: Graph should know the limits. but it doesn't yet. - // we should only copy here. better: just wrap, dont use {x,y,z}Axis - int z; - double x, y, *p; - DataX const *pD = pg->axis(0); - if(pD == 0) return; +void Diagram::getAxisLimits(Graph *pg) { + // FIXME: Graph should know the limits. but it doesn't yet. + // we should only copy here. better: just wrap, dont use {x,y,z}Axis + int z; + double x, y, *p; + DataX const *pD = pg->axis(0); + if (pD == 0) return; - if(Name[0] != 'C') { // not for location curves - p = pD->Points; - for(z=pD->count; z>0; z--) { // check x coordinates (1. dimension) - x = *(p++); - if(std::isfinite(x)) { - if(x > xAxis.max) xAxis.max = x; - if(x < xAxis.min) xAxis.min = x; - } + if (Name[0] != 'C') { // not for location curves + p = pD->Points; + for (z = pD->count; z > 0; z--) { // check x coordinates (1. dimension) + x = *(p++); + if (std::isfinite(x)) { + if (x > xAxis.max) xAxis.max = x; + if (x < xAxis.min) xAxis.min = x; + } + } } - } - if(Name == "Rect3D") { - DataX const *pDy = pg->axis(1); - if(pDy) { - p = pDy->Points; - for(z=pDy->count; z>0; z--) { // check y coordinates (2. dimension) - y = *(p++); - if(std::isfinite(y)) { - if(y > yAxis.max) yAxis.max = y; - if(y < yAxis.min) yAxis.min = y; - } - } + if (Name == "Rect3D") { + DataX const *pDy = pg->axis(1); + if (pDy) { + p = pDy->Points; + for (z = pDy->count; z > 0; z--) { // check y coordinates (2. dimension) + y = *(p++); + if (std::isfinite(y)) { + if (y > yAxis.max) yAxis.max = y; + if (y < yAxis.min) yAxis.min = y; + } + } + } } - } - Axis *pa; - if(pg->yAxisNo == 0) pa = &yAxis; - else pa = &zAxis; - (pa->numGraphs)++; // count graphs - p = pg->cPointsY; - if(p == 0) return; // if no data => invalid - for(z=pg->countY*pD->count; z>0; z--) { // check every y coordinate - x = *(p++); - y = *(p++); + Axis *pa; + if (pg->yAxisNo == 0) pa = &yAxis; + else pa = &zAxis; + (pa->numGraphs)++; // count graphs + p = pg->cPointsY; + if (p == 0) return; // if no data => invalid + for (z = pg->countY * pD->count; z > 0; z--) { // check every y coordinate + x = *(p++); + y = *(p++); - if(Name[0] != 'C') { - if(fabs(y) >= 1e-250) x = sqrt(x*x+y*y); - if(std::isfinite(x)) { - if(x > pa->max) pa->max = x; - if(x < pa->min) pa->min = x; - } + if (Name[0] != 'C') { + if (fabs(y) >= 1e-250) x = sqrt(x * x + y * y); + if (std::isfinite(x)) { + if (x > pa->max) pa->max = x; + if (x < pa->min) pa->min = x; + } + } else { // location curve needs different treatment + if (std::isfinite(x)) { + if (x > xAxis.max) xAxis.max = x; + if (x < xAxis.min) xAxis.min = x; + } + if (std::isfinite(y)) { + if (y > pa->max) pa->max = y; + if (y < pa->min) pa->min = y; + } + } } - else { // location curve needs different treatment - if(std::isfinite(x)) { - if(x > xAxis.max) xAxis.max = x; - if(x < xAxis.min) xAxis.min = x; - } - if(std::isfinite(y)) { - if(y > pa->max) pa->max = y; - if(y < pa->min) pa->min = y; - } - } - } } // -------------------------------------------------------------------------- -void Diagram::loadGraphData(const QString& defaultDataSet) -{ - int yNum = yAxis.numGraphs; - int zNum = zAxis.numGraphs; - yAxis.numGraphs = zAxis.numGraphs = 0; +void Diagram::loadGraphData(const QString &defaultDataSet) { + int yNum = yAxis.numGraphs; + int zNum = zAxis.numGraphs; + yAxis.numGraphs = zAxis.numGraphs = 0; - double xmin = xAxis.min, ymin = yAxis.min, zmin = zAxis.min; - double xmax = xAxis.max, ymax = yAxis.max, zmax = zAxis.max; - yAxis.min = zAxis.min = xAxis.min = DBL_MAX; - yAxis.max = zAxis.max = xAxis.max = -DBL_MAX; + double xmin = xAxis.min, ymin = yAxis.min, zmin = zAxis.min; + double xmax = xAxis.max, ymax = yAxis.max, zmax = zAxis.max; + yAxis.min = zAxis.min = xAxis.min = DBL_MAX; + yAxis.max = zAxis.max = xAxis.max = -DBL_MAX; - int No=0; - foreach(Graph *pg, Graphs) { - qDebug() << "load GraphData load" << defaultDataSet << pg->Var; - if(pg->loadDatFile(defaultDataSet) != 1) // load data, determine max/min values - No++; - getAxisLimits(pg); - } + int No = 0; + for (Graph *pg: Graphs) { + qDebug() << "load GraphData load" << defaultDataSet << pg->Var; + if (pg->loadDatFile(defaultDataSet) != 1) // load data, determine max/min values + No++; + getAxisLimits(pg); + } - if(No <= 0) { // All dataset files unchanged ? - yAxis.numGraphs = yNum; // rebuild scrollbar position - zAxis.numGraphs = zNum; + if (No <= 0) { // All dataset files unchanged ? + yAxis.numGraphs = yNum; // rebuild scrollbar position + zAxis.numGraphs = zNum; - xAxis.min = xmin; yAxis.min = ymin; zAxis.min = zmin; - xAxis.max = xmax; yAxis.max = ymax; zAxis.max = zmax; - return; // -> no update necessary - } + xAxis.min = xmin; + yAxis.min = ymin; + zAxis.min = zmin; + xAxis.max = xmax; + yAxis.max = ymax; + zAxis.max = zmax; + return; // -> no update necessary + } - if(xAxis.min > xAxis.max) - xAxis.min = xAxis.max = 0.0; - if(yAxis.min > yAxis.max) - yAxis.min = yAxis.max = 0.0; - if(zAxis.min > zAxis.max) - zAxis.min = zAxis.max = 0.0; + if (xAxis.min > xAxis.max) + xAxis.min = xAxis.max = 0.0; + if (yAxis.min > yAxis.max) + yAxis.min = yAxis.max = 0.0; + if (zAxis.min > zAxis.max) + zAxis.min = zAxis.max = 0.0; /* if((Name == "Polar") || (Name == "Smith")) { // one axis only if(yAxis.min > zAxis.min) yAxis.min = zAxis.min; if(yAxis.max < zAxis.max) yAxis.max = zAxis.max; }*/ - updateGraphData(); + updateGraphData(); } /*! Calculate diagram again without reading dataset from file. */ -void Diagram::recalcGraphData() -{ - yAxis.min = zAxis.min = xAxis.min = DBL_MAX; - yAxis.max = zAxis.max = xAxis.max = -DBL_MAX; - yAxis.numGraphs = zAxis.numGraphs = 0; +void Diagram::recalcGraphData() { + yAxis.min = zAxis.min = xAxis.min = DBL_MAX; + yAxis.max = zAxis.max = xAxis.max = -DBL_MAX; + yAxis.numGraphs = zAxis.numGraphs = 0; - // get maximum and minimum values - foreach(Graph *pg, Graphs) - getAxisLimits(pg); + // get maximum and minimum values + for (Graph *pg: Graphs) + getAxisLimits(pg); - if(xAxis.min > xAxis.max) { - xAxis.min = 0.0; - xAxis.max = 1.0; - } - if(yAxis.min > yAxis.max) { - yAxis.min = 0.0; - yAxis.max = 1.0; - } - if(zAxis.min > zAxis.max) { - zAxis.min = 0.0; - zAxis.max = 1.0; - } - if((Name == "Polar") || (Name == "Smith")) { // one axis only - if(yAxis.min > zAxis.min) yAxis.min = zAxis.min; - if(yAxis.max < zAxis.max) yAxis.max = zAxis.max; - } + if (xAxis.min > xAxis.max) { + xAxis.min = 0.0; + xAxis.max = 1.0; + } + if (yAxis.min > yAxis.max) { + yAxis.min = 0.0; + yAxis.max = 1.0; + } + if (zAxis.min > zAxis.max) { + zAxis.min = 0.0; + zAxis.max = 1.0; + } + if ((Name == "Polar") || (Name == "Smith")) { // one axis only + if (yAxis.min > zAxis.min) yAxis.min = zAxis.min; + if (yAxis.max < zAxis.max) yAxis.max = zAxis.max; + } - updateGraphData(); + updateGraphData(); } // ------------------------------------------------------------------------ -void Diagram::updateGraphData() -{ - int valid = calcDiagram(); // do not calculate graph data if invalid +void Diagram::updateGraphData() { + int valid = calcDiagram(); // do not calculate graph data if invalid - foreach(Graph *pg, Graphs) { - pg->clear(); - if((valid & (pg->yAxisNo+1)) != 0) - calcData(pg); // calculate screen coordinates - else if(pg->cPointsY) { - delete[] pg->cPointsY; - pg->cPointsY = 0; + for (Graph *pg: Graphs) { + pg->clear(); + if ((valid & (pg->yAxisNo + 1)) != 0) + calcData(pg); // calculate screen coordinates + else if (pg->cPointsY) { + delete[] pg->cPointsY; + pg->cPointsY = 0; + } } - } - createAxisLabels(); // virtual function + createAxisLabels(); // virtual function - // Setting markers must be done last, because in 3D diagram "Mem" - // is released in "createAxisLabels()". - foreach(Graph *pg, Graphs){ - pg->createMarkerText(); - } + // Setting markers must be done last, because in 3D diagram "Mem" + // is released in "createAxisLabels()". + for (Graph *pg: Graphs) { + pg->createMarkerText(); + } } // -------------------------------------------------------------------------- @@ -821,910 +806,903 @@ void Diagram::updateGraphData() * * FIXME: must invalidate markers. */ -int Graph::loadDatFile(const QString& fileName) -{ - Graph* g = this; - QFile file; - QString Variable; - QFileInfo Info(fileName); +int Graph::loadDatFile(const QString &fileName) { + Graph *g = this; + QFile file; + QString Variable; + QFileInfo Info(fileName); - int pos1 = g->Var.indexOf('/'); + int pos1 = g->Var.indexOf('/'); // if(g->Var.right(3) == "].X") // e.g. stdl[8:0].X // if(pos > g->Var.indexOf('[')) // pos = -1; - /* WORK-AROUND: A bug in SCIM (libscim) which Qt is linked to causes - to change the locale to the default. */ - setlocale (LC_NUMERIC, "C"); + /* WORK-AROUND: A bug in SCIM (libscim) which Qt is linked to causes + to change the locale to the default. */ + setlocale(LC_NUMERIC, "C"); - QString tail = ""; - QString svar = g->Var; - if (pos1 > 0) { // remove simulator signature - tail = '.' + g->Var.section('/',0,0); - svar = g->Var.mid(pos1 + 1); - } + QString tail = ""; + QString svar = g->Var; + if (pos1 > 0) { // remove simulator signature + tail = '.' + g->Var.section('/', 0, 0); + svar = g->Var.mid(pos1 + 1); + } - int pos = svar.indexOf(':'); - if(pos <= 0) { - file.setFileName(fileName+tail); - Variable = svar; - } - else { - QString ss3 = Info.path()+QDir::separator() + svar.left(pos)+".dat"+tail; - qDebug()<lastLoaded.isValid()) - if(g->lastLoaded > Info.lastModified()) - return 1; // dataset unchanged -> no update necessary + Info.setFile(file); + if (g->lastLoaded.isValid()) + if (g->lastLoaded > Info.lastModified()) + return 1; // dataset unchanged -> no update necessary - g->countY = 0; - g->mutable_axes().clear(); // HACK - if(g->cPointsY) { delete[] g->cPointsY; g->cPointsY = 0; } - if(Variable.isEmpty()) return 0; + g->countY = 0; + g->mutable_axes().clear(); // HACK + if (g->cPointsY) { + delete[] g->cPointsY; + g->cPointsY = 0; + } + if (Variable.isEmpty()) return 0; #if 0 // FIXME encapsulation. implement digital waves later. - if(Variable.right(2) == ".X") - if(Name.at(0) != 'T') - return 0; // digital variables only for tabulars and ziming diagram + if(Variable.right(2) == ".X") + if(Name.at(0) != 'T') + return 0; // digital variables only for tabulars and ziming diagram #endif - // PlotVs() emulation - bool hasExplIndep = false; // Ex[licit indep var - QString ExplIndep = ""; - if (Variable.contains("@")) { - hasExplIndep = true; - ExplIndep = Variable.section("@",1,1); - Variable = Variable.section("@",0,0); - } - - - if(!file.open(QIODevice::ReadOnly)) return 0; - - // ***************************************************************** - // To strongly speed up the file read operation the whole file is - // read into the memory in one piece. - QByteArray FileContent; - FileContent = file.readAll(); - file.close(); - char *FileString = FileContent.data(); - if(!FileString) return 0; - char *pPos = FileString+FileContent.size()-1; - if(*pPos > ' ') if(*pPos != '>') return 0; - *pPos = 0; - - - // ***************************************************************** - // look for variable name in data file **************************** - bool isIndep = false; - Variable = "dep "+Variable+" "; - // "pFile" is used through-out the whole function and must NOT used - // for other purposes! - char *pFile = strstr(FileString, Variable.toLatin1()); - while(pFile) { - if(*(pFile-1) == '<') // is dependent variable ? - break; - else if(strncmp(pFile-3, "'); - if(!pPos) return 0; // file corrupt - *pPos = 0; - Line = QString(pFile); - *pPos = '>'; - pFile = pPos+1; - if(!isIndep) { - pos = 0; - tmp = Line.section(' ', pos, pos); - while(!tmp.isEmpty()) { - if (hasExplIndep)g->mutable_axes().push_back(new DataX(ExplIndep)); - else g->mutable_axes().push_back(new DataX(tmp)); // name of independent variable - pos++; - tmp = Line.section(' ', pos, pos); + if (!file.open(QIODevice::ReadOnly)) return 0; + + // ***************************************************************** + // To strongly speed up the file read operation the whole file is + // read into the memory in one piece. + QByteArray FileContent; + FileContent = file.readAll(); + file.close(); + char *FileString = FileContent.data(); + if (!FileString) return 0; + char *pPos = FileString + FileContent.size() - 1; + if (*pPos > ' ') if (*pPos != '>') return 0; + *pPos = 0; + + + // ***************************************************************** + // look for variable name in data file **************************** + bool isIndep = false; + Variable = "dep " + Variable + " "; + // "pFile" is used through-out the whole function and must NOT used + // for other purposes! + char *pFile = strstr(FileString, Variable.toLatin1()); + while (pFile) { + if (*(pFile - 1) == '<') // is dependent variable ? + break; + else if (strncmp(pFile - 3, "mutable_axes().push_back(new DataX("number", 0, counting)); - if(!ok) return 0; + if (!pFile) return 0; // data not found - p = new double[counting]; // memory of new independent variable - g->countY = 1; - g->mutable_axes().back()->Points = p; - for(int z=1; z<=counting; z++) *(p++) = double(z); - auto Axis = g->mutable_axes().back(); - Axis->min(1.); - Axis->max(double(counting)); - } - else { // ................................... - // get independent variables from data file - g->countY = 1; + QString Line, tmp; + pFile += Variable.length(); + pPos = strchr(pFile, '>'); + if (!pPos) return 0; // file corrupt + *pPos = 0; + Line = QString(pFile); + *pPos = '>'; + pFile = pPos + 1; + if (!isIndep) { + pos = 0; + tmp = Line.section(' ', pos, pos); + while (!tmp.isEmpty()) { + if (hasExplIndep)g->mutable_axes().push_back(new DataX(ExplIndep)); + else g->mutable_axes().push_back(new DataX(tmp)); // name of independent variable + pos++; + tmp = Line.section(' ', pos, pos); + } + } + + // ***************************************************************** + // get independent variable **************************************** + bool ok = true; + double *p; + int counting = 0; + if (isIndep) { // create independent variable by myself ? + counting = Line.toInt(&ok); // get number of values + g->mutable_axes().push_back(new DataX("number", 0, counting)); + if (!ok) return 0; + + p = new double[counting]; // memory of new independent variable + g->countY = 1; + g->mutable_axes().back()->Points = p; + for (int z = 1; z <= counting; z++) *(p++) = double(z); + auto Axis = g->mutable_axes().back(); + Axis->min(1.); + Axis->max(double(counting)); + } else { // ................................... + // get independent variables from data file + g->countY = 1; #if 0 // FIXME: we do not have a Name. - DataX *bLast = 0; - if(Name == "Rect3D") bLast = g->axis(1); // y axis for Rect3D + DataX *bLast = 0; + if(Name == "Rect3D") bLast = g->axis(1); // y axis for Rect3D #endif #if 0 // FIXME: this is about diagram. do after load. - double min_tmp = xAxis.min, max_tmp = xAxis.max; + double min_tmp = xAxis.min, max_tmp = xAxis.max; #endif - DataX const *pD; - for(int ii= g->numAxes(); (pD = g->axis(--ii)); ) { + DataX const *pD; + for (int ii = g->numAxes(); (pD = g->axis(--ii));) { #if 0 // FIXME: this is about diagram. do after load. - pa = &xAxis; - if(pD == g->axis(0)) { - xAxis.min = min_tmp; // only count first independent variable - xAxis.max = max_tmp; - } - else if(pD == bLast) pa = &yAxis; // y axis for Rect3D + pa = &xAxis; + if(pD == g->axis(0)) { + xAxis.min = min_tmp; // only count first independent variable + xAxis.max = max_tmp; + } + else if(pD == bLast) pa = &yAxis; // y axis for Rect3D #endif - counting = loadIndepVarData(pD->Var, FileString, mutable_axis(ii)); - if(counting <= 0) return 0; + counting = loadIndepVarData(pD->Var, FileString, mutable_axis(ii)); + if (counting <= 0) return 0; - g->countY *= counting; + g->countY *= counting; + } + g->countY /= counting; } - g->countY /= counting; - } - // ***************************************************************** - // get dependent variables ***************************************** - counting *= g->countY; - p = new double[2*counting]; // memory for dependent variables - g->cPointsY = p; + // ***************************************************************** + // get dependent variables ***************************************** + counting *= g->countY; + p = new double[2 * counting]; // memory for dependent variables + g->cPointsY = p; #if 0 // FIXME: what does this do?! - if(g->yAxisNo == 0) pa = &yAxis; // for which axis - else pa = &zAxis; - (pa->numGraphs)++; // count graphs + if(g->yAxisNo == 0) pa = &yAxis; // for which axis + else pa = &zAxis; + (pa->numGraphs)++; // count graphs #endif - char *pEnd; - double x, y; - pPos = pFile; + char *pEnd; + double x, y; + pPos = pFile; -if(Variable.right(3) != ".X ") { // not "digital" + if (Variable.right(3) != ".X ") { // not "digital" - for(int z=counting; z>0; z--) { - pEnd = 0; - while((*pPos) && (*pPos <= ' ')) pPos++; // find start of next number - x = strtod(pPos, &pEnd); // real part - pPos = pEnd + 1; - if(*pEnd < ' ') // is there an imaginary part ? - y = 0.0; - else { - if(((*pEnd != '+') && (*pEnd != '-')) || (*pPos != 'j')) { - delete[] g->cPointsY; g->cPointsY = 0; - return 0; - } - *pPos = *pEnd; // overwrite 'j' with sign - pEnd = 0; - y = strtod(pPos, &pEnd); // imaginary part - *pPos = 'j'; // write back old character - pPos = pEnd; - } - *(p++) = x; - *(p++) = y; + for (int z = counting; z > 0; z--) { + pEnd = 0; + while ((*pPos) && (*pPos <= ' ')) pPos++; // find start of next number + x = strtod(pPos, &pEnd); // real part + pPos = pEnd + 1; + if (*pEnd < ' ') // is there an imaginary part ? + y = 0.0; + else { + if (((*pEnd != '+') && (*pEnd != '-')) || (*pPos != 'j')) { + delete[] g->cPointsY; + g->cPointsY = 0; + return 0; + } + *pPos = *pEnd; // overwrite 'j' with sign + pEnd = 0; + y = strtod(pPos, &pEnd); // imaginary part + *pPos = 'j'; // write back old character + pPos = pEnd; + } + *(p++) = x; + *(p++) = y; #if 0 // FIXME there is no Name here. - if(Name[0] != 'C') + if(Name[0] != 'C') #endif - { - if(fabs(y) >= 1e-250) x = sqrt(x*x+y*y); - if(std::isfinite(x)) { - auto Axis = g->mutable_axes().back(); - Axis->min(x); - Axis->max(x); - } - } + { + if (fabs(y) >= 1e-250) x = sqrt(x * x + y * y); + if (std::isfinite(x)) { + auto Axis = g->mutable_axes().back(); + Axis->min(x); + Axis->max(x); + } + } #if 0 // this is not location curve code. - else { // location curve needs different treatment - if(std::isfinite(x)) { - if(x > xAxis.max) xAxis.max = x; - if(x < xAxis.min) xAxis.min = x; - } - if(std::isfinite(y)) { - if(y > pa->max) pa->max = y; - if(y < pa->min) pa->min = y; - } - } + else { // location curve needs different treatment + if(std::isfinite(x)) { + if(x > xAxis.max) xAxis.max = x; + if(x < xAxis.min) xAxis.min = x; + } + if(std::isfinite(y)) { + if(y > pa->max) pa->max = y; + if(y < pa->min) pa->min = y; + } + } #endif - } + } -} else { // of "if not digital" + } else { // of "if not digital" - char *pc = (char*)p; - pEnd = pc + 2*(counting-1)*sizeof(double); - // for digital variables (e.g. 100ZX0): - for(int z=counting; z>0; z--) { + char *pc = (char *) p; + pEnd = pc + 2 * (counting - 1) * sizeof(double); + // for digital variables (e.g. 100ZX0): + for (int z = counting; z > 0; z--) { - while((*pPos) && (*pPos <= ' ')) pPos++; // find start of next bit vector - if(*pPos == 0) { - delete[] g->cPointsY; g->cPointsY = 0; - return 0; - } + while ((*pPos) && (*pPos <= ' ')) pPos++; // find start of next bit vector + if (*pPos == 0) { + delete[] g->cPointsY; + g->cPointsY = 0; + return 0; + } - while(*pPos > ' ') { // copy bit vector - *(pc++) = *(pPos++); - if(pEnd <= pc) { - counting = pc - (char*)g->cPointsY; - pc = (char*)realloc(g->cPointsY, counting+1024); - pEnd = pc; - g->cPointsY = (double*)pEnd; - pc += counting; - pEnd += counting+1020; - } - } - *(pc++) = 0; // terminate each vector with NULL - } + while (*pPos > ' ') { // copy bit vector + *(pc++) = *(pPos++); + if (pEnd <= pc) { + counting = pc - (char *) g->cPointsY; + pc = (char *) realloc(g->cPointsY, counting + 1024); + pEnd = pc; + g->cPointsY = (double *) pEnd; + pc += counting; + pEnd += counting + 1020; + } + } + *(pc++) = 0; // terminate each vector with NULL + } -} // of "if not digital" + } // of "if not digital" - lastLoaded = QDateTime::currentDateTime(); - return 2; + lastLoaded = QDateTime::currentDateTime(); + return 2; } /*! Reads the data of an independent variable. Returns the number of points. */ -int Graph::loadIndepVarData(const QString& Variable, - char *FileString, DataX* pD) -{ - bool isIndep = false; - QString Line, tmp; +int Graph::loadIndepVarData(const QString &Variable, + char *FileString, DataX *pD) { + bool isIndep = false; + QString Line, tmp; - /* WORK-AROUND: A bug in SCIM (libscim) which Qt is linked to causes - to change the locale to the default. */ - setlocale (LC_NUMERIC, "C"); + /* WORK-AROUND: A bug in SCIM (libscim) which Qt is linked to causes + to change the locale to the default. */ + setlocale(LC_NUMERIC, "C"); - Line = "dep "+Variable+" "; - // "pFile" is used through-out the whole function and must NOT used - // for other purposes! - char *pFile = strstr(FileString, Line.toLatin1()); - while(pFile) { - if(*(pFile-1) == '<') // is dependent variable ? - break; - else if(strncmp(pFile-3, "'); - if(!pPos) return -1; // file corrupt - *pPos = 0; - Line = QString(pFile); - *pPos = '>'; - pFile = pPos+1; - char *pEnd; - if(!isIndep) { // dependent variable can also be used... - if(Line.indexOf(' ') >= 0) return -1; // ...if only one dependency - Line = "'); - if(!pEnd) return -1; // file corrupt - *pEnd = 0; - Line = QString(pPos); - *pEnd = '>'; - } + pFile += Line.length(); + char *pPos = strchr(pFile, '>'); + if (!pPos) return -1; // file corrupt + *pPos = 0; + Line = QString(pFile); + *pPos = '>'; + pFile = pPos + 1; + char *pEnd; + if (!isIndep) { // dependent variable can also be used... + if (Line.indexOf(' ') >= 0) return -1; // ...if only one dependency + Line = "'); + if (!pEnd) return -1; // file corrupt + *pEnd = 0; + Line = QString(pPos); + *pEnd = '>'; + } - bool ok; - int n = Line.toInt(&ok); // number of values - if(!ok) return -1; + bool ok; + int n = Line.toInt(&ok); // number of values + if (!ok) return -1; - double *p = new double[n]; // memory for new independent variable + double *p = new double[n]; // memory for new independent variable // DataX *pD = pg->mutable_axes().back(); - pD->Points = p; - pD->count = n; + pD->Points = p; + pD->count = n; - double x; - pPos = pFile; - // find first position containing no whitespace - while((*pPos) && (*pPos <= ' ')) pPos++; + double x; + pPos = pFile; + // find first position containing no whitespace + while ((*pPos) && (*pPos <= ' ')) pPos++; - for(int z=0; z ' ') // drop imaginary part because - while (*pEnd > ' ') pEnd++; // Complex number on X-axis has no sense + if (*pEnd > ' ') // drop imaginary part because + while (*pEnd > ' ') pEnd++; // Complex number on X-axis has no sense - if(pPos == pEnd) { - delete[] pD->Points; pD->Points = 0; - return -1; - } - - *(p++) = x; + if (pPos == pEnd) { + delete[] pD->Points; + pD->Points = 0; + return -1; + } + + *(p++) = x; #if 0 // this is not location curve code - if(Name[0] != 'C') // not for location curves - if(std::isfinite(x)) { - if(x > pa->max) pa->max = x; - if(x < pa->min) pa->min = x; - } + if(Name[0] != 'C') // not for location curves + if(std::isfinite(x)) { + if(x > pa->max) pa->max = x; + if(x < pa->min) pa->min = x; + } #endif - - pPos = pEnd; - while((*pPos) && (*pPos <= ' ')) pPos++; // find start of next number - } - return n; // return number of independent data + pPos = pEnd; + while ((*pPos) && (*pPos <= ' ')) pPos++; // find start of next number + } + + return n; // return number of independent data } /*! Checks if the two graphs have the same independent variables. */ -bool Diagram::sameDependencies(Graph const*g1, Graph const*g2) const -{ - // FIXME - // return g1->same(*g2); - if(g1 == g2) return true; - if(g1->numAxes()!=g2->numAxes()) return false; +bool Diagram::sameDependencies(Graph const *g1, Graph const *g2) const { + // FIXME + // return g1->same(*g2); + if (g1 == g2) return true; + if (g1->numAxes() != g2->numAxes()) return false; - for(unsigned i=0; inumAxes(); ++i) { - if(g1->axisName(i) != g2->axisName(i)) return false; - } - - return true; -} - -// ------------------------------------------------------------ -int Diagram::checkColumnWidth(const QString& Str, - const QFontMetrics& metrics, int colWidth, int x, int y) -{ - //qDebug("%i", metrics.charWidth(Str,0)); - int w = metrics.boundingRect(Str).width(); // width of text - if(w > colWidth) { - colWidth = w; - if((x+colWidth) >= x2) { // enough space for text ? - // mark lack of space with a small arrow - Lines.append(new qucs::Line(x2-6, y-4, x2+7, y-4, QPen(Qt::red,2))); - Lines.append(new qucs::Line(x2, y-7, x2+6, y-4, QPen(Qt::red,2))); - Lines.append(new qucs::Line(x2, y-1, x2+6, y-4, QPen(Qt::red,2))); - return -1; + for (unsigned i = 0; i < g1->numAxes(); ++i) { + if (g1->axisName(i) != g2->axisName(i)) return false; } - } - return colWidth; + + return true; } // ------------------------------------------------------------ -void Diagram::setCenter(int x, int y, bool relative) -{ - if(relative) { - cx += x; cy += y; - } - else { - cx = x; cy = y; - } +int Diagram::checkColumnWidth(const QString &Str, + const QFontMetrics &metrics, int colWidth, int x, int y) { + //qDebug("%i", metrics.charWidth(Str,0)); + int w = metrics.boundingRect(Str).width(); // width of text + if (w > colWidth) { + colWidth = w; + if ((x + colWidth) >= x2) { // enough space for text ? + // mark lack of space with a small arrow + Lines.append(new qucs::Line(x2 - 6, y - 4, x2 + 7, y - 4, QPen(Qt::red, 2))); + Lines.append(new qucs::Line(x2, y - 7, x2 + 6, y - 4, QPen(Qt::red, 2))); + Lines.append(new qucs::Line(x2, y - 1, x2 + 6, y - 4, QPen(Qt::red, 2))); + return -1; + } + } + return colWidth; +} + +// ------------------------------------------------------------ +void Diagram::setCenter(int x, int y, bool relative) { + if (relative) { + cx += x; + cy += y; + } else { + cx = x; + cy = y; + } } // ------------------------------------------------------- -void Diagram::getCenter(int& x, int& y) -{ - x = cx + (x2 >> 1); - y = cy - (y2 >> 1); +void Diagram::getCenter(int &x, int &y) { + x = cx + (x2 >> 1); + y = cy - (y2 >> 1); } // ------------------------------------------------------------ -Diagram* Diagram::newOne() -{ - return new Diagram(); +Diagram *Diagram::newOne() { + return new Diagram(); } // ------------------------------------------------------------ -void Diagram::finishMarkerCoordinates(float& fCX, float& fCY) const -{ - if(!insideDiagram(fCX, fCY)) { - fCX = float(x2 >> 1); - fCY = float(y2 >> 1); - } -} - -// ------------------------------------------------------------ -QString Diagram::save() -{ - QString s = "<"+Name+" "+QString::number(cx)+" "+QString::number(cy)+" "; - s += QString::number(x2)+" "+QString::number(y2)+" "; - char c = '0'; - if(xAxis.GridOn) c |= 1; - if(hideLines) c |= 2; - s += c; - s += " " + GridPen.color().name() + " " + QString::number(GridPen.style()); - - if(xAxis.log) s+= " 1"; else s += " 0"; - c = '0'; - if(yAxis.log) c |= 1; - if(zAxis.log) c |= 2; - s += c; - - if(xAxis.autoScale) s+= " 1 "; - else s+= " 0 "; - s += QString::number(xAxis.limit_min) + " "; - s += QString::number(xAxis.step) + " "; - s += QString::number(xAxis.limit_max); - if(yAxis.autoScale) s+= " 1 "; - else s+= " 0 "; - s += QString::number(yAxis.limit_min) + " "; - s += QString::number(yAxis.step) + " "; - s += QString::number(yAxis.limit_max); - if(zAxis.autoScale) s+= " 1 "; - else s+= " 0 "; - s += QString::number(zAxis.limit_min) + " "; - s += QString::number(zAxis.step) + " "; - s += QString::number(zAxis.limit_max) + " "; - - s += QString::number(rotX)+" "+QString::number(rotY)+" "+ - QString::number(rotZ); - - if (engineeringNotation) s += " 1 "; - else s += " 0 "; - - s += QString::number(yAxis.Units) + " " - + QString::number(zAxis.Units); - - // labels can contain spaces -> must be last items in the line - s += " \""+xAxis.Label+"\" \""+yAxis.Label+"\" \""+zAxis.Label+"\">\n"; - - foreach(Graph *pg, Graphs) - s += pg->save()+"\n"; - - s += " "; - return s; -} - -// ------------------------------------------------------------ -bool Diagram::load(const QString& Line, QTextStream *stream) -{ - bool ok; - QString s = Line; - - if(s.at(0) != '<') return false; - if(s.at(s.length()-1) != '>') return false; - s = s.mid(1, s.length()-2); // cut off start and end character - - QString n; - n = s.section(' ',1,1); // cx - cx = n.toInt(&ok); - if(!ok) return false; - - n = s.section(' ',2,2); // cy - cy = n.toInt(&ok); - if(!ok) return false; - - n = s.section(' ',3,3); // x2 - x2 = n.toInt(&ok); - if(!ok) return false; - - n = s.section(' ',4,4); // y2 - y2 = n.toInt(&ok); - if(!ok) return false; - - char c; - n = s.section(' ',5,5); // GridOn - c = n.at(0).toLatin1() - '0'; - xAxis.GridOn = yAxis.GridOn = (c & 1) != 0; - hideLines = (c & 2) != 0; - - n = s.section(' ',6,6); // color for GridPen - QColor co; - co.setNamedColor(n); - GridPen.setColor(co); - if(!GridPen.color().isValid()) return false; - - n = s.section(' ',7,7); // line style - GridPen.setStyle((Qt::PenStyle)n.toInt(&ok)); - if(!ok) return false; - - n = s.section(' ',8,8); // xlog, ylog - xAxis.log = n.at(0) != '0'; - c = n.at(1).toLatin1(); - yAxis.log = ((c - '0') & 1) == 1; - zAxis.log = ((c - '0') & 2) == 2; - - n = s.section(' ',9,9); // xAxis.autoScale - if(n.at(0) != '"') { // backward compatible - if(n == "1") xAxis.autoScale = true; - else xAxis.autoScale = false; - - n = s.section(' ',10,10); // xAxis.limit_min - xAxis.limit_min = n.toDouble(&ok); - if(!ok) return false; - - n = s.section(' ',11,11); // xAxis.step - xAxis.step = n.toDouble(&ok); - if(!ok) return false; - - n = s.section(' ',12,12); // xAxis.limit_max - xAxis.limit_max = n.toDouble(&ok); - if(!ok) return false; - - n = s.section(' ',13,13); // yAxis.autoScale - if(n == "1") yAxis.autoScale = true; - else yAxis.autoScale = false; - - n = s.section(' ',14,14); // yAxis.limit_min - yAxis.limit_min = n.toDouble(&ok); - if(!ok) return false; - - n = s.section(' ',15,15); // yAxis.step - yAxis.step = n.toDouble(&ok); - if(!ok) return false; - - n = s.section(' ',16,16); // yAxis.limit_max - yAxis.limit_max = n.toDouble(&ok); - if(!ok) return false; - - n = s.section(' ',17,17); // zAxis.autoScale - if(n == "1") zAxis.autoScale = true; - else zAxis.autoScale = false; - - n = s.section(' ',18,18); // zAxis.limit_min - zAxis.limit_min = n.toDouble(&ok); - if(!ok) return false; - - n = s.section(' ',19,19); // zAxis.step - zAxis.step = n.toDouble(&ok); - if(!ok) return false; - - n = s.section(' ',20,20); // zAxis.limit_max - zAxis.limit_max = n.toDouble(&ok); - if(!ok) return false; - - n = s.section(' ',21,21); // rotX - if(n.at(0) != '"') { // backward compatible - rotX = n.toInt(&ok); - if(!ok) return false; - - n = s.section(' ',22,22); // rotY - rotY = n.toInt(&ok); - if(!ok) return false; - - n = s.section(' ',23,23); // rotZ - rotZ = n.toInt(&ok); - if(!ok) return false; - - n = s.section(' ',24,24); - if (n.at(0) != '"') { - if (n == "1") engineeringNotation = true; - else engineeringNotation = false; - n = s.section(' ',25,25); - if (n.at(0) != '"') { - yAxis.Units = n.toInt(&ok); - if(!ok) return false; - - n = s.section(' ',26,26); - zAxis.Units = n.toInt(&ok); - if(!ok) return false; - } - } +void Diagram::finishMarkerCoordinates(float &fCX, float &fCY) const { + if (!insideDiagram(fCX, fCY)) { + fCX = float(x2 >> 1); + fCY = float(y2 >> 1); } - } +} - xAxis.Label = s.section('"',1,1); // xLabel - yAxis.Label = s.section('"',3,3); // yLabel left - zAxis.Label = s.section('"',5,5); // yLabel right +// ------------------------------------------------------------ +QString Diagram::save() { + QString s = "<" + Name + " " + QString::number(cx) + " " + QString::number(cy) + " "; + s += QString::number(x2) + " " + QString::number(y2) + " "; + char c = '0'; + if (xAxis.GridOn) c |= 1; + if (hideLines) c |= 2; + s += c; + s += " " + GridPen.color().name() + " " + QString::number(GridPen.style()); - Graph *pg; - // ....................................................... - // load graphs of the diagram - while(!stream->atEnd()) { - s = stream->readLine(); - s = s.trimmed(); - if(s.isEmpty()) continue; + if (xAxis.log) s += " 1"; else s += " 0"; + c = '0'; + if (yAxis.log) c |= 1; + if (zAxis.log) c |= 2; + s += c; - if(s == ("")) return true; // found end tag ? - if(s.section(' ', 0,0) == "parentDiagram() == this); - Marker *pm = new Marker(pg); - if(!pm->load(s)) { - delete pm; - return false; - } - pg->Markers.append(pm); - continue; + s += QString::number(rotX) + " " + QString::number(rotY) + " " + + QString::number(rotZ); + + if (engineeringNotation) s += " 1 "; + else s += " 0 "; + + s += QString::number(yAxis.Units) + " " + + QString::number(zAxis.Units); + + // labels can contain spaces -> must be last items in the line + s += " \"" + xAxis.Label + "\" \"" + yAxis.Label + "\" \"" + zAxis.Label + "\">\n"; + + for (Graph *pg: Graphs) + s += pg->save() + "\n"; + + s += " "; + return s; +} + +// ------------------------------------------------------------ +bool Diagram::load(const QString &Line, QTextStream *stream) { + bool ok; + QString s = Line; + + if (s.at(0) != '<') return false; + if (s.at(s.length() - 1) != '>') return false; + s = s.mid(1, s.length() - 2); // cut off start and end character + + QString n; + n = s.section(' ', 1, 1); // cx + cx = n.toInt(&ok); + if (!ok) return false; + + n = s.section(' ', 2, 2); // cy + cy = n.toInt(&ok); + if (!ok) return false; + + n = s.section(' ', 3, 3); // x2 + x2 = n.toInt(&ok); + if (!ok) return false; + + n = s.section(' ', 4, 4); // y2 + y2 = n.toInt(&ok); + if (!ok) return false; + + char c; + n = s.section(' ', 5, 5); // GridOn + c = n.at(0).toLatin1() - '0'; + xAxis.GridOn = yAxis.GridOn = (c & 1) != 0; + hideLines = (c & 2) != 0; + + n = s.section(' ', 6, 6); // color for GridPen + QColor co; + co.setNamedColor(n); + GridPen.setColor(co); + if (!GridPen.color().isValid()) return false; + + n = s.section(' ', 7, 7); // line style + GridPen.setStyle((Qt::PenStyle) n.toInt(&ok)); + if (!ok) return false; + + n = s.section(' ', 8, 8); // xlog, ylog + xAxis.log = n.at(0) != '0'; + c = n.at(1).toLatin1(); + yAxis.log = ((c - '0') & 1) == 1; + zAxis.log = ((c - '0') & 2) == 2; + + n = s.section(' ', 9, 9); // xAxis.autoScale + if (n.at(0) != '"') { // backward compatible + if (n == "1") xAxis.autoScale = true; + else xAxis.autoScale = false; + + n = s.section(' ', 10, 10); // xAxis.limit_min + xAxis.limit_min = n.toDouble(&ok); + if (!ok) return false; + + n = s.section(' ', 11, 11); // xAxis.step + xAxis.step = n.toDouble(&ok); + if (!ok) return false; + + n = s.section(' ', 12, 12); // xAxis.limit_max + xAxis.limit_max = n.toDouble(&ok); + if (!ok) return false; + + n = s.section(' ', 13, 13); // yAxis.autoScale + if (n == "1") yAxis.autoScale = true; + else yAxis.autoScale = false; + + n = s.section(' ', 14, 14); // yAxis.limit_min + yAxis.limit_min = n.toDouble(&ok); + if (!ok) return false; + + n = s.section(' ', 15, 15); // yAxis.step + yAxis.step = n.toDouble(&ok); + if (!ok) return false; + + n = s.section(' ', 16, 16); // yAxis.limit_max + yAxis.limit_max = n.toDouble(&ok); + if (!ok) return false; + + n = s.section(' ', 17, 17); // zAxis.autoScale + if (n == "1") zAxis.autoScale = true; + else zAxis.autoScale = false; + + n = s.section(' ', 18, 18); // zAxis.limit_min + zAxis.limit_min = n.toDouble(&ok); + if (!ok) return false; + + n = s.section(' ', 19, 19); // zAxis.step + zAxis.step = n.toDouble(&ok); + if (!ok) return false; + + n = s.section(' ', 20, 20); // zAxis.limit_max + zAxis.limit_max = n.toDouble(&ok); + if (!ok) return false; + + n = s.section(' ', 21, 21); // rotX + if (n.at(0) != '"') { // backward compatible + rotX = n.toInt(&ok); + if (!ok) return false; + + n = s.section(' ', 22, 22); // rotY + rotY = n.toInt(&ok); + if (!ok) return false; + + n = s.section(' ', 23, 23); // rotZ + rotZ = n.toInt(&ok); + if (!ok) return false; + + n = s.section(' ', 24, 24); + if (n.at(0) != '"') { + if (n == "1") engineeringNotation = true; + else engineeringNotation = false; + n = s.section(' ', 25, 25); + if (n.at(0) != '"') { + yAxis.Units = n.toInt(&ok); + if (!ok) return false; + + n = s.section(' ', 26, 26); + zAxis.Units = n.toInt(&ok); + if (!ok) return false; + } + } + } } - pg = new Graph(this); - if(!pg->load(s)) { - delete pg; - return false; - } - Graphs.append(pg); - } + xAxis.Label = s.section('"', 1, 1); // xLabel + yAxis.Label = s.section('"', 3, 3); // yLabel left + zAxis.Label = s.section('"', 5, 5); // yLabel right - return false; // end tag missing + Graph *pg; + // ....................................................... + // load graphs of the diagram + while (!stream->atEnd()) { + s = stream->readLine(); + s = s.trimmed(); + if (s.isEmpty()) continue; + + if (s == ("")) return true; // found end tag ? + if (s.section(' ', 0, 0) == "parentDiagram() == this); + Marker *pm = new Marker(pg); + if (!pm->load(s)) { + delete pm; + return false; + } + pg->Markers.append(pm); + continue; + } + + pg = new Graph(this); + if (!pg->load(s)) { + delete pg; + return false; + } + Graphs.append(pg); + } + + return false; // end tag missing } // -------------------------------------------------------------- -void Diagram::calcSmithAxisScale(Axis *Axis, int& GridX, int& GridY) -{ - xAxis.low = xAxis.min; - xAxis.up = xAxis.max; +void Diagram::calcSmithAxisScale(Axis *Axis, int &GridX, int &GridY) { + xAxis.low = xAxis.min; + xAxis.up = xAxis.max; - Axis->low = 0.0; - if(fabs(Axis->min) > Axis->max) - Axis->max = fabs(Axis->min); // also fit negative values - if(Axis->autoScale) { - if(Axis->max > 1.01) Axis->up = 1.05*Axis->max; - else Axis->up = 1.0; - GridX = GridY = 4; - } - else { - Axis->up = Axis->limit_max = fabs(Axis->limit_max); - GridX = GridY = int(Axis->step); - } + Axis->low = 0.0; + if (fabs(Axis->min) > Axis->max) + Axis->max = fabs(Axis->min); // also fit negative values + if (Axis->autoScale) { + if (Axis->max > 1.01) Axis->up = 1.05 * Axis->max; + else Axis->up = 1.0; + GridX = GridY = 4; + } else { + Axis->up = Axis->limit_max = fabs(Axis->limit_max); + GridX = GridY = int(Axis->step); + } } // ------------------------------------------------------------ -void Diagram::createSmithChart(Axis *Axis, int Mode) -{ - int GridX; // number of arcs with re(z)=const - int GridY; // number of arcs with im(z)=const - calcSmithAxisScale(Axis, GridX, GridY); +void Diagram::createSmithChart(Axis *Axis, int Mode) { + int GridX; // number of arcs with re(z)=const + int GridY; // number of arcs with im(z)=const + calcSmithAxisScale(Axis, GridX, GridY); - if(!xAxis.GridOn) return; + if (!xAxis.GridOn) return; - bool Zplane = ((Mode & 1) == 1); // impedance or admittance chart ? - bool Above = ((Mode & 2) == 2); // paint upper half ? - bool Below = ((Mode & 4) == 4); // paint lower half ? + bool Zplane = ((Mode & 1) == 1); // impedance or admittance chart ? + bool Above = ((Mode & 2) == 2); // paint upper half ? + bool Below = ((Mode & 4) == 4); // paint lower half ? - int dx2 = x2>>1; + int dx2 = x2 >> 1; - double im, n_cos, n_sin, real, real1, real2, root; - double rMAXq = Axis->up*Axis->up; - int theta, beta, phi, len, m, x, y; + double im, n_cos, n_sin, real, real1, real2, root; + double rMAXq = Axis->up * Axis->up; + int theta, beta, phi, len, m, x, y; - int R1 = int(x2/Axis->up + 0.5); - // .................................................... - // draw arcs with im(z)=const - for(m=1; mup,0.7); // up^0.7 is beauty correction - y = int(im/Axis->up*x2 + 0.5); // diameter + int R1 = int(x2 / Axis->up + 0.5); + // .................................................... + // draw arcs with im(z)=const + for (m = 1; m < GridY; m++) { + n_sin = pi * double(m) / double(GridY); + n_cos = cos(n_sin); + n_sin = sin(n_sin); + im = (1.0 - n_cos) / n_sin * pow(Axis->up, 0.7); // up^0.7 is beauty correction + y = int(im / Axis->up * x2 + 0.5); // diameter - if(Axis->up <= 1.0) { // Smith chart with |r|=1 - beta = int(16.0*180.0*atan2(n_sin-im,n_cos-1.0)/pi - 0.5); - if(beta<0) beta += 16*360; - theta = 16*270-beta; - } - else { // Smith chart with |r|>1 - im = 1.0/im; - real = (rMAXq+1.0)/(rMAXq-1.0); - root = real*real - im*im - 1.0; - if(root < 0.0) { // circle lies completely within the Smith chart ? - beta = 0; // yes, ... - theta = 16*360; // ... draw whole circle - } - else { - // calculate both intersections with most outer circle - real1 = sqrt(root)-real; - real2 = -sqrt(root)-real; + if (Axis->up <= 1.0) { // Smith chart with |r|=1 + beta = int(16.0 * 180.0 * atan2(n_sin - im, n_cos - 1.0) / pi - 0.5); + if (beta < 0) beta += 16 * 360; + theta = 16 * 270 - beta; + } else { // Smith chart with |r|>1 + im = 1.0 / im; + real = (rMAXq + 1.0) / (rMAXq - 1.0); + root = real * real - im * im - 1.0; + if (root < 0.0) { // circle lies completely within the Smith chart ? + beta = 0; // yes, ... + theta = 16 * 360; // ... draw whole circle + } else { + // calculate both intersections with most outer circle + real1 = sqrt(root) - real; + real2 = -sqrt(root) - real; - root = (real1+1.0)*(real1+1.0) + im*im; - n_cos = (real1*real1 + im*im - 1.0) / root; - n_sin = 2.0*im / root; - beta = int(16.0*180.0*atan2(n_sin-1.0/im,n_cos-1.0)/pi); - if(beta<0) beta += 16*360; + root = (real1 + 1.0) * (real1 + 1.0) + im * im; + n_cos = (real1 * real1 + im * im - 1.0) / root; + n_sin = 2.0 * im / root; + beta = int(16.0 * 180.0 * atan2(n_sin - 1.0 / im, n_cos - 1.0) / pi); + if (beta < 0) beta += 16 * 360; - root = (real2+1.0)*(real2+1.0) + im*im; - n_cos = (real2*real2 + im*im - 1.0) / root; - n_sin = 2.0*im / root; - theta = int(16.0*180.0*atan2(n_sin-1/im,n_cos-1)/pi); - if(theta<0) theta += 16*360; - theta = theta - beta; // arc length - if(theta < 0) theta = 16*360+theta; - } + root = (real2 + 1.0) * (real2 + 1.0) + im * im; + n_cos = (real2 * real2 + im * im - 1.0) / root; + n_sin = 2.0 * im / root; + theta = int(16.0 * 180.0 * atan2(n_sin - 1 / im, n_cos - 1) / pi); + if (theta < 0) theta += 16 * 360; + theta = theta - beta; // arc length + if (theta < 0) theta = 16 * 360 + theta; + } + } + + if (Zplane) + x = (x2 + R1 - y) >> 1; + else { + x = (x2 - R1 - y) >> 1; + beta = 16 * 180 - beta - theta; // mirror + if (beta < 0) beta += 16 * 360; // angle has to be > 0 + } + + if (Above) + Arcs.append(new struct qucs::Arc(x, dx2 + y, y, y, beta, theta, GridPen)); + if (Below) + Arcs.append(new struct qucs::Arc(x, dx2, y, y, 16 * 360 - beta - theta, theta, GridPen)); } - if(Zplane) - x = (x2 + R1 - y) >> 1; - else { - x = (x2 - R1 - y) >> 1; - beta = 16*180 - beta - theta; // mirror - if(beta < 0) beta += 16*360; // angle has to be > 0 + // .................................................... + // draw arcs with Re(z)=const + theta = 0; // arc length + beta = 16 * 180; // start angle + if (Above) { + beta = 0; + theta = 16 * 180; + } + if (Below) theta += 16 * 180; + + for (m = 1; m < GridX; m++) { + im = m * (Axis->up + 1.0) / GridX - Axis->up; + y = int((1.0 - im) / Axis->up * double(dx2) + 0.5); // diameter + + if (Zplane) + x = ((x2 + R1) >> 1) - y; + else + x = (x2 - R1) >> 1; + if (fabs(fabs(im) - 1.0) > 0.2) // if too near to |r|=1, it looks ugly + Arcs.append(new struct qucs::Arc(x, (x2 + y) >> 1, y, y, beta, theta, GridPen)); + + if (Axis->up > 1.0) { // draw arcs on the rigth-handed side ? + im = 1.0 - im; + im = (rMAXq - 1.0) / (im * (im / 2.0 + 1.0)) - 1.0; + if (Zplane) x += y; + else x -= y; + if (im >= 1.0) + Arcs.append(new struct qucs::Arc(x, (x2 + y) >> 1, y, y, beta, theta, GridPen)); + else { + phi = int(16.0 * 180.0 / pi * acos(im)); + len = 16 * 180 - phi; + if (Above && Below) len += len; + else if (Below) phi = 16 * 180; + if (!Zplane) phi += 16 * 180; + Arcs.append(new struct qucs::Arc(x, (x2 + y) >> 1, y, y, phi, len, GridPen)); + } + } } - if(Above) - Arcs.append(new struct qucs::Arc(x, dx2+y, y, y, beta, theta, GridPen)); - if(Below) - Arcs.append(new struct qucs::Arc(x, dx2, y, y, 16*360-beta-theta, theta, GridPen)); - } - // .................................................... - // draw arcs with Re(z)=const - theta = 0; // arc length - beta = 16*180; // start angle - if(Above) { beta = 0; theta = 16*180; } - if(Below) theta += 16*180; + // .................................................... + if (Axis->up > 1.0) { // draw circle with |r|=1 ? + x = (x2 - R1) >> 1; + y = (x2 + R1) >> 1; + Arcs.append(new struct qucs::Arc(x, y, R1, R1, beta, theta, QPen(Qt::black, 0))); - for(m=1; mup+1.0)/GridX - Axis->up; - y = int((1.0-im)/Axis->up*double(dx2) + 0.5); // diameter + // vertical line Re(r)=1 (visible only if |r|>1) + if (Zplane) x = y; + y = int(sqrt(rMAXq - 1) / Axis->up * dx2 + 0.5); + if (Above) m = y; + else m = 0; + if (!Below) y = 0; + Lines.append(new qucs::Line(x, dx2 + m, x, dx2 - y, GridPen)); - if(Zplane) - x = ((x2+R1)>>1) - y; - else - x = (x2-R1)>>1; - if(fabs(fabs(im)-1.0) > 0.2) // if too near to |r|=1, it looks ugly - Arcs.append(new struct qucs::Arc(x, (x2+y)>>1, y, y, beta, theta, GridPen)); - - if(Axis->up > 1.0) { // draw arcs on the rigth-handed side ? - im = 1.0-im; - im = (rMAXq-1.0)/(im*(im/2.0+1.0)) - 1.0; - if(Zplane) x += y; - else x -= y; - if(im >= 1.0) - Arcs.append(new struct qucs::Arc(x, (x2+y)>>1, y, y, beta, theta, GridPen)); - else { - phi = int(16.0*180.0/pi*acos(im)); - len = 16*180-phi; - if(Above && Below) len += len; - else if(Below) phi = 16*180; - if(!Zplane) phi += 16*180; - Arcs.append(new struct qucs::Arc(x, (x2+y)>>1, y, y, phi, len, GridPen)); - } + if (Below) y = 4; + else y = y2 - 4 - QucsSettings.font.pointSize(); + Texts.append(new Text(0, y, misc::StringNum(Axis->up))); } - } - - - // .................................................... - if(Axis->up > 1.0) { // draw circle with |r|=1 ? - x = (x2-R1) >> 1; - y = (x2+R1) >> 1; - Arcs.append(new struct qucs::Arc(x, y, R1, R1, beta, theta, QPen(Qt::black,0))); - - // vertical line Re(r)=1 (visible only if |r|>1) - if(Zplane) x = y; - y = int(sqrt(rMAXq-1)/Axis->up*dx2 + 0.5); - if(Above) m = y; - else m = 0; - if(!Below) y = 0; - Lines.append(new qucs::Line(x, dx2+m, x, dx2-y, GridPen)); - - if(Below) y = 4; - else y = y2-4-QucsSettings.font.pointSize(); - Texts.append(new Text(0, y, misc::StringNum(Axis->up))); - } } // -------------------------------------------------------------- -void Diagram::calcPolarAxisScale(Axis *Axis, double& numGrids, - double& GridStep, double& zD) -{ - if(Axis->autoScale) { // auto-scale or user defined limits ? - double Expo, Base; - numGrids = floor(double(x2)/80.0); // minimal grid is 40 pixel - Expo = floor(log10(Axis->max/numGrids)); - Base = Axis->max/numGrids/pow(10.0,Expo);// get first significant digit - if(Base < 3.5) { // use only 1, 2 and 5, which ever is best fitted - if(Base < 1.5) Base = 1.0; - else Base = 2.0; - } - else { - if(Base < 7.5) Base = 5.0; - else { Base = 1.0; Expo++; } - } - GridStep = Base * pow(10.0,Expo); // grid distance in real values - numGrids -= floor(numGrids - Axis->max/GridStep); // correct num errors - Axis->up = GridStep*numGrids; +void Diagram::calcPolarAxisScale(Axis *Axis, double &numGrids, + double &GridStep, double &zD) { + if (Axis->autoScale) { // auto-scale or user defined limits ? + double Expo, Base; + numGrids = floor(double(x2) / 80.0); // minimal grid is 40 pixel + Expo = floor(log10(Axis->max / numGrids)); + Base = Axis->max / numGrids / pow(10.0, Expo);// get first significant digit + if (Base < 3.5) { // use only 1, 2 and 5, which ever is best fitted + if (Base < 1.5) Base = 1.0; + else Base = 2.0; + } else { + if (Base < 7.5) Base = 5.0; + else { + Base = 1.0; + Expo++; + } + } + GridStep = Base * pow(10.0, Expo); // grid distance in real values + numGrids -= floor(numGrids - Axis->max / GridStep); // correct num errors + Axis->up = GridStep * numGrids; - zD = double(x2) / numGrids; // grid distance in pixel - } - else { // no auto-scale - Axis->up = Axis->limit_max = fabs(Axis->limit_max); - GridStep = Axis->step; - zD = double(x2) / Axis->limit_max * Axis->step; // grid distance in pixel + zD = double(x2) / numGrids; // grid distance in pixel + } else { // no auto-scale + Axis->up = Axis->limit_max = fabs(Axis->limit_max); + GridStep = Axis->step; + zD = double(x2) / Axis->limit_max * Axis->step; // grid distance in pixel - if(fabs(zD) < 2.0) { // if grid too small, then no grid - zD = double(x2); - GridStep = Axis->step = Axis->up; - numGrids = 1.0; + if (fabs(zD) < 2.0) { // if grid too small, then no grid + zD = double(x2); + GridStep = Axis->step = Axis->up; + numGrids = 1.0; + } else numGrids = Axis->limit_max / Axis->step; } - else numGrids = Axis->limit_max / Axis->step; - } } // ------------------------------------------------------------ -void Diagram::createPolarDiagram(Axis *Axis, int Mode) -{ - xAxis.low = xAxis.min; - xAxis.up = xAxis.max; - Axis->low = 0.0; - if(fabs(Axis->min) > Axis->max) - Axis->max = fabs(Axis->min); // also fit negative values +void Diagram::createPolarDiagram(Axis *Axis, int Mode) { + xAxis.low = xAxis.min; + xAxis.up = xAxis.max; + Axis->low = 0.0; + if (fabs(Axis->min) > Axis->max) + Axis->max = fabs(Axis->min); // also fit negative values - bool Above = ((Mode & 1) == 1); // paint upper half ? - bool Below = ((Mode & 2) == 2); // paint lower half ? + bool Above = ((Mode & 1) == 1); // paint upper half ? + bool Below = ((Mode & 2) == 2); // paint lower half ? - int i, z, tmp; - if(Above) i = y2; else i = y2>>1; - if(Below) z = 0; else z = y2>>1; - // y line - Lines.append(new qucs::Line(x2>>1, i, x2>>1, z, GridPen)); + int i, z, tmp; + if (Above) i = y2; else i = y2 >> 1; + if (Below) z = 0; else z = y2 >> 1; + // y line + Lines.append(new qucs::Line(x2 >> 1, i, x2 >> 1, z, GridPen)); - int len = 0; // arc length - int beta = 16*180; // start angle - if(Above) { beta = 0; len = 16*180; } - if(Below) len += 16*180; - - int phi, tPos; - int tHeight = QucsSettings.font.pointSize() + 5; - if(!Below) tPos = (y2>>1) + 3; - else tPos = (y2>>1) - tHeight + 3; - - double Expo, Base, numGrids, GridStep, zD; - if(xAxis.GridOn) { - calcPolarAxisScale(Axis, numGrids, GridStep, zD); - - double zDstep = zD; - double GridNum = 0.0; - for(i=int(numGrids); i>1; i--) { // create all grid circles - z = int(zD); - GridNum += GridStep; - QString lbl; - if (engineeringNotation) lbl = misc::num2str(GridNum); - else lbl = misc::StringNiceNum(GridNum); - Texts.append(new Text(((x2+z)>>1)-10, tPos, lbl)); - - phi = int(16.0*180.0/pi*atan(double(2*tHeight)/zD)); - if(!Below) tmp = beta + phi; - else tmp = beta; - Arcs.append(new struct qucs::Arc((x2-z)>>1, (y2+z)>>1, z, z, tmp, len-phi, - GridPen)); - zD += zDstep; + int len = 0; // arc length + int beta = 16 * 180; // start angle + if (Above) { + beta = 0; + len = 16 * 180; } - } - else { // of "if(GridOn)" - Expo = floor(log10(Axis->max)); - Base = ceil(Axis->max/pow(10.0,Expo) - 0.01); - Axis->up = Base * pow(10.0,Expo); // separate Base * 10^Expo - } + if (Below) len += 16 * 180; - // create outer circle - Texts.append(new Text(x2-8, tPos, misc::StringNiceNum(Axis->up))); - phi = int(16.0*180.0/pi*atan(double(2*tHeight)/double(x2))); - if(!Below) tmp = phi; - else tmp = 0; - Arcs.append(new struct qucs::Arc(0, y2, x2, y2, tmp, 16*360-phi, QPen(Qt::black,0))); + int phi, tPos; + int tHeight = QucsSettings.font.pointSize() + 5; + if (!Below) tPos = (y2 >> 1) + 3; + else tPos = (y2 >> 1) - tHeight + 3; - // get size of text using the screen-compatible metric - QFontMetrics metrics(QucsSettings.font, 0); - QSize r = metrics.size(0, Texts.last()->s); // width of text - len = x2+r.width()-4; // more space at the right - if(len > x3) x3 = len; + double Expo, Base, numGrids, GridStep, zD; + if (xAxis.GridOn) { + calcPolarAxisScale(Axis, numGrids, GridStep, zD); + + double zDstep = zD; + double GridNum = 0.0; + for (i = int(numGrids); i > 1; i--) { // create all grid circles + z = int(zD); + GridNum += GridStep; + QString lbl; + if (engineeringNotation) lbl = misc::num2str(GridNum); + else lbl = misc::StringNiceNum(GridNum); + Texts.append(new Text(((x2 + z) >> 1) - 10, tPos, lbl)); + + phi = int(16.0 * 180.0 / pi * atan(double(2 * tHeight) / zD)); + if (!Below) tmp = beta + phi; + else tmp = beta; + Arcs.append(new struct qucs::Arc((x2 - z) >> 1, (y2 + z) >> 1, z, z, tmp, len - phi, + GridPen)); + zD += zDstep; + } + } else { // of "if(GridOn)" + Expo = floor(log10(Axis->max)); + Base = ceil(Axis->max / pow(10.0, Expo) - 0.01); + Axis->up = Base * pow(10.0, Expo); // separate Base * 10^Expo + } + + // create outer circle + Texts.append(new Text(x2 - 8, tPos, misc::StringNiceNum(Axis->up))); + phi = int(16.0 * 180.0 / pi * atan(double(2 * tHeight) / double(x2))); + if (!Below) tmp = phi; + else tmp = 0; + Arcs.append(new struct qucs::Arc(0, y2, x2, y2, tmp, 16 * 360 - phi, QPen(Qt::black, 0))); + + // get size of text using the screen-compatible metric + QFontMetrics metrics(QucsSettings.font, 0); + QSize r = metrics.size(0, Texts.last()->s); // width of text + len = x2 + r.width() - 4; // more space at the right + if (len > x3) x3 = len; } /*! @@ -1738,111 +1716,114 @@ void Diagram::createPolarDiagram(Axis *Axis, int Mode) \param[out] zD - screen coordinate where the first grid is placed \param[out] zDstep - distance on screen from one grid to the next */ -bool Diagram::calcAxisScale(Axis *Axis, double& GridNum, double& zD, - double& zDstep, double& GridStep, double Dist) -{ - bool back=false; - double numGrids, Base, Expo, corr; -if(Axis->autoScale) { +bool Diagram::calcAxisScale(Axis *Axis, double &GridNum, double &zD, + double &zDstep, double &GridStep, double Dist) { + bool back = false; + double numGrids, Base, Expo, corr; + if (Axis->autoScale) { - if(fabs(Axis->max-Axis->min) < 1e-200) { - if((Axis->max == 0.0) && (Axis->min == 0.0)) { - Axis->up = 1.0; - Axis->low = -1.0; + if (fabs(Axis->max - Axis->min) < 1e-200) { + if ((Axis->max == 0.0) && (Axis->min == 0.0)) { + Axis->up = 1.0; + Axis->low = -1.0; + } else { // if max = min, double difference + Axis->up = Axis->max + fabs(Axis->max); + Axis->low = Axis->min - fabs(Axis->min); + } + } else if (Axis != &xAxis) { + // keep a small bounding between graph and diagram limit + Axis->up = Axis->max + 0.1 * (Axis->max - Axis->min); + Axis->low = Axis->min - 0.1 * (Axis->max - Axis->min); + } else { + Axis->up = Axis->max; // normal case for x axis + Axis->low = Axis->min; + } + + + numGrids = floor(Dist / 60.0); // minimal grid is 60 pixel + if (numGrids < 1.0) Base = Axis->up - Axis->low; + else Base = (Axis->up - Axis->low) / numGrids; + Expo = floor(log10(Base)); + Base = Base / pow(10.0, Expo); // separate first significant digit + if (Base < 3.5) { // use only 1, 2 and 5, which ever is best fitted + if (Base < 1.5) Base = 1.0; + else Base = 2.0; + } else { + if (Base < 7.5) Base = 5.0; + else { + Base = 1.0; + Expo++; + } + } + GridStep = Base * pow(10.0, Expo); // grid distance in real coordinates + corr = floor((Axis->up - Axis->low) / GridStep - numGrids); + if (corr < 0.0) corr++; + numGrids += corr; // correct rounding faults + + + // upper y boundary ........................... + zD = fabs(fmod(Axis->up, GridStep));// expand grid to upper diagram edge ? + GridNum = zD / GridStep; + if ((1.0 - GridNum) < 1e-10) GridNum = 0.0; // fix rounding errors + if (Axis->up <= 0.0) { + if (GridNum < 0.3) { + Axis->up += zD; + zD = 0.0; + } + } else if (GridNum > 0.7) Axis->up += GridStep - zD; + else if (GridNum < 0.1) + if (GridNum * Dist >= 1.0)// more than 1 pixel above ? + Axis->up += 0.3 * GridStep; // beauty correction + + + // lower y boundary ........................... + zD = fabs(fmod(Axis->low, GridStep));// expand grid to lower diagram edge ? + GridNum = zD / GridStep; + if ((1.0 - GridNum) < 1e-10) zD = GridNum = 0.0; // fix rounding errors + if (Axis->low <= 0.0) { + if (GridNum > 0.7) { + Axis->low -= GridStep - zD; + zD = 0.0; + } + else if (GridNum < 0.1) + if (GridNum * Dist >= 1.0) { // more than 1 pixel above ? + Axis->low -= 0.3 * GridStep; // beauty correction + zD += 0.3 * GridStep; + } + } else { + if (GridNum > 0.3) { + zD = GridStep - zD; + if (GridNum > 0.9) { + if ((1.0 - GridNum) * Dist >= 1.0) { // more than 1 pixel above ? + Axis->low -= 0.3 * GridStep; // beauty correction + zD += 0.3 * GridStep; + } + } + } else { + Axis->low -= zD; + zD = 0.0; + } + } + + GridNum = Axis->low + zD; + zD /= (Axis->up - Axis->low) / Dist; + } else { // user defined limits + zD = 0.0; + Axis->low = GridNum = Axis->limit_min; + Axis->up = Axis->limit_max; + if (Axis->limit_max < Axis->limit_min) + back = true; + GridStep = Axis->step; } - else { // if max = min, double difference - Axis->up = Axis->max + fabs(Axis->max); - Axis->low = Axis->min - fabs(Axis->min); + + zDstep = GridStep / (Axis->up - Axis->low) * Dist; // grid in pixel + + if (fabs(zDstep) < 2.0) { // if grid too small, then no grid + zDstep = Dist; + GridStep = Axis->step = Axis->up - Axis->low; } - } - else if(Axis != &xAxis) { - // keep a small bounding between graph and diagram limit - Axis->up = Axis->max + 0.1*(Axis->max-Axis->min); - Axis->low = Axis->min - 0.1*(Axis->max-Axis->min); - } - else { - Axis->up = Axis->max; // normal case for x axis - Axis->low = Axis->min; - } - - numGrids = floor(Dist/60.0); // minimal grid is 60 pixel - if(numGrids < 1.0) Base = Axis->up-Axis->low; - else Base = (Axis->up-Axis->low)/numGrids; - Expo = floor(log10(Base)); - Base = Base/pow(10.0,Expo); // separate first significant digit - if(Base < 3.5) { // use only 1, 2 and 5, which ever is best fitted - if(Base < 1.5) Base = 1.0; - else Base = 2.0; - } - else { - if(Base < 7.5) Base = 5.0; - else { Base = 1.0; Expo++; } - } - GridStep = Base * pow(10.0,Expo); // grid distance in real coordinates - corr = floor((Axis->up-Axis->low)/GridStep - numGrids); - if(corr < 0.0) corr++; - numGrids += corr; // correct rounding faults - - - // upper y boundary ........................... - zD = fabs(fmod(Axis->up, GridStep));// expand grid to upper diagram edge ? - GridNum = zD/GridStep; - if((1.0-GridNum) < 1e-10) GridNum = 0.0; // fix rounding errors - if(Axis->up <= 0.0) { - if(GridNum < 0.3) { Axis->up += zD; zD = 0.0; } - } - else if(GridNum > 0.7) Axis->up += GridStep-zD; - else if(GridNum < 0.1) - if(GridNum*Dist >= 1.0)// more than 1 pixel above ? - Axis->up += 0.3*GridStep; // beauty correction - - - // lower y boundary ........................... - zD = fabs(fmod(Axis->low, GridStep));// expand grid to lower diagram edge ? - GridNum = zD/GridStep; - if((1.0-GridNum) < 1e-10) zD = GridNum = 0.0; // fix rounding errors - if(Axis->low <= 0.0) { - if(GridNum > 0.7) { Axis->low -= GridStep-zD; zD = 0.0; } - else if(GridNum < 0.1) - if(GridNum*Dist >= 1.0) { // more than 1 pixel above ? - Axis->low -= 0.3*GridStep; // beauty correction - zD += 0.3*GridStep; - } - } - else { - if(GridNum > 0.3) { - zD = GridStep-zD; - if(GridNum > 0.9) { - if((1.0-GridNum)*Dist >= 1.0) { // more than 1 pixel above ? - Axis->low -= 0.3*GridStep; // beauty correction - zD += 0.3*GridStep; - } - } - } - else { Axis->low -= zD; zD = 0.0; } - } - - GridNum = Axis->low + zD; - zD /= (Axis->up-Axis->low)/Dist; -} -else { // user defined limits - zD = 0.0; - Axis->low = GridNum = Axis->limit_min; - Axis->up = Axis->limit_max; - if(Axis->limit_max < Axis->limit_min) - back = true; - GridStep = Axis->step; -} - - zDstep = GridStep/(Axis->up-Axis->low)*Dist; // grid in pixel - - if(fabs(zDstep) < 2.0) { // if grid too small, then no grid - zDstep = Dist; - GridStep = Axis->step = Axis->up-Axis->low; - } - - return back; + return back; } /*! @@ -1860,201 +1841,200 @@ else { // user defined limits \todo use this as example to document other methods */ -bool Diagram::calcAxisLogScale(Axis *Axis, int& z, double& zD, - double& zDstep, double& corr, int len) -{ - if(fabs(Axis->max-Axis->min) < 1e-200) { // if max = min, double difference - Axis->max *= 10.0; - Axis->min /= 10.0; - } - Axis->low = Axis->min; Axis->up = Axis->max; +bool Diagram::calcAxisLogScale(Axis *Axis, int &z, double &zD, + double &zDstep, double &corr, int len) { + if (fabs(Axis->max - Axis->min) < 1e-200) { // if max = min, double difference + Axis->max *= 10.0; + Axis->min /= 10.0; + } + Axis->low = Axis->min; + Axis->up = Axis->max; - if(!Axis->autoScale) { - Axis->low = Axis->limit_min; - Axis->up = Axis->limit_max; - } - - - bool mirror=false, mirror2=false; - double tmp; - if(Axis->up < 0.0) { // for negative values - tmp = Axis->low; - Axis->low = -Axis->up; - Axis->up = -tmp; - mirror = true; - } - - double Base, Expo; - if(Axis->autoScale) { - if(mirror) { // set back values ? - tmp = Axis->min; - Axis->min = -Axis->max; - Axis->max = -tmp; + if (!Axis->autoScale) { + Axis->low = Axis->limit_min; + Axis->up = Axis->limit_max; } - Expo = floor(log10(Axis->max)); - Base = Axis->max/pow(10.0,Expo); - if(Base > 3.0001) Axis->up = pow(10.0,Expo+1.0); - else if(Base < 1.0001) Axis->up = pow(10.0,Expo); - else Axis->up = 3.0 * pow(10.0,Expo); - Expo = floor(log10(Axis->min)); - Base = Axis->min/pow(10.0,Expo); - if(Base < 2.999) Axis->low = pow(10.0,Expo); - else if(Base > 9.999) Axis->low = pow(10.0,Expo+1.0); - else Axis->low = 3.0 * pow(10.0,Expo); - - corr = double(len) / log10(Axis->up / Axis->low); - - z = 0; - zD = Axis->low; - zDstep = pow(10.0,Expo); - - if(mirror) { // set back values ? - tmp = Axis->min; - Axis->min = -Axis->max; - Axis->max = -tmp; - } - } - else { // user defined limits - if(Axis->up < Axis->low) { - tmp = Axis->low; - Axis->low = Axis->up; - Axis->up = tmp; - mirror2 = true; + bool mirror = false, mirror2 = false; + double tmp; + if (Axis->up < 0.0) { // for negative values + tmp = Axis->low; + Axis->low = -Axis->up; + Axis->up = -tmp; + mirror = true; } - Expo = floor(log10(Axis->low)); - Base = ceil(Axis->low/pow(10.0,Expo)); - zD = Base * pow(10.0, Expo); - zDstep = pow(10.0,Expo); - if(zD > 9.5*zDstep) zDstep *= 10.0; + double Base, Expo; + if (Axis->autoScale) { + if (mirror) { // set back values ? + tmp = Axis->min; + Axis->min = -Axis->max; + Axis->max = -tmp; + } - corr = double(len) / log10(Axis->up / Axis->low); - z = int(corr*log10(zD / Axis->low) + 0.5); // int(..) implies floor(..) + Expo = floor(log10(Axis->max)); + Base = Axis->max / pow(10.0, Expo); + if (Base > 3.0001) Axis->up = pow(10.0, Expo + 1.0); + else if (Base < 1.0001) Axis->up = pow(10.0, Expo); + else Axis->up = 3.0 * pow(10.0, Expo); - if(mirror2) { // set back values ? - tmp = Axis->low; - Axis->low = Axis->up; - Axis->up = tmp; + Expo = floor(log10(Axis->min)); + Base = Axis->min / pow(10.0, Expo); + if (Base < 2.999) Axis->low = pow(10.0, Expo); + else if (Base > 9.999) Axis->low = pow(10.0, Expo + 1.0); + else Axis->low = 3.0 * pow(10.0, Expo); + + corr = double(len) / log10(Axis->up / Axis->low); + + z = 0; + zD = Axis->low; + zDstep = pow(10.0, Expo); + + if (mirror) { // set back values ? + tmp = Axis->min; + Axis->min = -Axis->max; + Axis->max = -tmp; + } + } else { // user defined limits + if (Axis->up < Axis->low) { + tmp = Axis->low; + Axis->low = Axis->up; + Axis->up = tmp; + mirror2 = true; + } + + Expo = floor(log10(Axis->low)); + Base = ceil(Axis->low / pow(10.0, Expo)); + zD = Base * pow(10.0, Expo); + zDstep = pow(10.0, Expo); + if (zD > 9.5 * zDstep) zDstep *= 10.0; + + corr = double(len) / log10(Axis->up / Axis->low); + z = int(corr * log10(zD / Axis->low) + 0.5); // int(..) implies floor(..) + + if (mirror2) { // set back values ? + tmp = Axis->low; + Axis->low = Axis->up; + Axis->up = tmp; + } } - } - if(mirror) { // set back values ? - tmp = Axis->low; - Axis->low = -Axis->up; - Axis->up = -tmp; - } + if (mirror) { // set back values ? + tmp = Axis->low; + Axis->low = -Axis->up; + Axis->up = -tmp; + } - if(mirror == mirror2) return false; - else return true; + if (mirror == mirror2) return false; + else return true; } // -------------------------------------------------------------- -bool Diagram::calcYAxis(Axis *Axis, int x0) -{ - int z, w; - double GridStep, corr, zD, zDstep, GridNum; +bool Diagram::calcYAxis(Axis *Axis, int x0) { + int z, w; + double GridStep, corr, zD, zDstep, GridNum; - QString tmp; - // get size of text using the screen-compatible metric - QFontMetrics metrics(QucsSettings.font, 0); - int maxWidth = 0; + QString tmp; + // get size of text using the screen-compatible metric + QFontMetrics metrics(QucsSettings.font, 0); + int maxWidth = 0; - bool back = false; -if(Axis->log) { - if(Axis->autoScale) { - if(Axis->max*Axis->min <= 0.0) return false; // invalid - } - else if(Axis->limit_min*Axis->limit_max <= 0.0) return false; // invalid + bool back = false; + if (Axis->log) { + if (Axis->autoScale) { + if (Axis->max * Axis->min <= 0.0) return false; // invalid + } else if (Axis->limit_min * Axis->limit_max <= 0.0) return false; // invalid - back = calcAxisLogScale(Axis, z, zD, zDstep, corr, y2); + back = calcAxisLogScale(Axis, z, zD, zDstep, corr, y2); - if(back) z = y2; - while((z <= y2) && (z >= 0)) { // create all grid lines - if(Axis->GridOn) if(z < y2) if(z > 0) { - if (Axis->Units == Axis::NoUnits) { - Lines.prepend(new qucs::Line(0, z, x2, z, GridPen)); // y grid - } - } + if (back) z = y2; + while ((z <= y2) && (z >= 0)) { // create all grid lines + if (Axis->GridOn) + if (z < y2) + if (z > 0) { + if (Axis->Units == Axis::NoUnits) { + Lines.prepend(new qucs::Line(0, z, x2, z, GridPen)); // y grid + } + } - if((zD < 1.5*zDstep) || (z == 0)) { - double yVal = qucs::num2db(zD,Axis->Units); - if (engineeringNotation) tmp = misc::num2str(yVal); - else tmp = misc::StringNiceNum(yVal); + if ((zD < 1.5 * zDstep) || (z == 0)) { + double yVal = qucs::num2db(zD, Axis->Units); + if (engineeringNotation) tmp = misc::num2str(yVal); + else tmp = misc::StringNiceNum(yVal); - if(Axis->up < 0.0) tmp = '-'+tmp; + if (Axis->up < 0.0) tmp = '-' + tmp; - w = metrics.boundingRect(tmp).width(); // width of text - if(maxWidth < w) maxWidth = w; - if(x0 > 0) - Texts.append(new Text(x0+7, z-6, tmp)); // text aligned left - else - Texts.append(new Text(-w-7, z-6, tmp)); // text aligned right + w = metrics.boundingRect(tmp).width(); // width of text + if (maxWidth < w) maxWidth = w; + if (x0 > 0) + Texts.append(new Text(x0 + 7, z - 6, tmp)); // text aligned left + else + Texts.append(new Text(-w - 7, z - 6, tmp)); // text aligned right - // y marks - if (Axis->Units != Axis::NoUnits) { - Lines.prepend(new qucs::Line(0, z, x2, z, GridPen)); // y grid - } - Lines.append(new qucs::Line(x0-5, z, x0+5, z, QPen(Qt::black,0))); - } + // y marks + if (Axis->Units != Axis::NoUnits) { + Lines.prepend(new qucs::Line(0, z, x2, z, GridPen)); // y grid + } + Lines.append(new qucs::Line(x0 - 5, z, x0 + 5, z, QPen(Qt::black, 0))); + } - zD += zDstep; - if(zD > 9.5*zDstep) zDstep *= 10.0; - if(back) { - z = int(corr*log10(zD / fabs(Axis->up)) + 0.5); // int() implies floor() - z = y2 - z; - } - else - z = int(corr*log10(zD / fabs(Axis->low)) + 0.5);// int() implies floor() - } -} -else { // not logarithmical - back = calcAxisScale(Axis, GridNum, zD, zDstep, GridStep, double(y2)); + zD += zDstep; + if (zD > 9.5 * zDstep) zDstep *= 10.0; + if (back) { + z = int(corr * log10(zD / fabs(Axis->up)) + 0.5); // int() implies floor() + z = y2 - z; + } else + z = int(corr * log10(zD / fabs(Axis->low)) + 0.5);// int() implies floor() + } + } else { // not logarithmical + back = calcAxisScale(Axis, GridNum, zD, zDstep, GridStep, double(y2)); - double Expo; - if(Axis->up == 0.0) Expo = log10(fabs(Axis->up-Axis->low)); - else Expo = log10(fabs(Axis->up)); + double Expo; + if (Axis->up == 0.0) Expo = log10(fabs(Axis->up - Axis->low)); + else Expo = log10(fabs(Axis->up)); - zD += 0.5; // perform rounding - z = int(zD); // "int(...)" implies "floor(...)" - while((z <= y2) && (z >= 0)) { // create all grid lines - if(fabs(GridNum) < 0.01*pow(10.0, Expo)) GridNum = 0.0;// make 0 really 0 - if (engineeringNotation) tmp = misc::num2str(GridNum); - else tmp = misc::StringNiceNum(GridNum); + zD += 0.5; // perform rounding + z = int(zD); // "int(...)" implies "floor(...)" + while ((z <= y2) && (z >= 0)) { // create all grid lines + if (fabs(GridNum) < 0.01 * pow(10.0, Expo)) GridNum = 0.0;// make 0 really 0 + if (engineeringNotation) tmp = misc::num2str(GridNum); + else tmp = misc::StringNiceNum(GridNum); - w = metrics.boundingRect(tmp).width(); // width of text - if(maxWidth < w) maxWidth = w; - if(x0 > 0) - Texts.append(new Text(x0+8, z-6, tmp)); // text aligned left - else - Texts.append(new Text(-w-7, z-6, tmp)); // text aligned right - GridNum += GridStep; + w = metrics.boundingRect(tmp).width(); // width of text + if (maxWidth < w) maxWidth = w; + if (x0 > 0) + Texts.append(new Text(x0 + 8, z - 6, tmp)); // text aligned left + else + Texts.append(new Text(-w - 7, z - 6, tmp)); // text aligned right + GridNum += GridStep; - if(Axis->GridOn) if(z < y2) if(z > 0) - Lines.prepend(new qucs::Line(0, z, x2, z, GridPen)); // y grid - Lines.append(new qucs::Line(x0-5, z, x0+5, z, QPen(Qt::black,0))); // y marks - zD += zDstep; - z = int(zD); - } -} // of "if(ylog) ... else ..." - if(x0 == 0) x1 = maxWidth+14; - else x3 = x2+maxWidth+14; - return true; + if (Axis->GridOn) + if (z < y2) + if (z > 0) + Lines.prepend(new qucs::Line(0, z, x2, z, GridPen)); // y grid + Lines.append(new qucs::Line(x0 - 5, z, x0 + 5, z, QPen(Qt::black, 0))); // y marks + zD += zDstep; + z = int(zD); + } + } // of "if(ylog) ... else ..." + if (x0 == 0) x1 = maxWidth + 14; + else x3 = x2 + maxWidth + 14; + return true; } // convenience wrappers -bool Diagram::insideDiagramP(Graph::iterator const& p) const -{ - float f1 = p->getScrX(); - float f2 = p->getScrY(); - return insideDiagram(f1,f2); +bool Diagram::insideDiagramP(Graph::iterator const &p) const { + float f1 = p->getScrX(); + float f2 = p->getScrY(); + return insideDiagram(f1, f2); } -void Diagram::calcCoordinateP (const double*x, const double*y, const double*z, Graph::iterator& p, Axis const* A) const -{ - float f1, f2; - calcCoordinate(x, y, z, &f1, &f2, A); - p->setScr(f1, f2); + +void +Diagram::calcCoordinateP(const double *x, const double *y, const double *z, Graph::iterator &p, Axis const *A) const { + float f1, f2; + calcCoordinate(x, y, z, &f1, &f2, A); + p->setScr(f1, f2); }; diff --git a/qucs/diagrams/diagramdialog.cpp b/qucs/diagrams/diagramdialog.cpp index 294f68f3..c3b53eb0 100644 --- a/qucs/diagrams/diagramdialog.cpp +++ b/qucs/diagrams/diagramdialog.cpp @@ -792,7 +792,7 @@ DiagramDialog::DiagramDialog(Diagram *d, QWidget *parent, Graph *currentGraph) // ........................................................... // put all graphs into the ListBox Row = 0; - foreach(Graph *pg, Diag->Graphs) { + for (Graph *pg : Diag->Graphs) { GraphList->insertItem(Row, pg->Var); if(pg == currentGraph) { GraphList->setCurrentRow(Row); // select current graph @@ -1486,7 +1486,7 @@ void DiagramDialog::slotSetGraphStyle(int style) */ void DiagramDialog::copyDiagramGraphs() { - foreach(Graph *pg, Diag->Graphs) + for (Graph *pg : Diag->Graphs) Graphs.append(pg->sameNewOne()); } diff --git a/qucs/diagrams/graph.cpp b/qucs/diagrams/graph.cpp index 5621d2a3..5e8efa5b 100644 --- a/qucs/diagrams/graph.cpp +++ b/qucs/diagrams/graph.cpp @@ -103,7 +103,7 @@ QString Graph::save() " "+QString::number(numMode)+" "+QString::number(Style)+ " "+QString::number(yAxisNo)+">"; - foreach(Marker *pm, Markers) + for (Marker *pm : Markers) s += "\n\t "+pm->save(); return s; @@ -258,7 +258,7 @@ Graph* Graph::sameNewOne() pg->numMode = numMode; pg->yAxisNo = yAxisNo; - foreach(Marker *pm, Markers) + for (Marker *pm : Markers) pg->Markers.append(pm->sameNewOne(pg)); return pg; diff --git a/qucs/diagrams/rect3ddiagram.cpp b/qucs/diagrams/rect3ddiagram.cpp index 8726b3c0..38c5b69f 100644 --- a/qucs/diagrams/rect3ddiagram.cpp +++ b/qucs/diagrams/rect3ddiagram.cpp @@ -390,7 +390,7 @@ void Rect3DDiagram::removeHiddenLines(char *zBuffer, tBound *Bounds) tPoint3D *p; int i, j, z, dx, dy, Size=0; // pre-calculate buffer size to avoid reallocations in the first step - foreach(Graph *g, Graphs) + for (Graph *g : Graphs) if(g->cPointsY) Size += g->axis(0)->count * g->countY; @@ -410,7 +410,7 @@ void Rect3DDiagram::removeHiddenLines(char *zBuffer, tBound *Bounds) tPointZ *zp = zMem, *zp_tmp; // ............................................................... - foreach(Graph *g, Graphs) { + for (Graph *g : Graphs) { pz = g->cPointsY; if(!pz) continue; @@ -533,7 +533,7 @@ void Rect3DDiagram::removeHiddenLines(char *zBuffer, tBound *Bounds) tPoint3D *MemEnd = Mem + malloc_8xsize*2*Size - 5; // limit of buffer zp = zMem; - foreach(Graph *g, Graphs) { + for (Graph *g : Graphs) { if(!g->cPointsY) continue; dx = g->axis(0)->count; if(g->countY > 1) dy = g->axis(1)->count; @@ -788,7 +788,7 @@ void Rect3DDiagram::createAxis(Axis *Axis, bool Right, y = y1_ - int(double(valid)*cos_phi); if(Axis->Label.isEmpty()) { // write all labels ---------------------------------------- - foreach(Graph *pg, Graphs) { + for (Graph *pg : Graphs) { if(Axis != &zAxis) { if(!pg->cPointsY) continue; if(valid < 0) { diff --git a/qucs/diagrams/tabdiagram.cpp b/qucs/diagrams/tabdiagram.cpp index 0747d2c8..2691379b 100644 --- a/qucs/diagrams/tabdiagram.cpp +++ b/qucs/diagrams/tabdiagram.cpp @@ -55,7 +55,7 @@ void TabDiagram::paint(ViewPainter *p) void TabDiagram::paintDiagram(ViewPainter *p) { // paint all lines - foreach(qucs::Line *pl, Lines) { + for (qucs::Line *pl : Lines) { p->Painter->setPen(pl->style); p->drawLine(cx+pl->x1, cy-pl->y1, cx+pl->x2, cy-pl->y2); } @@ -109,7 +109,7 @@ void TabDiagram::paintDiagram(ViewPainter *p) p->Painter->setPen(Qt::black); // write whole text - foreach(Text *pt, Texts) + for (Text *pt : Texts) p->drawText(pt->s, cx+pt->x, cy-pt->y); @@ -243,7 +243,7 @@ int TabDiagram::calcDiagram() firstGraph = g; // ................................................ // all dependent variables - foreach(Graph *g, Graphs) { + for (Graph *g : Graphs) { y = y2-tHeight-5; colWidth = 0; diff --git a/qucs/diagrams/timingdiagram.cpp b/qucs/diagrams/timingdiagram.cpp index 7cd53943..181ab5ae 100644 --- a/qucs/diagrams/timingdiagram.cpp +++ b/qucs/diagrams/timingdiagram.cpp @@ -54,14 +54,14 @@ void TimingDiagram::paint(ViewPainter *p) void TimingDiagram::paintDiagram(ViewPainter *p) { // paint all lines - foreach(qucs::Line *pl, Lines) { + for(qucs::Line *pl : Lines) { p->Painter->setPen(pl->style); p->drawLine(cx+pl->x1, cy-pl->y1, cx+pl->x2, cy-pl->y2); } p->Painter->setPen(Qt::black); // write whole text - foreach(Text *pt, Texts) + for(Text *pt : Texts) p->drawText(pt->s, cx+pt->x, cy-pt->y); @@ -187,7 +187,7 @@ int TimingDiagram::calcDiagram() // First check the maximum bit number of all vectors. colWidth = 0; - foreach(Graph *g, Graphs) + for (Graph *g : Graphs) if(g->cPointsY) { if(g->Var.right(2) == ".X") { z = strlen((char*)g->cPointsY); @@ -228,7 +228,7 @@ if(!firstGraph->isEmpty()) { y -= 5; // write all dependent variable names to get width of first column - foreach(Graph *g, Graphs) { + for (Graph *g : Graphs) { if(y < tHeight) break; Str = g->Var; colWidth = checkColumnWidth(Str, metrics, colWidth, x, y); @@ -276,7 +276,7 @@ if(!firstGraph->isEmpty()) { QPen Pen; int yLast, yNow; y = y2-tHeight-9; - foreach(Graph *g, Graphs) { + for (Graph *g : Graphs) { if(y < tHeight) { // mark lack of space with a small arrow Lines.append(new qucs::Line(4, 6, 4, -7, QPen(Qt::red,2))); diff --git a/qucs/diagrams/truthdiagram.cpp b/qucs/diagrams/truthdiagram.cpp index a9028b86..c9abd132 100644 --- a/qucs/diagrams/truthdiagram.cpp +++ b/qucs/diagrams/truthdiagram.cpp @@ -154,7 +154,7 @@ int TruthDiagram::calcDiagram() firstGraph = g; // ................................................ // all dependent variables - foreach(Graph *g ,Graphs) { + for (Graph *g : Graphs) { y = y2-tHeight-5; Str = g->Var; diff --git a/qucs/dialogs/librarydialog.cpp b/qucs/dialogs/librarydialog.cpp index e0cd1ff8..6362c885 100644 --- a/qucs/dialogs/librarydialog.cpp +++ b/qucs/dialogs/librarydialog.cpp @@ -507,12 +507,12 @@ void LibraryDialog::slotSave() XSPICE_CMbuilder *bld = new XSPICE_CMbuilder(Doc); QStringList srcs,dsts; bld->getModIfsFileList(srcs); - foreach(QString ifl,srcs) { + for (QString& ifl : srcs) { QString ofl=ifl; intoFile(ifl,ofl,dsts); } QString s = " selectedPaths = pathsTableWidget->selectedItems(); - foreach (QTableWidgetItem * item, selectedPaths) + for (QTableWidgetItem * item : selectedPaths) { QString path = item->text(); //removedPaths.append(path); @@ -1101,7 +1101,7 @@ void QucsSettingsDialog::makePathTable() pathsTableWidget->setRowCount(0); // fill listview with the list of paths - foreach (QString pathstr, currentPaths) + for (const QString& pathstr : currentPaths) { int row = pathsTableWidget->rowCount(); pathsTableWidget->setRowCount(row+1); diff --git a/qucs/extsimkernels/abstractspicekernel.cpp b/qucs/extsimkernels/abstractspicekernel.cpp index 050940a8..2eacdc01 100644 --- a/qucs/extsimkernels/abstractspicekernel.cpp +++ b/qucs/extsimkernels/abstractspicekernel.cpp @@ -264,16 +264,15 @@ void AbstractSpiceKernel::createSubNetlsit(QTextStream &stream, bool lib) } } std::sort(ports.begin(), ports.end()); - QPair pp; if (lib) header += " gnd "; // Ground node forwarding for Library - foreach(pp,ports) { + for (const auto& pp : ports) { header += pp.second + " "; } - Painting *pi; - for(pi = Sch->SymbolPaints.first(); pi != 0; pi = Sch->SymbolPaints.next()) - if(pi->Name == ".ID ") { - ID_Text *pid = (ID_Text*)pi; + Painting *pai; + for(pai = Sch->SymbolPaints.first(); pai != 0; pai = Sch->SymbolPaints.next()) + if(pai->Name == ".ID ") { + ID_Text *pid = (ID_Text*)pai; QList::const_iterator it; for(it = pid->Parameter.constBegin(); it != pid->Parameter.constEnd(); it++) { header += (*it)->Name + " "; // keep 'Name' unchanged @@ -413,7 +412,7 @@ void AbstractSpiceKernel::parseHBOutput(QString ngspice_file, QList1) ParSwp = true; - foreach (QString lin, lines) { // Extract poles + for (const QString& lin : lines) { // Extract poles if (lin.contains(var + "(")) { if (!var_list.contains(var)) { var_list.append(var+"_number"); @@ -637,7 +639,7 @@ void AbstractSpiceKernel::parseDC_OPoutput(QString ngspice_file) if (ofile.open(QFile::ReadOnly)) { QTextStream ngsp_data(&ofile); QStringList lines = ngsp_data.readAll().split("\n"); - foreach (QString lin,lines) { + for (const QString& lin : lines) { if (lin.contains('=')) { QString nod = lin.section('=',0,0).remove(' '); double val = lin.section('=',1,1).toDouble(); @@ -1044,10 +1046,12 @@ void AbstractSpiceKernel::convertToQucsData(const QString &qucs_dataset) { if (DC_OP_only) { // Don't touch existing datasets when only DC was simulated // It's need to show DC bias on schematic only - foreach(QString output,output_files) { - QString full_outfile = workdir+QDir::separator()+output; - if (output.endsWith(".dc_op")) parseDC_OPoutput(full_outfile); - else if (output.endsWith(".dc_op_xyce")) parseDC_OPoutputXY(full_outfile); + for (const QString& outputfile : output_files) { + QString full_outfile = workdir+QDir::separator()+outputfile; + if (outputfile.endsWith(".dc_op")) { + parseDC_OPoutput(full_outfile); + } else if (outputfile.endsWith(".dc_op_xyce")) { + parseDC_OPoutputXY(full_outfile); } } return; } @@ -1061,8 +1065,7 @@ void AbstractSpiceKernel::convertToQucsData(const QString &qucs_dataset) QString sim,indep; QStringList indep_vars; - QString ngspice_output_filename; - foreach(ngspice_output_filename,output_files) { // For every simulation convert results to Qucs dataset + for (const QString& ngspice_output_filename : output_files) { // For every simulation convert results to Qucs dataset QList< QList > sim_points; QStringList var_list; QString swp_var,swp_var2; @@ -1166,7 +1169,7 @@ void AbstractSpiceKernel::convertToQucsData(const QString &qucs_dataset) normalizeVarsNames(var_list); QString indep = var_list.first(); - QList sim_point; + //QList sim_point; if (hasParSweep) { @@ -1184,7 +1187,7 @@ void AbstractSpiceKernel::convertToQucsData(const QString &qucs_dataset) } ds_stream<\n").arg(swp_var).arg(swp_var_val.count()); - foreach (QString val,swp_var_val) { + for (const QString& val : swp_var_val) { ds_stream<\n"; @@ -1192,7 +1195,7 @@ void AbstractSpiceKernel::convertToQucsData(const QString &qucs_dataset) else indep += " " + swp_var; if (hasDblParSweep) { ds_stream<\n").arg(swp_var2).arg(swp_var2_val.count()); - foreach (QString val,swp_var2_val) { + for (const QString& val : swp_var2_val) { ds_stream<\n"; @@ -1200,7 +1203,7 @@ void AbstractSpiceKernel::convertToQucsData(const QString &qucs_dataset) } } else if (!indep.isEmpty()) { ds_stream<\n").arg(indep).arg(sim_points.count()); // output indep var: TODO: parameter sweep - foreach (sim_point,sim_points) { + for (auto& sim_point : sim_points) { ds_stream<\n"; @@ -1209,7 +1212,7 @@ void AbstractSpiceKernel::convertToQucsData(const QString &qucs_dataset) for(int i=1;i\n").arg(var_list.at(i)).arg(sim_points.count()); else ds_stream<\n").arg(var_list.at(i)).arg(indep); - foreach (sim_point,sim_points) { + for (auto& sim_point : sim_points) { if (isComplex) { double re=sim_point.at(2*(i-1)+1); double im = sim_point.at(2*i); @@ -1245,7 +1248,7 @@ void AbstractSpiceKernel::convertToQucsData(const QString &qucs_dataset) */ void AbstractSpiceKernel::removeAllSimulatorOutputs() { - foreach(QString output_filename,output_files) { + for (const QString& output_filename : output_files) { QString full_outfile = workdir+QDir::separator()+output_filename; QFile::remove(full_outfile); } @@ -1274,8 +1277,8 @@ void AbstractSpiceKernel::normalizeVarsNames(QStringList &var_list) HB = true; } - for(auto it = var_list.begin();it!=var_list.end();it++) { // For subcircuit nodes output i.e. v(X1:n1) - (*it).replace(":","_"); // colon symbol is reserved in Qucs as dataset specifier + for(auto & it : var_list) { // For subcircuit nodes output i.e. v(X1:n1) + it.replace(":","_"); // colon symbol is reserved in Qucs as dataset specifier } QStringList::iterator it=var_list.begin(); diff --git a/qucs/extsimkernels/codemodelgen.cpp b/qucs/extsimkernels/codemodelgen.cpp index 80fcf80d..76a5ec82 100644 --- a/qucs/extsimkernels/codemodelgen.cpp +++ b/qucs/extsimkernels/codemodelgen.cpp @@ -169,7 +169,7 @@ bool CodeModelGen::createIFSfromEDD(QTextStream &stream, Schematic *sch, Compone stream<Ports.at(2*i)->Connection->Name; @@ -281,7 +281,7 @@ bool CodeModelGen::createMODfromEDD(QTextStream &stream, Schematic *sch, Compone spicecompat::splitEqn(Ieqn,tokens); spicecompat::splitEqn(Qeqn,tokens1); tokens.append(tokens1); - foreach(QString tok,tokens){ + for (QString& tok : tokens){ bool isNum = true; tok.toFloat(&isNum); QRegExp inp_pattern("[IV][0-9]+"); @@ -295,7 +295,7 @@ bool CodeModelGen::createMODfromEDD(QTextStream &stream, Schematic *sch, Compone scanEquations(sch,pars,init_pars,InitEqns); QStringList inputs_old; // Variables for charge eqns. - foreach(QString inp,inputs) { + for (const QString& inp : inputs) { inputs_old.append(inp+"_old"); } @@ -337,7 +337,7 @@ bool CodeModelGen::createMODfromEDD(QTextStream &stream, Schematic *sch, Compone stream<<"\tdouble delta_t;\n\n"; stream<<"\tif(INIT) {\n"; - foreach (QString par, pars) { + for (const QString& par : pars) { stream<<"\t\t"+ par + " = PARAM(" + par.toLower() + ");\n"; } auto it_ip=init_pars.begin(); @@ -353,10 +353,10 @@ bool CodeModelGen::createMODfromEDD(QTextStream &stream, Schematic *sch, Compone stream<<"\tif (ANALYSIS != AC) {\n"; stream<<"\tif (TIME == 0) {\n"; //QStringList::iterator it1 = inputs.begin(); - for(auto it1 = inputs.begin();it1!=inputs.end();it1++) { - QString vv = *it1; // Get input voltage number + for(auto & input : inputs) { + QString vv = input; // Get input voltage number int vn = vv.remove(0,1).toInt()-1; - stream<DocComps.first();pc!=0;pc=sch->DocComps.next()) { + for(Component *pc=sch->DocComps.first();pc!=nullptr;pc=sch->DocComps.next()) { if(pc->Model=="Eqn") { int Np = pc->Props.count(); for(int i=0;itoPlainText().split('\n'); - foreach(QString line,strings) { + for (const QString& line : strings) { QRegExp let_pattern("^\\s*let\\s+[A-Za-z]+\\w*\\s*\\=\\s*[A-Za-z]+.*$"); if (let_pattern.exactMatch(line)) { QString var = line.section('=',0,0); @@ -181,7 +181,7 @@ void CustomSimDialog::slotFindOutputs() if (isXyceScr) { QRegExp print_ex("^\\s*\\.print\\s.*"); print_ex.setCaseSensitivity(Qt::CaseInsensitive); - foreach(QString line,strings) { + for (const QString& line : strings) { if (print_ex.exactMatch(line)) { QRegExp file_ex("\\s*file\\s*=\\s*"); file_ex.setCaseSensitivity(Qt::CaseInsensitive); @@ -195,7 +195,7 @@ void CustomSimDialog::slotFindOutputs() } else { QRegExp write_ex("^\\s*write\\s.*"); write_ex.setCaseSensitivity(Qt::CaseInsensitive); - foreach(QString line,strings) { + for (const QString& line : strings) { if (write_ex.exactMatch(line)) { outps.append(line.section(QRegExp("\\s"),1,1,QString::SectionSkipEmpty)); } diff --git a/qucs/extsimkernels/ngspice.cpp b/qucs/extsimkernels/ngspice.cpp index a79d8690..a2b472f4 100644 --- a/qucs/extsimkernels/ngspice.cpp +++ b/qucs/extsimkernels/ngspice.cpp @@ -153,10 +153,9 @@ void Ngspice::createNetlist(QTextStream &stream, int , } } - QString sim; outputs.clear(); - foreach(sim, simulations) { + for (const QString& sim : simulations) { bool hasParSWP = false; bool hasDblSWP = false; @@ -298,10 +297,9 @@ void Ngspice::createNetlist(QTextStream &stream, int , continue; } - QString nod; QString nods; nods.clear(); - foreach (nod,vars) { + for (const QString& nod : vars) { if (!nod.endsWith("#branch")) { nods += QString("v(%1) ").arg(nod); } else { diff --git a/qucs/extsimkernels/qucs2spice.cpp b/qucs/extsimkernels/qucs2spice.cpp index a2479cb5..63f25224 100644 --- a/qucs/extsimkernels/qucs2spice.cpp +++ b/qucs/extsimkernels/qucs2spice.cpp @@ -31,20 +31,20 @@ namespace qucs2spice { - QString convert_rcl(QString line); + QString convert_rcl(const QString& line); QString convert_header(QString line); QString convert_diode(QString line,bool xyce=false); QString convert_jfet(QString line, bool xyce=false); QString convert_mosfet(QString line, bool xyce=false); QString convert_bjt(QString line); - QString convert_cccs(QString line); - QString convert_ccvs(QString line); - QString convert_ccs(QString line, bool voltage); - QString convert_vccs(QString line); - QString convert_vcvs(QString line); - QString convert_vcs(QString line, bool voltage); - QString convert_dc_src(QString line); - QString convert_edd(QString line, QStringList &EqnsAndVars); + QString convert_cccs(const QString& line); + QString convert_ccvs(const QString& line); + QString convert_ccs(const QString& line, bool voltage); + QString convert_vccs(const QString& line); + QString convert_vcvs(const QString& line); + QString convert_vcs(const QString& line, bool voltage); + QString convert_dc_src(const QString& line); + QString convert_edd(const QString& line, QStringList &EqnsAndVars); QString convert_subckt(QString line); QString convert_gyrator(QString line); @@ -85,7 +85,7 @@ QString qucs2spice::convert_netlist(QString netlist, bool xyce) QStringList EqnsAndVars; - foreach(QString line,net_lst) { // Find equations + for (QString line : net_lst) { // Find equations if (eqn_pattern.exactMatch(line)) { line.remove(QRegExp("^[ \t]*Eqn:[A-Za-z]+\\w+\\s+")); ExtractVarsAndValues(line,EqnsAndVars); @@ -96,7 +96,7 @@ QString qucs2spice::convert_netlist(QString netlist, bool xyce) EqnsAndVars.removeAll("yes"); - foreach(QString line,net_lst) { + for (QString& line : net_lst) { if (subckt_head_pattern.exactMatch(line)) { if (ends_pattern.exactMatch(line)) s += ".ENDS\n"; else s += convert_header(line); @@ -122,7 +122,7 @@ QString qucs2spice::convert_netlist(QString netlist, bool xyce) return s; } -QString qucs2spice::convert_rcl(QString line) +QString qucs2spice::convert_rcl(const QString& line) { QString s=""; QStringList lst = line.split(" ",qucs::SkipEmptyParts); @@ -256,14 +256,14 @@ QString qucs2spice::convert_bjt(QString line) QStringList spice_incompat; // spice incompatibel parameters; spice_incompat<<"Type="<<"Area="<<"Temp="<<"Ffe="<<"Kb="<<"Ab="<<"Fb="; for(int i=0;iDocName); QString basenam = inf.baseName(); - QString nod,nods; + QString nods; nods.clear(); - foreach (nod,vars) { + for (auto& nod :vars) { if (!nod.startsWith("I(")) { nods += QString("v(%1) ").arg(nod); } else { @@ -311,7 +311,7 @@ void Xyce::slotSimulate() QFile::remove(workdir+"spice4qucs.sens_tr.cir.SENS.prn"); QFile::remove(workdir+"spice4qucs.sens_tr.cir.TRADJ.prn"); - foreach(QString sim,simulationsQueue) { + for (const QString& sim : simulationsQueue) { QStringList sim_lst; sim_lst.clear(); sim_lst.append(sim); diff --git a/qucs/imagewriter.cpp b/qucs/imagewriter.cpp index ae23f8cf..5ac4d5cb 100644 --- a/qucs/imagewriter.cpp +++ b/qucs/imagewriter.cpp @@ -38,9 +38,9 @@ ImageWriter::~ImageWriter() } void -ImageWriter::noGuiPrint(QWidget *doc, QString printFile, QString color) +ImageWriter::noGuiPrint(QWidget *doc, const QString& printFile, const QString& color) { - Schematic *sch = static_cast(doc); + Schematic *sch = dynamic_cast(doc); const int bourder = 30; int w,h,wsel,hsel, xmin, ymin, xmin_sel, ymin_sel; @@ -131,7 +131,7 @@ QString ImageWriter::getLastSavedFile() // FIXME: should check if filename exists and not silently overwrite int ImageWriter::print(QWidget *doc) { - Schematic *sch = static_cast(doc); + Schematic *sch = dynamic_cast(doc); const int border = 30; int w,h,wsel,hsel, @@ -328,7 +328,7 @@ void ImageWriter::getSelAreaWidthAndHeight(Schematic *sch, int &wsel, int &hsel, } } - for(Wire *pw = sch->Wires->first(); pw != 0; pw = sch->Wires->next()) { + for(Wire *pw = sch->Wires->first(); pw != nullptr; pw = sch->Wires->next()) { if (pw->isSelected) { if(pw->x1 < xmin) xmin = pw->x1; @@ -348,7 +348,7 @@ void ImageWriter::getSelAreaWidthAndHeight(Schematic *sch, int &wsel, int &hsel, } } - for(Node *pn = sch->Nodes->first(); pn != 0; pn = sch->Nodes->next()) { + for(Node *pn = sch->Nodes->first(); pn != nullptr; pn = sch->Nodes->next()) { WireLabel *pl = pn->Label; if(pl) { // check position of node label if (pl->isSelected) { @@ -362,19 +362,16 @@ void ImageWriter::getSelAreaWidthAndHeight(Schematic *sch, int &wsel, int &hsel, } } - for(Diagram *pd = sch->Diagrams->first(); pd != 0; pd =sch-> Diagrams->next()) { - - - + for(Diagram *pd = sch->Diagrams->first(); pd != nullptr; pd =sch-> Diagrams->next()) { if (pd->isSelected) { int x1,y1,x2,y2; pd->Bounding(x1,y1,x2,y2); updateMinMax(xmin,xmax,ymin,ymax,x1,x2,y1,y2); - foreach (Graph *pg, pd->Graphs) { - foreach (Marker *pm, pg->Markers) { + for (auto& pg: qAsConst(pd->Graphs)) { + for (auto& pm: qAsConst(pg->Markers)) { if (pm->isSelected) { - int x1,y1,x2,y2; + //int x1,y1,x2,y2; pm->Bounding(x1,y1,x2,y2); updateMinMax(xmin,xmax,ymin,ymax,x1,x2,y1,y2); } @@ -383,7 +380,7 @@ void ImageWriter::getSelAreaWidthAndHeight(Schematic *sch, int &wsel, int &hsel, } } - for(Painting *pp = sch->Paintings->first(); pp != 0; pp = sch->Paintings->next()) { + for(Painting *pp = sch->Paintings->first(); pp != nullptr; pp = sch->Paintings->next()) { if (pp->isSelected) { int x1,y1,x2,y2; diff --git a/qucs/imagewriter.h b/qucs/imagewriter.h index 14f422b0..140b5fb0 100644 --- a/qucs/imagewriter.h +++ b/qucs/imagewriter.h @@ -33,7 +33,7 @@ public: ImageWriter (QString lastfile); virtual ~ImageWriter (); int print(QWidget *); - void noGuiPrint(QWidget *, QString printFile, QString color); + void noGuiPrint(QWidget *, const QString& printFile, const QString& color); QString getLastSavedFile(); @@ -44,7 +44,7 @@ private: void getSchWidthAndHeight(Schematic *sch, int &w, int &h, int &xmin, int &ymin); void getSelAreaWidthAndHeight(Schematic *sch, int &wsel, int& hsel, int& xmin_sel_, int& ymin_sel_); - void updateMinMax(int &xmin, int &xmax, int &ymin, int &ymax, int x1, int x2, int y1m, int y2); + static void updateMinMax(int &xmin, int &xmax, int &ymin, int &ymax, int x1, int x2, int y1m, int y2); }; #endif diff --git a/qucs/main.cpp b/qucs/main.cpp index 48aefd5e..ff90b354 100644 --- a/qucs/main.cpp +++ b/qucs/main.cpp @@ -276,7 +276,7 @@ bool saveApplSettings() settings.remove("Paths"); settings.beginWriteArray("Paths"); int i = 0; - foreach(QString path, qucsPathList) { + for (QString& path: qucsPathList) { settings.setArrayIndex(i); settings.setValue("path", path); i++; @@ -530,7 +530,7 @@ void createIcons() { Module::registerModules (); QStringList cats = Category::getCategories (); - foreach(QString category, cats) { + for (const QString& category: cats) { QList Comps; Comps = Category::getModules(category); @@ -541,7 +541,7 @@ void createIcons() { char * File; QString Name; - foreach (Module *Mod, Comps) { + for (Module *Mod: Comps) { if (Mod->info) { Element *e = (Mod->info) (Name, File, true); @@ -557,11 +557,11 @@ void createIcons() { QGraphicsScene *scene = new QGraphicsScene(); - foreach (qucs::Line *l, Lines) { + for (qucs::Line *l : Lines) { scene->addLine(l->x1, l->y1, l->x2, l->y2, l->style); } - foreach(struct qucs::Arc *a, Arcs) { + for (struct qucs::Arc *a: Arcs) { // we need an open item here; QGraphisEllipseItem draws a filled ellipse and doesn't do the job here... QPainterPath *path = new QPainterPath(); // the components do not contain the angles in degrees but in 1/16th degrees -> conversion needed @@ -570,19 +570,19 @@ void createIcons() { scene->addPath(*path); } - foreach(qucs::Area *a, Rects) { + for(qucs::Area *a: Rects) { scene->addRect(a->x, a->y, a->w, a->h, a->Pen, a->Brush); } - foreach(qucs::Area *a, Ellips) { + for(qucs::Area *a: Ellips) { scene->addEllipse(a->x, a->y, a->w, a->h, a->Pen, a->Brush); } - foreach(Port *p, Ports) { + for(Port *p: Ports) { scene->addEllipse(p->x-4, p->y-4, 8, 8, QPen(Qt::red)); } - foreach(Text *t, Texts) { + for(Text *t: Texts) { QFont myFont; myFont.setPointSize(10); QGraphicsTextItem* item = new QGraphicsTextItem(t->s); @@ -664,7 +664,7 @@ void createDocData() { int nComps = 0; // table for quick reference, schematic and netlist entry - foreach(QString category, cats) { + for (const QString& category: cats) { QList Comps; Comps = Category::getModules(category); @@ -684,7 +684,7 @@ void createDocData() { int num = 0; // component id inside category - foreach (Module *Mod, Comps) { + for (Module *Mod: Comps) { num += 1; nComps += 1; @@ -720,7 +720,7 @@ void createDocData() { QStringList compProps; compProps << "# Note: auto-generated file (changes will be lost on update)"; compProps << QString("# %1; %2; %3; %4").arg( "Name", "Value", "Display", "Description"); - foreach(Property *prop, c->Props) { + for (Property *prop : c->Props) { compProps << QString("%1; \"%2\"; %3; \"%4\"").arg( prop->Name, prop->Value, @@ -755,7 +755,7 @@ void createListComponentEntry(){ Module::registerModules (); QStringList cats = Category::getCategories (); // table for quick reference, schematic and netlist entry - foreach(QString category, cats) { + for (QString category: cats) { QList Comps; Comps = Category::getModules(category); @@ -766,7 +766,7 @@ void createListComponentEntry(){ char * File; QString Name; - foreach (Module *Mod, Comps) { + for (Module *Mod: Comps) { Element *e = (Mod->info) (Name, File, true); Component *c = (Component* ) e; @@ -775,7 +775,7 @@ void createListComponentEntry(){ // add dummy ports/wires, avoid segfault int port = 0; - foreach (Port *p, c->Ports) { + for (Port *p: c->Ports) { Node *n = new Node(0,0); n->Name="_net"+QString::number(port); p->Connection = n; diff --git a/qucs/mouseactions.cpp b/qucs/mouseactions.cpp index 9ee88b76..3e7a037b 100644 --- a/qucs/mouseactions.cpp +++ b/qucs/mouseactions.cpp @@ -49,8 +49,8 @@ #include #include -#include -#include +#include +#include #define DOC_X_POS(x) (int(float(x)/Doc->Scale) + Doc->ViewX1) @@ -933,9 +933,8 @@ void MouseActions::MPressLabel(Schematic *Doc, QMouseEvent*, float fX, float fY) if(Name.isEmpty()) return; */ if(pe) { - if(((Conductor*)pe)->Label) - delete ((Conductor*)pe)->Label; // delete old name - ((Conductor*)pe)->Label = 0; + delete ((Conductor*)pe)->Label; // delete old name + ((Conductor*)pe)->Label = nullptr; } int xl = x+30; @@ -1670,8 +1669,8 @@ void MouseActions::MReleaseResizeDiagram(Schematic *Doc, QMouseEvent *Event) Diagram *pd = (Diagram*)focusElement; pd->updateGraphData(); - foreach(Graph *pg, pd->Graphs) - foreach(Marker *pm, pg->Markers) { + for (Graph *pg : pd->Graphs) + for(Marker *pm : pg->Markers) { pm->x1 += MAx3; // correct changes due to move of diagram corner pm->y1 += MAy3; } @@ -1680,7 +1679,7 @@ void MouseActions::MReleaseResizeDiagram(Schematic *Doc, QMouseEvent *Event) pd->Bounding(x1, x2, y1, y2); Doc->enlargeView(x1, x2, y1, y2); - QucsMain->MouseMoveAction = 0; + QucsMain->MouseMoveAction = nullptr; QucsMain->MousePressAction = &MouseActions::MPressSelect; QucsMain->MouseReleaseAction = &MouseActions::MReleaseSelect; QucsMain->MouseDoubleClickAction = &MouseActions::MDoubleClickSelect; diff --git a/qucs/paintings/id_dialog.cpp b/qucs/paintings/id_dialog.cpp index 72ba32c3..abb0d453 100644 --- a/qucs/paintings/id_dialog.cpp +++ b/qucs/paintings/id_dialog.cpp @@ -296,7 +296,7 @@ void ID_Dialog::slotOk() if(changed) idText->Parameter.swap(scratch); - foreach(SubParameter *p, scratch) { + for (SubParameter *p : scratch) { delete p; } diff --git a/qucs/qucs.cpp b/qucs/qucs.cpp index c7664116..39721ab6 100644 --- a/qucs/qucs.cpp +++ b/qucs/qucs.cpp @@ -466,7 +466,7 @@ void QucsApp::fillLibrariesTreeView () QDir LibDir(QucsSettings.LibDir); LibFiles = LibDir.entryList(QStringList("*.lib"), QDir::Files, QDir::Name); QStringList blacklist = getBlacklistedLibraries(QucsSettings.LibDir); - foreach(QString ss, blacklist) { // exclude blacklisted files + for (const QString& ss: blacklist) { // exclude blacklisted files LibFiles.removeAll(ss); } @@ -483,18 +483,18 @@ void QucsApp::fillLibrariesTreeView () nameAndFileName.append (parsedlibrary.name); nameAndFileName.append (QucsSettings.LibDir + *it); - QTreeWidgetItem* newlibitem = new QTreeWidgetItem((QTreeWidget*)0, nameAndFileName); + QTreeWidgetItem* newlibitem = new QTreeWidgetItem((QTreeWidget*)nullptr, nameAndFileName); switch (result) { case QUCS_COMP_LIB_IO_ERROR: { QString filename = getLibAbsPath(libPath); - QMessageBox::critical(0, tr ("Error"), tr("Cannot open \"%1\".").arg (filename)); + QMessageBox::critical(nullptr, tr ("Error"), tr("Cannot open \"%1\".").arg (filename)); return; } case QUCS_COMP_LIB_CORRUPT: - QMessageBox::critical(0, tr("Error"), tr("Library is corrupt.")); + QMessageBox::critical(nullptr, tr("Error"), tr("Library is corrupt.")); return; default: break; @@ -539,7 +539,7 @@ void QucsApp::fillLibrariesTreeView () const QDir& UsrLibDir(UserLibDir); LibFiles = UsrLibDir.entryList(QStringList("*.lib"), QDir::Files, QDir::Name); blacklist = getBlacklistedLibraries(QucsSettings.LibDir); - foreach(QString ss, blacklist) { // exclude blacklisted files + for (const QString& ss : blacklist) { // exclude blacklisted files LibFiles.removeAll(ss); } int UserLibCount = LibFiles.count(); @@ -669,7 +669,7 @@ void QucsApp::fillComboBox (bool setAll) CompChoose->insertItem(CompChoose->count(), QObject::tr("paintings")); } else { QStringList cats = Category::getCategories (); - foreach (QString it, cats) { + for (const QString& it : cats) { CompChoose->insertItem(CompChoose->count(), it); } } @@ -803,12 +803,12 @@ void QucsApp::slotSearchComponent(const QString &searchText) QString Name; char * File; QList Comps; - iconCompInfoStruct iconCompInfo; + iconCompInfoStruct iconCompInfo{}; QVariant v; QStringList cats = Category::getCategories (); int catIdx = 0; - foreach(QString it, cats) { + for (const QString& it : cats) { // this will go also over the "verilog-a user devices" category, if present // but since modules there have no 'info' function it won't handle them Comps = Category::getModules(it); @@ -1356,31 +1356,7 @@ bool QucsApp::recurRemove(const QString &Path) { bool result = true; QDir projDir = QDir(Path); - - if (projDir.exists(Path)) { - Q_FOREACH(QFileInfo info, - projDir.entryInfoList( - QDir::AllDirs | QDir::NoDotAndDotDot | QDir::Hidden | QDir::AllEntries, QDir::DirsFirst)) { - if (info.isDir()) { - result = recurRemove(info.absoluteFilePath()); - if (!result) { - QMessageBox::information(this, tr("Info"), - tr("Cannot remove directory: %1").arg(Path)); - return false; - } - } - else if(info.isFile()) { - result = QFile::remove(info.absoluteFilePath()); - if (!result) { - QMessageBox::information(this, tr("Info"), - tr("Cannot delete file: %1").arg(info.fileName())); - return false; - } - } - } - result = projDir.rmdir(Path); - } - return result; + return projDir.removeRecursively(); } // ---------------------------------------------------------- @@ -2854,13 +2830,13 @@ void QucsApp::updateSchNameHash(void) // clear out any existing hash table entries schNameHash.clear(); - foreach (QString qucspath, qucsPathList) { + for (const QString& qucspath : qucsPathList) { QDir thispath(qucspath); // get all the schematic files in the directory QFileInfoList schfilesList = thispath.entryInfoList( nameFilter, QDir::Files ); // put each one in the hash table with the unique key the base name of // the file, note this will overwrite the value if the key already exists - foreach (QFileInfo schfile, schfilesList) { + for (const QFileInfo& schfile : schfilesList) { QString bn = schfile.completeBaseName(); schNameHash[schfile.completeBaseName()] = schfile.absoluteFilePath(); } @@ -2871,7 +2847,7 @@ void QucsApp::updateSchNameHash(void) QFileInfoList schfilesList = thispath.entryInfoList( nameFilter, QDir::Files ); // put each one in the hash table with the unique key the base name of // the file, note this will overwrite the value if the key already exists - foreach (QFileInfo schfile, schfilesList) { + for (const QFileInfo& schfile : schfilesList) { schNameHash[schfile.completeBaseName()] = schfile.absoluteFilePath(); } } @@ -2879,7 +2855,7 @@ void QucsApp::updateSchNameHash(void) // ----------------------------------------------------------- // Searches the qucs path list for all spice files and creates // a hash for lookup later -void QucsApp::updateSpiceNameHash(void) +void QucsApp::updateSpiceNameHash() { // update the list of paths to search in qucsPathList, this // removes nonexisting entries @@ -2895,13 +2871,13 @@ void QucsApp::updateSpiceNameHash(void) // clear out any existing hash table entries spiceNameHash.clear(); - foreach (QString qucspath, qucsPathList) { + for (const QString& qucspath : qucsPathList) { QDir thispath(qucspath); // get all the schematic files in the directory QFileInfoList spicefilesList = thispath.entryInfoList( QucsSettings.spiceExtensions, QDir::Files ); // put each one in the hash table with the unique key the base name of // the file, note this will overwrite the value if the key already exists - foreach (QFileInfo spicefile, spicefilesList) { + for (const QFileInfo& spicefile : spicefilesList) { QString bn = spicefile.completeBaseName(); schNameHash[spicefile.completeBaseName()] = spicefile.absoluteFilePath(); } @@ -2912,14 +2888,14 @@ void QucsApp::updateSpiceNameHash(void) QFileInfoList spicefilesList = thispath.entryInfoList( QucsSettings.spiceExtensions, QDir::Files ); // put each one in the hash table with the unique key the base name of // the file, note this will overwrite the value if the key already exists - foreach (QFileInfo spicefile, spicefilesList) { + for (const QFileInfo& spicefile : spicefilesList) { spiceNameHash[spicefile.completeBaseName()] = spicefile.absoluteFilePath(); } } // ----------------------------------------------------------- // update the list of paths, pruning non-existing paths -void QucsApp::updatePathList(void) +void QucsApp::updatePathList() { // check each path actually exists, if not remove it QMutableListIterator i(qucsPathList); @@ -2941,7 +2917,7 @@ void QucsApp::updatePathList(QStringList newPathList) qucsPathList.clear(); // copy the new path into the path list - foreach(QString path, newPathList) + for (const QString& path : newPathList) { qucsPathList.append(path); } diff --git a/qucs/qucs.h b/qucs/qucs.h index babe1078..19490b3c 100644 --- a/qucs/qucs.h +++ b/qucs/qucs.h @@ -254,7 +254,7 @@ private: void switchSchematicDoc(bool); void switchEditMode(bool); void changeSchematicSymbolMode(Schematic*); - bool recurRemove(const QString &); + static bool recurRemove(const QString &); void closeFile(int); void updateRecentFilesList(QString s); diff --git a/qucs/schematic.cpp b/qucs/schematic.cpp index eda92038..f0f5ab43 100644 --- a/qucs/schematic.cpp +++ b/qucs/schematic.cpp @@ -635,115 +635,114 @@ void Schematic::print(QPrinter*, QPainter *Painter, bool printAll, bool fitToPag } -void Schematic::paintSchToViewpainter(ViewPainter *p, bool printAll, bool toImage, int screenDpiX, int printerDpiX) -{ +void Schematic::paintSchToViewpainter(ViewPainter *p, bool printAll, bool toImage, int screenDpiX, int printerDpiX) { bool selected; if (printAll) { - int x2,y2; - if (sizeOfFrame(x2,y2)) paintFrame(p); + int x2, y2; + if (sizeOfFrame(x2, y2)) paintFrame(p); } - for(Component *pc = Components->first(); pc != 0; pc = Components->next()) - if(pc->isSelected || printAll) { - selected = pc->isSelected; - pc->isSelected = false; - if (toImage) { - pc->paint(p); - } else { - pc->print(p, (float)screenDpiX / (float)printerDpiX); + for (Component *pc = Components->first(); pc != 0; pc = Components->next()) + if (pc->isSelected || printAll) { + selected = pc->isSelected; + pc->isSelected = false; + if (toImage) { + pc->paint(p); + } else { + pc->print(p, (float) screenDpiX / (float) printerDpiX); + } + pc->isSelected = selected; } - pc->isSelected = selected; - } - for(Wire *pw = Wires->first(); pw != 0; pw = Wires->next()) { - if(pw->isSelected || printAll) { - selected = pw->isSelected; - pw->isSelected = false; - pw->paint(p); // paint all selected wires - pw->isSelected = selected; - } - if(pw->Label) - if(pw->Label->isSelected || printAll) { - selected = pw->Label->isSelected; - pw->Label->isSelected = false; - pw->Label->paint(p); - pw->Label->isSelected = selected; + for (Wire *pw = Wires->first(); pw != 0; pw = Wires->next()) { + if (pw->isSelected || printAll) { + selected = pw->isSelected; + pw->isSelected = false; + pw->paint(p); // paint all selected wires + pw->isSelected = selected; } + if (pw->Label) + if (pw->Label->isSelected || printAll) { + selected = pw->Label->isSelected; + pw->Label->isSelected = false; + pw->Label->paint(p); + pw->Label->isSelected = selected; + } } Element *pe; - for(Node *pn = Nodes->first(); pn != 0; pn = Nodes->next()) { - for(pe = pn->Connections.first(); pe != 0; pe = pn->Connections.next()) - if(pe->isSelected || printAll) { - pn->paint(p); // paint all nodes with selected elements - break; - } - if(pn->Label) - if(pn->Label->isSelected || printAll) { - selected = pn->Label->isSelected; - pn->Label->isSelected = false; - pn->Label->paint(p); - pn->Label->isSelected = selected; - } + for (Node *pn = Nodes->first(); pn != 0; pn = Nodes->next()) { + for (pe = pn->Connections.first(); pe != 0; pe = pn->Connections.next()) + if (pe->isSelected || printAll) { + pn->paint(p); // paint all nodes with selected elements + break; + } + if (pn->Label) + if (pn->Label->isSelected || printAll) { + selected = pn->Label->isSelected; + pn->Label->isSelected = false; + pn->Label->paint(p); + pn->Label->isSelected = selected; + } } - for(Painting *pp = Paintings->first(); pp != 0; pp = Paintings->next()) - if(pp->isSelected || printAll) { - selected = pp->isSelected; - pp->isSelected = false; - pp->paint(p); // paint all selected paintings - pp->isSelected = selected; - } - - for(Diagram *pd = Diagrams->first(); pd != 0; pd = Diagrams->next()) - if(pd->isSelected || printAll) { - // if graph or marker is selected, deselect during printing - foreach(Graph *pg, pd->Graphs) { - if(pg->isSelected) pg->Type |= 1; // remember selection - pg->isSelected = false; - foreach(Marker *pm, pg->Markers) { - if(pm->isSelected) pm->Type |= 1; // remember selection - pm->isSelected = false; - } + for (Painting *pp = Paintings->first(); pp != 0; pp = Paintings->next()) + if (pp->isSelected || printAll) { + selected = pp->isSelected; + pp->isSelected = false; + pp->paint(p); // paint all selected paintings + pp->isSelected = selected; } - selected = pd->isSelected; - pd->isSelected = false; - pd->paintDiagram(p); // paint all selected diagrams with graphs and markers - pd->paintMarkers(p,printAll); - pd->isSelected = selected; + for (Diagram *pd = Diagrams->first(); pd != 0; pd = Diagrams->next()) + if (pd->isSelected || printAll) { + // if graph or marker is selected, deselect during printing + for (Graph *pg: pd->Graphs) { + if (pg->isSelected) pg->Type |= 1; // remember selection + pg->isSelected = false; + for (Marker *pm: pg->Markers) { + if (pm->isSelected) pm->Type |= 1; // remember selection + pm->isSelected = false; + } + } - // revert selection of graphs and markers - foreach(Graph *pg, pd->Graphs) { - if(pg->Type & 1) pg->isSelected = true; - pg->Type &= -2; - foreach(Marker *pm, pg->Markers) { - if(pm->Type & 1) pm->isSelected = true; - pm->Type &= -2; - } - } - } + selected = pd->isSelected; + pd->isSelected = false; + pd->paintDiagram(p); // paint all selected diagrams with graphs and markers + pd->paintMarkers(p, printAll); + pd->isSelected = selected; - if(showBias > 0) { // show DC bias points in schematic ? - int x, y, z; - for(Node* pn = Nodes->first(); pn != 0; pn = Nodes->next()) { - if(pn->Name.isEmpty()) continue; - x = pn->cx; - y = pn->cy + 4; - z = pn->x1; - if(z & 1) x -= p->Painter->fontMetrics().boundingRect(pn->Name).width(); - if(!(z & 2)) { - y -= (p->LineSpacing>>1) + 4; - if(z & 1) x -= 4; - else x += 4; + // revert selection of graphs and markers + for (Graph *pg: pd->Graphs) { + if (pg->Type & 1) pg->isSelected = true; + pg->Type &= -2; + for (Marker *pm: pg->Markers) { + if (pm->Type & 1) pm->isSelected = true; + pm->Type &= -2; + } + } + } + + if (showBias > 0) { // show DC bias points in schematic ? + int x, y, z; + for (Node *pn = Nodes->first(); pn != 0; pn = Nodes->next()) { + if (pn->Name.isEmpty()) continue; + x = pn->cx; + y = pn->cy + 4; + z = pn->x1; + if (z & 1) x -= p->Painter->fontMetrics().boundingRect(pn->Name).width(); + if (!(z & 2)) { + y -= (p->LineSpacing >> 1) + 4; + if (z & 1) x -= 4; + else x += 4; + } + if (z & 0x10) + p->Painter->setPen(Qt::darkGreen); // green for currents + else + p->Painter->setPen(Qt::blue); // blue for voltages + p->drawText(pn->Name, x, y); } - if(z & 0x10) - p->Painter->setPen(Qt::darkGreen); // green for currents - else - p->Painter->setPen(Qt::blue); // blue for voltages - p->drawText(pn->Name, x, y); - } } } @@ -1006,9 +1005,9 @@ void Schematic::sizeOfAll(int& xmin, int& ymin, int& xmax, int& ymax) if(y1 < ymin) ymin = y1; if(y2 > ymax) ymax = y2; - foreach(Graph *pg, pd->Graphs) + for (Graph *pg : pd->Graphs) // test all markers of diagram - foreach(Marker *pm, pg->Markers) { + for (Marker *pm : pg->Markers) { pm->Bounding(x1, y1, x2, y2); if(x1 < xmin) xmin = x1; if(x2 > xmax) xmax = x2; @@ -1018,7 +1017,7 @@ void Schematic::sizeOfAll(int& xmin, int& ymin, int& xmax, int& ymax) } // find boundings of all Paintings - for(pp = Paintings->first(); pp != 0; pp = Paintings->next()) { + for(pp = Paintings->first(); pp != nullptr; pp = Paintings->next()) { pp->Bounding(x1, y1, x2, y2); if(x1 < xmin) xmin = x1; if(x2 > xmax) xmax = x2; @@ -1056,7 +1055,7 @@ bool Schematic::rotateElements() Component *pc; WireLabel *pl; // re-insert elements - foreach(Element *pe, ElementCache) + for (Element *pe : ElementCache) switch(pe->Type) { case isComponent: case isAnalogComponent: @@ -1150,7 +1149,7 @@ bool Schematic::mirrorXComponents() Component *pc; WireLabel *pl; // re-insert elements - foreach(Element *pe, ElementCache) + for (Element *pe : ElementCache) switch(pe->Type) { case isComponent: case isAnalogComponent: @@ -1218,7 +1217,7 @@ bool Schematic::mirrorYComponents() Component *pc; WireLabel *pl; // re-insert elements - foreach(Element *pe, ElementCache) + for (Element *pe : ElementCache) switch(pe->Type) { case isComponent: case isAnalogComponent: @@ -1717,139 +1716,137 @@ bool Schematic::redo() // --------------------------------------------------- // Sets selected elements on grid. -bool Schematic::elementsOnGrid() -{ - int x, y, No; - bool count = false; - WireLabel *pl, *pLabel; - Q3PtrList LabelCache; +bool Schematic::elementsOnGrid() { + int x, y, No; + bool count = false; + WireLabel *pl, *pLabel; + Q3PtrList LabelCache; - // test all components - Components->setAutoDelete(false); - for(Component *pc = Components->last(); pc != 0; pc = Components->prev()) - if(pc->isSelected) { + // test all components + Components->setAutoDelete(false); + for (Component *pc = Components->last(); pc != nullptr; pc = Components->prev()) + if (pc->isSelected) { - // rescue non-selected node labels - foreach(Port *pp, pc->Ports) - if(pp->Connection->Label) - if(pp->Connection->Connections.count() < 2) { - LabelCache.append(pp->Connection->Label); - pp->Connection->Label->pOwner = 0; - pp->Connection->Label = 0; - } + // rescue non-selected node labels + for (Port *pp: pc->Ports) + if (pp->Connection->Label) + if (pp->Connection->Connections.count() < 2) { + LabelCache.append(pp->Connection->Label); + pp->Connection->Label->pOwner = 0; + pp->Connection->Label = 0; + } - x = pc->cx; - y = pc->cy; - No = Components->at(); - deleteComp(pc); - setOnGrid(pc->cx, pc->cy); - insertRawComponent(pc); - Components->at(No); // restore current list position - pc->isSelected = false; - count = true; + x = pc->cx; + y = pc->cy; + No = Components->at(); + deleteComp(pc); + setOnGrid(pc->cx, pc->cy); + insertRawComponent(pc); + Components->at(No); // restore current list position + pc->isSelected = false; + count = true; - x -= pc->cx; - y -= pc->cy; // re-insert node labels and correct position - for(pl = LabelCache.first(); pl != 0; pl = LabelCache.next()) { - pl->cx -= x; - pl->cy -= y; - insertNodeLabel(pl); - } - LabelCache.clear(); - } - Components->setAutoDelete(true); - - Wires->setAutoDelete(false); - // test all wires and wire labels - for(Wire *pw = Wires->last(); pw != 0; pw = Wires->prev()) { - pl = pw->Label; - pw->Label = 0; - - if(pw->isSelected) { - // rescue non-selected node label - pLabel = 0; - if(pw->Port1->Label) { - if(pw->Port1->Connections.count() < 2) { - pLabel = pw->Port1->Label; - pw->Port1->Label = 0; + x -= pc->cx; + y -= pc->cy; // re-insert node labels and correct position + for (pl = LabelCache.first(); pl != 0; pl = LabelCache.next()) { + pl->cx -= x; + pl->cy -= y; + insertNodeLabel(pl); + } + LabelCache.clear(); } - } - else if(pw->Port2->Label) { - if(pw->Port2->Connections.count() < 2) { - pLabel = pw->Port2->Label; - pw->Port2->Label = 0; + Components->setAutoDelete(true); + + Wires->setAutoDelete(false); + // test all wires and wire labels + for (Wire *pw = Wires->last(); pw != 0; pw = Wires->prev()) { + pl = pw->Label; + pw->Label = nullptr; + + if (pw->isSelected) { + // rescue non-selected node label + pLabel = nullptr; + if (pw->Port1->Label) { + if (pw->Port1->Connections.count() < 2) { + pLabel = pw->Port1->Label; + pw->Port1->Label = nullptr; + } + } else if (pw->Port2->Label) { + if (pw->Port2->Connections.count() < 2) { + pLabel = pw->Port2->Label; + pw->Port2->Label = nullptr; + } + } + + No = Wires->at(); + deleteWire(pw); + setOnGrid(pw->x1, pw->y1); + setOnGrid(pw->x2, pw->y2); + insertWire(pw); + Wires->at(No); // restore current list position + pw->isSelected = false; + count = true; + if (pl) + setOnGrid(pl->cx, pl->cy); + + if (pLabel) { + setOnGrid(pLabel->cx, pLabel->cy); + insertNodeLabel(pLabel); + } } - } - No = Wires->at(); - deleteWire(pw); - setOnGrid(pw->x1, pw->y1); - setOnGrid(pw->x2, pw->y2); - insertWire(pw); - Wires->at(No); // restore current list position - pw->isSelected = false; - count = true; - if(pl) - setOnGrid(pl->cx, pl->cy); - - if(pLabel) { - setOnGrid(pLabel->cx, pLabel->cy); - insertNodeLabel(pLabel); - } - } - - if(pl) { - pw->Label = pl; - if(pl->isSelected) { - setOnGrid(pl->x1, pl->y1); - pl->isSelected = false; - count = true; - } - } - } - Wires->setAutoDelete(true); - - // test all node labels - for(Node *pn = Nodes->first(); pn != 0; pn = Nodes->next()) - if(pn->Label) - if(pn->Label->isSelected) { - setOnGrid(pn->Label->x1, pn->Label->y1); - pn->Label->isSelected = false; - count = true; - } - - // test all diagrams - for(Diagram *pd = Diagrams->last(); pd != 0; pd = Diagrams->prev()) { - if(pd->isSelected) { - setOnGrid(pd->cx, pd->cy); - pd->isSelected = false; - count = true; - } - - foreach(Graph *pg,pd->Graphs) - // test markers of diagram - foreach(Marker *pm, pg->Markers) - if(pm->isSelected) { - x = pm->x1 + pd->cx; - y = pm->y1 + pd->cy; - setOnGrid(x, y); - pm->x1 = x - pd->cx; - pm->y1 = y - pd->cy; - pm->isSelected = false; - count = true; + if (pl) { + pw->Label = pl; + if (pl->isSelected) { + setOnGrid(pl->x1, pl->y1); + pl->isSelected = false; + count = true; + } } - } + } + Wires->setAutoDelete(true); - // test all paintings - for(Painting *pa = Paintings->last(); pa != 0; pa = Paintings->prev()) - if(pa->isSelected) { - setOnGrid(pa->cx, pa->cy); - pa->isSelected = false; - count = true; + // test all node labels + for (Node *pn = Nodes->first(); pn != 0; pn = Nodes->next()) + if (pn->Label) + if (pn->Label->isSelected) { + setOnGrid(pn->Label->x1, pn->Label->y1); + pn->Label->isSelected = false; + count = true; + } + + // test all diagrams + for (Diagram *pd = Diagrams->last(); pd != 0; pd = Diagrams->prev()) { + if (pd->isSelected) { + setOnGrid(pd->cx, pd->cy); + pd->isSelected = false; + count = true; + } + + for (Graph *pg: pd->Graphs) + // test markers of diagram + for (Marker *pm: pg->Markers) + if (pm->isSelected) { + x = pm->x1 + pd->cx; + y = pm->y1 + pd->cy; + setOnGrid(x, y); + pm->x1 = x - pd->cx; + pm->y1 = y - pd->cy; + pm->isSelected = false; + count = true; + } } - if(count) setChanged(true, true); - return count; + // test all paintings + for (Painting *pa = Paintings->last(); pa != 0; pa = Paintings->prev()) + if (pa->isSelected) { + setOnGrid(pa->cx, pa->cy); + pa->isSelected = false; + count = true; + } + + if (count) setChanged(true, true); + return count; } // --------------------------------------------------- @@ -2090,7 +2087,7 @@ void Schematic::contentsDropEvent(QDropEvent *Event) d->DocChanged = true; // URI: file:/home/linuxuser/Desktop/example.sch - foreach(QUrl url, urls) { + for (QUrl url : urls) { App->gotoPage(QDir::toNativeSeparators(url.toLocalFile())); } @@ -2106,8 +2103,8 @@ void Schematic::contentsDropEvent(QDropEvent *Event) App->view->MPressElement(this, &e, x, y); - if(App->view->selElem) delete App->view->selElem; - App->view->selElem = 0; // no component selected + delete App->view->selElem; + App->view->selElem = nullptr; // no component selected if(formerAction) formerAction->setChecked(true); // restore old action @@ -2117,7 +2114,7 @@ void Schematic::contentsDropEvent(QDropEvent *Event) void Schematic::contentsDragEnterEvent(QDragEnterEvent *Event) { //FIXME: the function of drag library component seems not working? - formerAction = 0; + formerAction = nullptr; dragIsOkay = false; // file dragged in ? diff --git a/qucs/schematic.h b/qucs/schematic.h index d3c14f5a..7e4174fd 100644 --- a/qucs/schematic.h +++ b/qucs/schematic.h @@ -227,9 +227,9 @@ public: Element* selectElement(float, float, bool, int *index=0); void deselectElements(Element*); - int selectElements(int, int, int, int, bool); - void selectMarkers(); - void newMovingWires(Q3PtrList*, Node*, int); + int selectElements(int, int, int, int, bool) const; + void selectMarkers() const; + void newMovingWires(Q3PtrList*, Node*, int) const; int copySelectedElements(Q3PtrList*); bool deleteElements(); bool aligning(int); @@ -244,11 +244,11 @@ public: bool activateSpecifiedComponent(int, int); bool activateSelectedComponents(); void setCompPorts(Component*); - Component* selectCompText(int, int, int&, int&); + Component* selectCompText(int, int, int&, int&) const; Component* searchSelSubcircuit(); Component* selectedComponent(int, int); void deleteComp(Component*); - Component* getComponentByName(QString compname); + Component* getComponentByName(const QString& compname); void oneLabel(Node*); int placeNodeLabel(WireLabel*); diff --git a/qucs/schematic_element.cpp b/qucs/schematic_element.cpp index 75a7622f..e582c196 100644 --- a/qucs/schematic_element.cpp +++ b/qucs/schematic_element.cpp @@ -1135,10 +1135,10 @@ Element* Schematic::selectElement(float fX, float fY, bool flag, int *index) for(Diagram *pd = Diagrams->last(); pd != 0; pd = Diagrams->prev()) { - foreach(Graph *pg, pd->Graphs) + for (Graph *pg : pd->Graphs) { // test markers of graphs - foreach(Marker *pm, pg->Markers) + for (Marker *pm : pg->Markers) { if(pm->getSelected(x-pd->cx, y-pd->cy)) { @@ -1202,7 +1202,7 @@ Element* Schematic::selectElement(float fX, float fY, bool flag, int *index) } // test graphs of diagram - foreach(Graph *pg, pd->Graphs) + for (Graph *pg : pd->Graphs) { if(pg->getSelected(x-pd->cx, pd->cy-y) >= 0) { @@ -1458,12 +1458,12 @@ void Schematic::deselectElements(Element *e) if(e != pd) pd->isSelected = false; // test graphs of diagram - foreach(Graph *pg, pd->Graphs) + for (Graph *pg : pd->Graphs) { if(e != pg) pg->isSelected = false; // test markers of graph - foreach(Marker *pm, pg->Markers) + for (Marker *pm : pg->Markers) if(e != pm) pm->isSelected = false; } @@ -1476,7 +1476,7 @@ void Schematic::deselectElements(Element *e) // --------------------------------------------------- // Selects elements that lie within the rectangle x1/y1, x2/y2. -int Schematic::selectElements(int x1, int y1, int x2, int y2, bool flag) +int Schematic::selectElements(int x1, int y1, int x2, int y2, bool flag) const { int z=0; // counts selected elements int cx1, cy1, cx2, cy2; @@ -1492,7 +1492,7 @@ int Schematic::selectElements(int x1, int y1, int x2, int y2, bool flag) y2 = cy2; // test all components - for(Component *pc = Components->first(); pc != 0; pc = Components->next()) + for(Component *pc = Components->first(); pc != nullptr; pc = Components->next()) { pc->Bounding(cx1, cy1, cx2, cy2); if(cx1 >= x1) if(cx2 <= x2) if(cy1 >= y1) if(cy2 <= y2) @@ -1506,21 +1506,23 @@ int Schematic::selectElements(int x1, int y1, int x2, int y2, bool flag) Wire *pw; - for(pw = Wires->first(); pw != 0; pw = Wires->next()) // test all wires + for (pw = Wires->first(); pw != nullptr; pw = Wires->next()) // test all wires { - if(pw->x1 >= x1) if(pw->x2 <= x2) if(pw->y1 >= y1) if(pw->y2 <= y2) - { + if (pw->x1 >= x1) + if (pw->x2 <= x2) + if (pw->y1 >= y1) + if (pw->y2 <= y2) { pw->isSelected = true; z++; continue; } - if(pw->isSelected &= flag) z++; + if (pw->isSelected &= flag) z++; } // test all wire labels ********************************* - WireLabel *pl=0; - for(pw = Wires->first(); pw != 0; pw = Wires->next()) + WireLabel *pl=nullptr; + for(pw = Wires->first(); pw != nullptr; pw = Wires->next()) { if(pw->Label) { @@ -1559,12 +1561,12 @@ int Schematic::selectElements(int x1, int y1, int x2, int y2, bool flag) for(Diagram *pd = Diagrams->first(); pd != 0; pd = Diagrams->next()) { // test graphs of diagram - foreach(Graph *pg, pd->Graphs) + for (Graph *pg : pd->Graphs) { if(pg->isSelected &= flag) z++; // test markers of graph - foreach(Marker *pm, pg->Markers) + for (Marker *pm : pg->Markers) { pm->Bounding(cx1, cy1, cx2, cy2); if(cx1 >= x1) if(cx2 <= x2) if(cy1 >= y1) if(cy2 <= y2) @@ -1606,11 +1608,11 @@ int Schematic::selectElements(int x1, int y1, int x2, int y2, bool flag) // --------------------------------------------------- // Selects all markers. -void Schematic::selectMarkers() +void Schematic::selectMarkers() const { for(Diagram *pd = Diagrams->first(); pd != 0; pd = Diagrams->next()) - foreach(Graph *pg, pd->Graphs) - foreach(Marker *pm, pg->Markers) + for (Graph *pg : pd->Graphs) + for (Marker *pm : pg->Markers) pm->isSelected = true; } @@ -1618,7 +1620,7 @@ void Schematic::selectMarkers() // For moving elements: If the moving element is connected to a not // moving element, insert two wires. If the connected element is already // a wire, use this wire. Otherwise create new wire. -void Schematic::newMovingWires(Q3PtrList *p, Node *pn, int pos) +void Schematic::newMovingWires(Q3PtrList *p, Node *pn, int pos) const { Element *pe; @@ -1641,7 +1643,7 @@ void Schematic::newMovingWires(Q3PtrList *p, Node *pn, int pos) // ................................................. long mask = 1, invMask = 3; - Wire *pw2=0, *pw = (Wire*)pe; + Wire *pw2=nullptr, *pw = (Wire*)pe; Node *pn2 = pw->Port1; if(pn2 == pn) pn2 = pw->Port2; @@ -1667,7 +1669,7 @@ void Schematic::newMovingWires(Q3PtrList *p, Node *pn, int pos) if(pw->isHorizontal()) mask = 2; - if(pw2 == 0) // place new wire between component and old wire + if(pw2 == nullptr) // place new wire between component and old wire { pn = pn2; mask ^= 3; @@ -1692,7 +1694,7 @@ void Schematic::newMovingWires(Q3PtrList *p, Node *pn, int pos) invMask ^= 3; // ................................................. // create new wire ? - if(pw2 == 0) + if(pw2 == nullptr) { if(pw->Port1 != (Node*)(uintptr_t)mask) p->insert(pos, @@ -1715,7 +1717,7 @@ void Schematic::newMovingWires(Q3PtrList *p, Node *pn, int pos) if(pw2->Port1 != pn2) { - pw2->Port1 = (Node*)0; + pw2->Port1 = (Node*)nullptr; pw2->Port2->State |= mask; pw2->Port2 = (Node*)(uintptr_t)mask; } @@ -1723,7 +1725,7 @@ void Schematic::newMovingWires(Q3PtrList *p, Node *pn, int pos) { pw2->Port1->State |= mask; pw2->Port1 = (Node*)(uintptr_t)mask; - pw2->Port2 = (Node*)0; + pw2->Port2 = (Node*)nullptr; } return; } @@ -1752,14 +1754,14 @@ int Schematic::copySelectedElements(Q3PtrList *p) // test all components ********************************* // Insert components before wires in order to prevent short-cut removal. - for(pc = Components->first(); pc != 0; ) + for(pc = Components->first(); pc != nullptr; ) if(pc->isSelected) { p->append(pc); count++; // delete all port connections - foreach(Port *pp, pc->Ports) + for (Port *pp : pc->Ports) { pp->Connection->Connections.removeRef((Element*)pc); pp->Connection->State = 4; @@ -1771,7 +1773,7 @@ int Schematic::copySelectedElements(Q3PtrList *p) else pc = Components->next(); // test all wires and wire labels *********************** - for(pw = Wires->first(); pw != 0; ) + for(pw = Wires->first(); pw != nullptr; ) { if(pw->Label) if(pw->Label->isSelected) p->append(pw->Label); @@ -1797,18 +1799,18 @@ int Schematic::copySelectedElements(Q3PtrList *p) pc = (Component*)p->first(); for(i=0; iPorts) + for (Port *pp : pc->Ports) newMovingWires(p, pp->Connection, count); p->findRef(pc); // back to the real current pointer pc = (Component*)p->next(); } - for(pe = (Element*)pc; pe != 0; pe = p->next()) // new wires + for(pe = (Element*)pc; pe != nullptr; pe = p->next()) // new wires if(pe->isSelected) break; - for(pw = (Wire*)pe; pw != 0; pw = (Wire*)p->next()) + for(pw = (Wire*)pe; pw != nullptr; pw = (Wire*)p->next()) if(pw->Type == isWire) // not working on labels { newMovingWires(p, pw->Port1, count); @@ -1878,7 +1880,7 @@ int Schematic::copySelectedElements(Q3PtrList *p) } else { - foreach(Graph *pg, pd->Graphs) + for (Graph *pg : pd->Graphs) { QMutableListIterator im(pg->Markers); Marker *pm; @@ -2484,7 +2486,7 @@ void Schematic::insertComponentNodes(Component *c, bool noOptimize) if (c->Ports.empty()) return; // connect every node of the component to corresponding schematic node - foreach(Port *pp, c->Ports) + for (Port *pp : c->Ports) pp->Connection = insertNode(pp->x+c->cx, pp->y+c->cy, c); if(noOptimize) return; @@ -2550,7 +2552,7 @@ void Schematic::recreateComponent(Component *Comp) // Save the labels whose node is not connected to somewhere else. // Otherwise the label would be deleted. pl = plMem = (WireLabel**)malloc(PortCount * sizeof(WireLabel*)); - foreach(Port *pp, Comp->Ports) + for (Port *pp : Comp->Ports) if(pp->Connection->Connections.count() < 2) { *(pl++) = pp->Connection->Label; @@ -2581,7 +2583,7 @@ void Schematic::recreateComponent(Component *Comp) { // restore node labels pl = plMem; - foreach(Port *pp, Comp->Ports) + for (Port *pp : Comp->Ports) { if(*pl != 0) { @@ -2754,7 +2756,7 @@ void Schematic::setCompPorts(Component *pc) WireLabel *pl; Q3PtrList LabelCache; - foreach(Port *pp, pc->Ports) + for (Port *pp : pc->Ports) { pp->Connection->Connections.removeRef((Element*)pc);// delete connections switch(pp->Connection->Connections.count()) @@ -2778,7 +2780,7 @@ void Schematic::setCompPorts(Component *pc) // Re-connect component node to schematic node. This must be done completely // after the first loop in order to avoid problems with node labels. - foreach(Port *pp, pc->Ports) + for (Port *pp : pc->Ports) pp->Connection = insertNode(pp->x+pc->cx, pp->y+pc->cy, pc); for(pl = LabelCache.first(); pl != 0; pl = LabelCache.next()) @@ -2787,7 +2789,7 @@ void Schematic::setCompPorts(Component *pc) // --------------------------------------------------- // Returns a pointer of the component on whose text x/y points. -Component* Schematic::selectCompText(int x_, int y_, int& w, int& h) +Component* Schematic::selectCompText(int x_, int y_, int& w, int& h) const { int a, b, dx, dy; for(Component *pc = Components->first(); pc != 0; pc = Components->next()) @@ -2843,11 +2845,11 @@ Component* Schematic::selectedComponent(int x, int y) void Schematic::deleteComp(Component *c) { // delete all port connections - foreach(Port *pn, c->Ports) + for (Port *pn : c->Ports) switch(pn->Connection->Connections.count()) { case 1 : - if(pn->Connection->Label) delete pn->Connection->Label; + delete pn->Connection->Label; Nodes->removeRef(pn->Connection); // delete open nodes pn->Connection = 0; // (auto-delete) break; @@ -2863,12 +2865,12 @@ void Schematic::deleteComp(Component *c) Components->removeRef(c); // delete component } -Component* Schematic::getComponentByName(QString compname) +Component* Schematic::getComponentByName(const QString& compname) { - for(Component *pc = DocComps.first(); pc != 0; pc = DocComps.next()) { + for(Component *pc = DocComps.first(); pc != nullptr; pc = DocComps.next()) { if (pc->Name == compname) return pc; } - return NULL; + return nullptr; } // --------------------------------------------------- @@ -2892,7 +2894,7 @@ int Schematic::copyComponents(int& x1, int& y1, int& x2, int& y2, ElementCache->append(pc); // rescue non-selected node labels - foreach(Port *pp, pc->Ports) + for (Port *pp : pc->Ports) if(pp->Connection->Label) if(pp->Connection->Connections.count() < 2) { @@ -2934,7 +2936,7 @@ void Schematic::copyComponents2(int& x1, int& y1, int& x2, int& y2, ElementCache->append(pc); // rescue non-selected node labels - foreach(Port *pp, pc->Ports) + for (Port *pp : pc->Ports) if(pp->Connection->Label) if(pp->Connection->Connections.count() < 2) { diff --git a/qucs/schematic_file.cpp b/qucs/schematic_file.cpp index 616c48c0..73f12c90 100644 --- a/qucs/schematic_file.cpp +++ b/qucs/schematic_file.cpp @@ -676,7 +676,7 @@ void Schematic::simpleInsertComponent(Component *c) Node *pn; int x, y; // connect every node of component - foreach(Port *pp, c->Ports) { + for (Port *pp : c->Ports) { x = pp->x+c->cx; y = pp->y+c->cy; @@ -692,7 +692,7 @@ void Schematic::simpleInsertComponent(Component *c) break; } - if(pn == 0) { // create new node, if no existing one lies at this position + if(pn == nullptr) { // create new node, if no existing one lies at this position pn = new Node(x, y); DocNodes.append(pn); } @@ -1330,7 +1330,7 @@ bool Schematic::throughAllComps(QTextStream *stream, int& countInit, { i = 0; // apply in/out signal types of subcircuit - foreach(Port *pp, pc->Ports) + for (Port *pp : pc->Ports) { pp->Type = it.value().PortTypes[i]; pp->Connection->DType = pp->Type; @@ -1368,7 +1368,7 @@ bool Schematic::throughAllComps(QTextStream *stream, int& countInit, { i = 0; // save in/out signal types of subcircuit - foreach(Port *pp, pc->Ports) + for (Port *pp : pc->Ports) { //if(i>=d->PortTypes.count())break; pp->Type = d->PortTypes[i]; diff --git a/qucs/spicecomponents/C_SPICE.cpp b/qucs/spicecomponents/C_SPICE.cpp index 08818660..1c88e1c3 100644 --- a/qucs/spicecomponents/C_SPICE.cpp +++ b/qucs/spicecomponents/C_SPICE.cpp @@ -81,7 +81,7 @@ QString C_SPICE::netlist() QString C_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/DIODE_SPICE.cpp b/qucs/spicecomponents/DIODE_SPICE.cpp index bf24b4a4..2a2aa3a1 100644 --- a/qucs/spicecomponents/DIODE_SPICE.cpp +++ b/qucs/spicecomponents/DIODE_SPICE.cpp @@ -87,7 +87,7 @@ QString DIODE_SPICE::netlist() QString DIODE_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/K_SPICE.cpp b/qucs/spicecomponents/K_SPICE.cpp index ba70112b..405b6d5d 100644 --- a/qucs/spicecomponents/K_SPICE.cpp +++ b/qucs/spicecomponents/K_SPICE.cpp @@ -78,7 +78,7 @@ QString K_SPICE::netlist() QString K_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/LTL_SPICE.cpp b/qucs/spicecomponents/LTL_SPICE.cpp index 21b28a60..8db3bb0d 100644 --- a/qucs/spicecomponents/LTL_SPICE.cpp +++ b/qucs/spicecomponents/LTL_SPICE.cpp @@ -91,7 +91,7 @@ QString LTL_SPICE::netlist() QString LTL_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/spicecomponents/LTRA_SPICE.cpp b/qucs/spicecomponents/LTRA_SPICE.cpp index 114757b6..aacb4d15 100644 --- a/qucs/spicecomponents/LTRA_SPICE.cpp +++ b/qucs/spicecomponents/LTRA_SPICE.cpp @@ -97,7 +97,7 @@ QString LTRA_SPICE::netlist() QString LTRA_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/L_SPICE.cpp b/qucs/spicecomponents/L_SPICE.cpp index 42c963f0..0076c61c 100644 --- a/qucs/spicecomponents/L_SPICE.cpp +++ b/qucs/spicecomponents/L_SPICE.cpp @@ -86,7 +86,7 @@ QString L_SPICE::netlist() QString L_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/MESFET_SPICE.cpp b/qucs/spicecomponents/MESFET_SPICE.cpp index 2d71bedb..5ab38d9a 100644 --- a/qucs/spicecomponents/MESFET_SPICE.cpp +++ b/qucs/spicecomponents/MESFET_SPICE.cpp @@ -89,7 +89,7 @@ QString MESFET_SPICE::netlist() QString MESFET_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/MOS_SPICE.cpp b/qucs/spicecomponents/MOS_SPICE.cpp index c21e30f4..fbb80035 100644 --- a/qucs/spicecomponents/MOS_SPICE.cpp +++ b/qucs/spicecomponents/MOS_SPICE.cpp @@ -223,7 +223,7 @@ void MOS_SPICE::createSymbol() QString MOS_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,Props.at(0)->Value); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/NJF_SPICE.cpp b/qucs/spicecomponents/NJF_SPICE.cpp index f57a306e..919a8374 100644 --- a/qucs/spicecomponents/NJF_SPICE.cpp +++ b/qucs/spicecomponents/NJF_SPICE.cpp @@ -95,7 +95,7 @@ QString NJF_SPICE::netlist() QString NJF_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/NMOS_SPICE.cpp b/qucs/spicecomponents/NMOS_SPICE.cpp index 9284d13d..8fdd57a4 100644 --- a/qucs/spicecomponents/NMOS_SPICE.cpp +++ b/qucs/spicecomponents/NMOS_SPICE.cpp @@ -105,7 +105,7 @@ QString NMOS_SPICE::netlist() QString NMOS_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/NPN_SPICE.cpp b/qucs/spicecomponents/NPN_SPICE.cpp index edee8c59..1df0bc09 100644 --- a/qucs/spicecomponents/NPN_SPICE.cpp +++ b/qucs/spicecomponents/NPN_SPICE.cpp @@ -97,7 +97,7 @@ QString NPN_SPICE::netlist() QString NPN_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/PJF_SPICE.cpp b/qucs/spicecomponents/PJF_SPICE.cpp index 92aec75c..bb859d33 100644 --- a/qucs/spicecomponents/PJF_SPICE.cpp +++ b/qucs/spicecomponents/PJF_SPICE.cpp @@ -95,7 +95,7 @@ QString PJF_SPICE::netlist() QString PJF_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/PMF_MESFET_SPICE.cpp b/qucs/spicecomponents/PMF_MESFET_SPICE.cpp index 114e1de8..1b447149 100644 --- a/qucs/spicecomponents/PMF_MESFET_SPICE.cpp +++ b/qucs/spicecomponents/PMF_MESFET_SPICE.cpp @@ -89,7 +89,7 @@ QString PMF_MESFET_SPICE::netlist() QString PMF_MESFET_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/PMOS_SPICE.cpp b/qucs/spicecomponents/PMOS_SPICE.cpp index 1050d1b7..314e7090 100644 --- a/qucs/spicecomponents/PMOS_SPICE.cpp +++ b/qucs/spicecomponents/PMOS_SPICE.cpp @@ -105,7 +105,7 @@ QString PMOS_SPICE::netlist() QString PMOS_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/PNP_SPICE.cpp b/qucs/spicecomponents/PNP_SPICE.cpp index a861f18b..7cf022da 100644 --- a/qucs/spicecomponents/PNP_SPICE.cpp +++ b/qucs/spicecomponents/PNP_SPICE.cpp @@ -98,7 +98,7 @@ QString PNP_SPICE::netlist() QString PNP_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/R_SPICE.cpp b/qucs/spicecomponents/R_SPICE.cpp index cb619e6e..9d24eabe 100644 --- a/qucs/spicecomponents/R_SPICE.cpp +++ b/qucs/spicecomponents/R_SPICE.cpp @@ -85,7 +85,7 @@ QString R_SPICE::netlist() QString R_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/S4Q_I.cpp b/qucs/spicecomponents/S4Q_I.cpp index 33a19aa2..84446d29 100644 --- a/qucs/spicecomponents/S4Q_I.cpp +++ b/qucs/spicecomponents/S4Q_I.cpp @@ -79,7 +79,7 @@ Element* S4Q_I::info(QString& Name, char* &BitmapFile, bool getNewOne) QString S4Q_I::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/S4Q_Ieqndef.cpp b/qucs/spicecomponents/S4Q_Ieqndef.cpp index a05cac9c..eb8f1ea0 100644 --- a/qucs/spicecomponents/S4Q_Ieqndef.cpp +++ b/qucs/spicecomponents/S4Q_Ieqndef.cpp @@ -89,7 +89,7 @@ QString S4Q_Ieqndef::netlist() QString S4Q_Ieqndef::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam + " "; // node names diff --git a/qucs/spicecomponents/S4Q_S.cpp b/qucs/spicecomponents/S4Q_S.cpp index 9dc44b2c..389bafa0 100644 --- a/qucs/spicecomponents/S4Q_S.cpp +++ b/qucs/spicecomponents/S4Q_S.cpp @@ -96,7 +96,7 @@ Element* S4Q_S::info(QString& Name, char* &BitmapFile, bool getNewOne) QString S4Q_S::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/S4Q_V.cpp b/qucs/spicecomponents/S4Q_V.cpp index 0bab9507..89505458 100644 --- a/qucs/spicecomponents/S4Q_V.cpp +++ b/qucs/spicecomponents/S4Q_V.cpp @@ -80,7 +80,7 @@ Element* S4Q_V::info(QString& Name, char* &BitmapFile, bool getNewOne) QString S4Q_V::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/S4Q_W.cpp b/qucs/spicecomponents/S4Q_W.cpp index c575a334..2be311bb 100644 --- a/qucs/spicecomponents/S4Q_W.cpp +++ b/qucs/spicecomponents/S4Q_W.cpp @@ -84,7 +84,7 @@ Element* S4Q_W::info(QString& Name, char* &BitmapFile, bool getNewOne) QString S4Q_W::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/UDRCTL_SPICE.cpp b/qucs/spicecomponents/UDRCTL_SPICE.cpp index 337ac94f..83e5a536 100644 --- a/qucs/spicecomponents/UDRCTL_SPICE.cpp +++ b/qucs/spicecomponents/UDRCTL_SPICE.cpp @@ -95,7 +95,7 @@ QString UDRCTL_SPICE::netlist() QString UDRCTL_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/eNL.cpp b/qucs/spicecomponents/eNL.cpp index 0692b45f..1135f878 100644 --- a/qucs/spicecomponents/eNL.cpp +++ b/qucs/spicecomponents/eNL.cpp @@ -82,7 +82,7 @@ QString eNL::netlist() QString eNL::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/spicecomponents/gNL.cpp b/qucs/spicecomponents/gNL.cpp index 36e01948..61b204b5 100644 --- a/qucs/spicecomponents/gNL.cpp +++ b/qucs/spicecomponents/gNL.cpp @@ -82,7 +82,7 @@ QString gNL::netlist() QString gNL::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/spicecomponents/iAmpMod.cpp b/qucs/spicecomponents/iAmpMod.cpp index dcf091a2..1a09cdb3 100644 --- a/qucs/spicecomponents/iAmpMod.cpp +++ b/qucs/spicecomponents/iAmpMod.cpp @@ -89,7 +89,7 @@ QString iAmpMod::netlist() QString iAmpMod::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/spicecomponents/iPWL.cpp b/qucs/spicecomponents/iPWL.cpp index ea104c77..b4cc1472 100644 --- a/qucs/spicecomponents/iPWL.cpp +++ b/qucs/spicecomponents/iPWL.cpp @@ -91,7 +91,7 @@ QString iPWL::netlist() QString iPWL::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/iTRNOISE.cpp b/qucs/spicecomponents/iTRNOISE.cpp index c1e329a9..14204137 100644 --- a/qucs/spicecomponents/iTRNOISE.cpp +++ b/qucs/spicecomponents/iTRNOISE.cpp @@ -100,7 +100,7 @@ QString iTRNOISE::netlist() QString iTRNOISE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/spicecomponents/isffm.cpp b/qucs/spicecomponents/isffm.cpp index a35c0cd9..98bfaad5 100644 --- a/qucs/spicecomponents/isffm.cpp +++ b/qucs/spicecomponents/isffm.cpp @@ -89,7 +89,7 @@ QString iSffm::netlist() QString iSffm::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/spicecomponents/sp_func.cpp b/qucs/spicecomponents/sp_func.cpp index d737fb9e..c518ef75 100644 --- a/qucs/spicecomponents/sp_func.cpp +++ b/qucs/spicecomponents/sp_func.cpp @@ -74,7 +74,7 @@ QString SpiceFunc::getExpression(bool) QString s; s.clear(); - foreach (Property *pp, Props) { + for (Property *pp : Props) { if ((QucsSettings.DefaultSimulator==spicecompat::simXyceSer)|| (QucsSettings.DefaultSimulator==spicecompat::simXycePar)) s += QString(".FUNC %1 %2\n").arg(pp->Name).arg(pp->Value); diff --git a/qucs/spicecomponents/sp_globalpar.cpp b/qucs/spicecomponents/sp_globalpar.cpp index fe893dcb..88335f5a 100644 --- a/qucs/spicecomponents/sp_globalpar.cpp +++ b/qucs/spicecomponents/sp_globalpar.cpp @@ -74,7 +74,7 @@ QString SpiceGlobalParam::getExpression(bool) QString s; s.clear(); - foreach (Property *pp, Props) { + for (Property *pp : Props) { s += QString(".GLOBAL_PARAM %1 = %2\n").arg(pp->Name).arg(pp->Value); } return s; diff --git a/qucs/spicecomponents/sp_ic.cpp b/qucs/spicecomponents/sp_ic.cpp index 444d5f17..66236d78 100644 --- a/qucs/spicecomponents/sp_ic.cpp +++ b/qucs/spicecomponents/sp_ic.cpp @@ -73,7 +73,7 @@ QString SpiceIC::getExpression(bool) QString s; s.clear(); - foreach (Property *pp, Props) { + for (Property *pp : Props) { s += QString(".IC %1 = %2\n").arg(pp->Name).arg(pp->Value); } return s; diff --git a/qucs/spicecomponents/sp_include.cpp b/qucs/spicecomponents/sp_include.cpp index e7adad72..758cc14f 100644 --- a/qucs/spicecomponents/sp_include.cpp +++ b/qucs/spicecomponents/sp_include.cpp @@ -78,7 +78,7 @@ QString S4Q_Include::getSpiceModel() QString s; s.clear(); - foreach (Property *pp, Props) { + for (Property *pp : Props) { QString val = pp->Value; if (!val.isEmpty()) { val = spicecompat::convert_relative_filename(val); diff --git a/qucs/spicecomponents/sp_model.cpp b/qucs/spicecomponents/sp_model.cpp index 87e0af7c..0a0adca0 100644 --- a/qucs/spicecomponents/sp_model.cpp +++ b/qucs/spicecomponents/sp_model.cpp @@ -80,7 +80,7 @@ QString S4Q_Model::getSpiceModel() QString s; s.clear(); - foreach (Property *pp, Props) { + for (Property *pp : Props) { if (!pp->Value.isEmpty()) s += pp->Value + "\n"; } diff --git a/qucs/spicecomponents/sp_nodeset.cpp b/qucs/spicecomponents/sp_nodeset.cpp index 52307a39..210c8107 100644 --- a/qucs/spicecomponents/sp_nodeset.cpp +++ b/qucs/spicecomponents/sp_nodeset.cpp @@ -73,7 +73,7 @@ QString SpiceNodeset::getExpression(bool) QString s; s.clear(); - foreach (Property *pp, Props) { + for (Property *pp : Props) { s += QString(".NODESET %1 = %2\n").arg(pp->Name).arg(pp->Value); } return s; diff --git a/qucs/spicecomponents/sp_parameter.cpp b/qucs/spicecomponents/sp_parameter.cpp index e068e7f1..a42bccd6 100644 --- a/qucs/spicecomponents/sp_parameter.cpp +++ b/qucs/spicecomponents/sp_parameter.cpp @@ -73,7 +73,7 @@ QString SpiceParam::getExpression(bool) QString s; s.clear(); - foreach (Property *pp, Props) { + for (Property *pp : Props) { s += QString(".PARAM %1 = %2\n").arg(pp->Name).arg(pp->Value); } return s; diff --git a/qucs/spicecomponents/spicegeneric.cpp b/qucs/spicecomponents/spicegeneric.cpp index 411b4de1..8084b211 100644 --- a/qucs/spicecomponents/spicegeneric.cpp +++ b/qucs/spicecomponents/spicegeneric.cpp @@ -121,7 +121,7 @@ void SpiceGeneric::createSymbol() fHeight = metrics.lineSpacing(); tx = x1+4; ty = y1 - fHeight - 4; - foreach(Property *pp,Props) { + for (Property *pp : Props) { if (pp->display) ty -= fHeight; } changed = true; @@ -137,7 +137,7 @@ QString SpiceGeneric::spice_netlist(bool) { // form RefDes from unique device letter and device name QString s = Props.at(1)->Value + Name; - foreach(Port *pp, Ports) { + for (Port *pp : Ports) { s += " " + spicecompat::normalize_node_name(pp->Connection->Name); } diff --git a/qucs/spicecomponents/spicelibcomp.cpp b/qucs/spicecomponents/spicelibcomp.cpp index 356569c9..858ebb82 100644 --- a/qucs/spicecomponents/spicelibcomp.cpp +++ b/qucs/spicecomponents/spicelibcomp.cpp @@ -215,7 +215,7 @@ int SpiceLibComp::loadSymbol(const QString& DocName) QString SpiceLibComp::spice_netlist(bool) { QString s = QString("X%1 ").arg(Name); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { s += " " + spicecompat::normalize_node_name(p1->Connection->Name); } s += QString(" %1 %2\n").arg(Props.at(1)->Value).arg(Props.at(3)->Value); @@ -236,7 +236,7 @@ void SpiceLibComp::getSymbolPatternsList(QStringList &symbols) QString dir_name = QucsSettings.BinDir + "/../share/" QUCS_NAME "/symbols/"; QDir sym_dir(dir_name); QStringList sym_files = sym_dir.entryList(QDir::Files); - foreach (QString file,sym_files) { + for (const QString& file : sym_files) { QFileInfo inf(file); symbols.append(inf.baseName()); } diff --git a/qucs/spicecomponents/src_eqndef.cpp b/qucs/spicecomponents/src_eqndef.cpp index cd47ffe1..6099c06f 100644 --- a/qucs/spicecomponents/src_eqndef.cpp +++ b/qucs/spicecomponents/src_eqndef.cpp @@ -67,7 +67,7 @@ QString Src_eqndef::netlist() QString Src_eqndef::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam + " "; // node names diff --git a/qucs/spicecomponents/vAmpMod.cpp b/qucs/spicecomponents/vAmpMod.cpp index ea3ebb4c..a70452df 100644 --- a/qucs/spicecomponents/vAmpMod.cpp +++ b/qucs/spicecomponents/vAmpMod.cpp @@ -92,7 +92,7 @@ QString vAmpMod::netlist() QString vAmpMod::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/spicecomponents/vPWL.cpp b/qucs/spicecomponents/vPWL.cpp index 6a4bbc51..aac0cd72 100644 --- a/qucs/spicecomponents/vPWL.cpp +++ b/qucs/spicecomponents/vPWL.cpp @@ -89,7 +89,7 @@ QString vPWL::netlist() QString vPWL::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/vTRNOISE.cpp b/qucs/spicecomponents/vTRNOISE.cpp index 928fddf9..32013f52 100644 --- a/qucs/spicecomponents/vTRNOISE.cpp +++ b/qucs/spicecomponents/vTRNOISE.cpp @@ -96,7 +96,7 @@ QString vTRNOISE::netlist() QString vTRNOISE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/spicecomponents/vTRRANDOM.cpp b/qucs/spicecomponents/vTRRANDOM.cpp index 6c713bbf..b72c5053 100644 --- a/qucs/spicecomponents/vTRRANDOM.cpp +++ b/qucs/spicecomponents/vTRRANDOM.cpp @@ -97,7 +97,7 @@ QString vTRRANDOM::netlist() QString vTRRANDOM::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/spicecomponents/volt_ac_SPICE.cpp b/qucs/spicecomponents/volt_ac_SPICE.cpp index dcb9874e..dc653ae9 100644 --- a/qucs/spicecomponents/volt_ac_SPICE.cpp +++ b/qucs/spicecomponents/volt_ac_SPICE.cpp @@ -76,7 +76,7 @@ Element* Vac_SPICE::info(QString& Name, char* &BitmapFile, bool getNewOne) QString Vac_SPICE::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam+" "; // node names diff --git a/qucs/spicecomponents/vsffm.cpp b/qucs/spicecomponents/vsffm.cpp index b711cc5c..dd9aa0ab 100644 --- a/qucs/spicecomponents/vsffm.cpp +++ b/qucs/spicecomponents/vsffm.cpp @@ -90,7 +90,7 @@ QString vSffm::netlist() QString vSffm::spice_netlist(bool) { QString s = spicecompat::check_refdes(Name,SpiceModel); - foreach(Port *p1, Ports) { + for (Port *p1 : Ports) { QString nam = p1->Connection->Name; if (nam=="gnd") nam = "0"; s += " "+ nam; // node names diff --git a/qucs/spicecomponents/xsp_cmlib.cpp b/qucs/spicecomponents/xsp_cmlib.cpp index c2719dc7..eb59dfb2 100644 --- a/qucs/spicecomponents/xsp_cmlib.cpp +++ b/qucs/spicecomponents/xsp_cmlib.cpp @@ -76,7 +76,7 @@ QString XSP_CMlib::getSpiceInit() { QString s; s.clear(); - foreach (Property *pp,Props) { + for (Property *pp : Props) { if (!pp->Value.isEmpty()) { QString f = spicecompat::convert_relative_filename(pp->Value); s += "codemodel " + f + "\n"; diff --git a/qucs/spicecomponents/xspicegeneric.cpp b/qucs/spicecomponents/xspicegeneric.cpp index 06f4d71a..3cd14621 100644 --- a/qucs/spicecomponents/xspicegeneric.cpp +++ b/qucs/spicecomponents/xspicegeneric.cpp @@ -78,7 +78,7 @@ void XspiceGeneric::createSymbol() QStringList t_ports = Props.at(0)->Value.split(','); QStringList n_ports; int k=0; - foreach (QString t_port, t_ports) { + for (QString t_port : t_ports) { t_port.remove(']').remove('['); if ((t_port.remove(' ').endsWith('d'))&& (t_port!="d")) { @@ -152,7 +152,7 @@ QString XspiceGeneric::spice_netlist(bool) QStringList t_ports = Props.at(0)->Value.split(','); int i=0; - foreach(QString t_port,t_ports) { + for(QString t_port : t_ports) { QString nod = spicecompat::normalize_node_name(Ports.at(i)->Connection->Name); if (t_port.contains('[')) { // Process array ports diff --git a/qucs/syntax.cpp b/qucs/syntax.cpp index c25c4bcb..5e4055f5 100644 --- a/qucs/syntax.cpp +++ b/qucs/syntax.cpp @@ -207,37 +207,37 @@ void SyntaxHighlighter::setLanguage(int lang) break; } - foreach (const QString &pattern, reservedWordPattern) { + for (const QString &pattern : reservedWordPattern) { rule.pattern = QRegExp(pattern); rule.format = reservedWordFormat; highlightingRules.append(rule); } - foreach (const QString &pattern, unitPattern) { + for (const QString &pattern : unitPattern) { rule.pattern = QRegExp(pattern); rule.format = unitFormat; highlightingRules.append(rule); } - foreach (const QString &pattern, datatypePattern) { + for (const QString &pattern : datatypePattern) { rule.pattern = QRegExp(pattern); rule.format = datatypeFormat; highlightingRules.append(rule); } - foreach (const QString &pattern, directivePattern) { + for (const QString &pattern : directivePattern) { rule.pattern = QRegExp(pattern); rule.format = directiveFormat; highlightingRules.append(rule); } - foreach (const QString &pattern, functionPattern) { + for (const QString &pattern : functionPattern) { rule.pattern = QRegExp(pattern); rule.format = functionFormat; highlightingRules.append(rule); } - foreach (const QString &pattern, commentPattern) { + for (const QString &pattern : commentPattern) { rule.pattern = QRegExp(pattern); rule.format = commentFormat; highlightingRules.append(rule); @@ -245,17 +245,14 @@ void SyntaxHighlighter::setLanguage(int lang) } // --------------------------------------------------- -void SyntaxHighlighter::highlightBlock(const QString& text) { - - -foreach (const HighlightingRule &rule, highlightingRules) { - QRegExp expression(rule.pattern); - int index = expression.indexIn(text); - while (index >= 0) { - int length = expression.matchedLength(); - setFormat(index, length, rule.format); - index = expression.indexIn(text, index + length); - } - } - +void SyntaxHighlighter::highlightBlock(const QString &text) { + for (const HighlightingRule &rule : highlightingRules) { + QRegExp expression(rule.pattern); + int index = expression.indexIn(text); + while (index >= 0) { + int length = expression.matchedLength(); + setFormat(index, length, rule.format); + index = expression.indexIn(text, index + length); + } + } }