Blame view

GUI/SW2/SRC/src/process/PrcGNetList.hpp 3.65 KB
886c558b   Steve Greedy   SACAMOS Public Re...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
//**************************************************************************************************
//                                         PrcGNetList.hpp                                         *
//                                        -----------------                                        *
// Description : Provides a programatic interface to the utility gnetlist which is used to         *
//               generate netlist file from various schematic editor formats.                      *
// Started     : 2004-01-29                                                                        *
// Last Update : 2016-10-21                                                                        *
// Copyright   : (C) 2004-2016 MSWaters                                                            *
//**************************************************************************************************

//**************************************************************************************************
//                                                                                                 *
//      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 3 of the License, or (at your option) any later version.                    *
//                                                                                                 *
//**************************************************************************************************

#ifndef PRCGNETLIST_HPP
#define PRCGNETLIST_HPP

// Application Includes

#include "TypeDefs.hpp"
#include "Config.hpp"
#include "base/PrcBase.hpp"

// wxWidgets Includes

#include <wx/filename.h>
#include <wx/regex.h>
#include <wx/tokenzr.h>

// Local Constant Declarations

#define  GNETLST_LOG_FILE    wxT("gspiceui.log")   // Default log file name
#define  GNETLST_GUILE_PROC  wxT("spice-sdb")      // Default Guile procedure
#define  GNETLST_USE_SCHEM   wxT("use-schem-name") // Use schematic name for to create netlist name
#define  GNETLST_CUR_PROC    1000                  // A value greater than the no. of Guile proc's

//**************************************************************************************************

class PrcGNetList : public PrcBase
{
  private :

            size_t         m_szGuileProc;    // The Guile procedure specifier
    static  wxArrayString  m_oasGuileProcs;  // Array of all possible Guile procedures
            ArrayFileName  m_oaNameSchems;   // The full names of the schematic file/s
            wxFileName     m_oNameNetLst;    // The full name  of the list file

    void  InitGuileProcs( void );

  public :

          PrcGNetList( void );
         ~PrcGNetList( );

    bool  bClear( void );

    bool  bSetGuileProc ( const wxString      &  rosGProc );
    bool  bSetSchemFiles( const wxString      &  rosFileNames );
    bool  bSetSchemFiles( const wxArrayString & roasFileNames );
    bool  bSetNetLstFile( const wxString      &  rosFileName=GNETLST_USE_SCHEM );

    static const wxArrayString & roasGetGuileProcs( void ) { return( m_oasGuileProcs ); }
           const wxString      &  rosGetGuileProc ( size_t szIndex=GNETLST_CUR_PROC );
           const ArrayFileName &  roaGetSchemFiles( void ) { return( m_oaNameSchems  ); }
           const wxFileName    &   roGetSchemFile ( size_t szIndex=0 );
           const wxFileName    &   roGetNetLstFile( void ) { return( m_oNameNetLst   ); }

    virtual  bool  bExec( void );
};

//**************************************************************************************************

#endif // PRCGNETLIST_HPP