qucs_s/qucs/components/spicefile.h
ThomasZecha 909f02340d New feature CDL netlist export
-introduced new type spicecompat::SpiceDialect to distinguish SPICE,
 Xyce and CDL
-adapt dependent components accordingly

Signed-off-by: ThomasZecha <zecha@ihp-microelectronics.com>
2024-12-30 16:52:35 +01:00

70 lines
2.2 KiB
C++

/***************************************************************************
spicefile.h
-------------
begin : Tue Dec 28 2004
copyright : (C) 2004 by Michael Margraf
email : michael.margraf@alumni.tu-berlin.de
***************************************************************************/
/***************************************************************************
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
***************************************************************************/
#ifndef SPICEFILE_H
#define SPICEFILE_H
#include "component.h"
#include <QObject>
#include <QDateTime>
class QProcess;
class QTextStream;
class QString;
class SpiceFile : public QObject, public MultiViewComponent {
Q_OBJECT
public:
SpiceFile();
~SpiceFile() {};
Component* newOne();
static Element* info(QString&, char* &, bool getNewOne=false);
bool withSim;
bool createSubNetlist(QTextStream *);
bool createSpiceSubckt(QTextStream * stream);
QString getErrorText() { return ErrText; }
QString getSubcircuitFile();
private:
bool makeSubcircuit;
bool insertSim;
bool changed;
QProcess *QucsConv, *SpicePrep;
QString NetText, ErrText, NetLine, SimText;
QTextStream *outstream, *filstream, *prestream;
QDateTime lastLoaded;
bool recreateSubNetlist(QString *, QString *);
protected:
QString netlist();
void createSymbol();
QString spice_netlist(spicecompat::SpiceDialect dialect = spicecompat::SPICEDefault);
virtual QString cdl_netlist();
private slots:
void slotGetNetlist();
void slotGetError();
void slotExited();
void slotSkipOut();
void slotSkipErr();
void slotGetPrepOut();
void slotGetPrepErr();
};
#endif