mirror of
https://github.com/ra3xdh/qucs_s
synced 2025-03-28 21:13:26 +00:00

-introduced new type spicecompat::SpiceDialect to distinguish SPICE, Xyce and CDL -adapt dependent components accordingly Signed-off-by: ThomasZecha <zecha@ihp-microelectronics.com>
70 lines
2.2 KiB
C++
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
|