You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							171 lines
						
					
					
						
							6.8 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							171 lines
						
					
					
						
							6.8 KiB
						
					
					
				
								#ifndef _SCH_LEGACY_PLUGIN_H_
							 | 
						|
								#define _SCH_LEGACY_PLUGIN_H_
							 | 
						|
								
							 | 
						|
								/*
							 | 
						|
								 * This program source code file is part of KiCad, a free EDA CAD application.
							 | 
						|
								 *
							 | 
						|
								 * Copyright (C) 2016 CERN
							 | 
						|
								 * Copyright (C) 2016-2017 KiCad Developers, see change_log.txt for contributors.
							 | 
						|
								 *
							 | 
						|
								 * @author Wayne Stambaugh <stambaughw@gmail.com>
							 | 
						|
								 *
							 | 
						|
								 * 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.
							 | 
						|
								 *
							 | 
						|
								 * This program is distributed in the hope that it will be useful,
							 | 
						|
								 * but WITHOUT ANY WARRANTY; without even the implied warranty of
							 | 
						|
								 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
							 | 
						|
								 * GNU General Public License for more details.
							 | 
						|
								 *
							 | 
						|
								 * You should have received a copy of the GNU General Public License along
							 | 
						|
								 * with this program.  If not, see <http://www.gnu.org/licenses/>.
							 | 
						|
								 */
							 | 
						|
								
							 | 
						|
								#include <sch_io_mgr.h>
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								class KIWAY;
							 | 
						|
								class LINE_READER;
							 | 
						|
								class SCH_SCREEN;
							 | 
						|
								class SCH_SHEET;
							 | 
						|
								class SCH_BITMAP;
							 | 
						|
								class SCH_JUNCTION;
							 | 
						|
								class SCH_NO_CONNECT;
							 | 
						|
								class SCH_LINE;
							 | 
						|
								class SCH_BUS_ENTRY_BASE;
							 | 
						|
								class SCH_TEXT;
							 | 
						|
								class SCH_COMPONENT;
							 | 
						|
								class SCH_FIELD;
							 | 
						|
								class PROPERTIES;
							 | 
						|
								class SCH_LEGACY_PLUGIN_CACHE;
							 | 
						|
								class LIB_PART;
							 | 
						|
								class PART_LIB;
							 | 
						|
								class LIB_ALIAS;
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								/**
							 | 
						|
								 * Class SCH_LEGACY_PLUGIN
							 | 
						|
								 *
							 | 
						|
								 * is a #SCH_PLUGIN derivation for loading schematic files created before the new
							 | 
						|
								 * s-expression file format.
							 | 
						|
								 *
							 | 
						|
								 * The legacy parser and formatter attempt to be compatible with the legacy file format.
							 | 
						|
								 * The original parser was very forgiving in that it would parse only part of a keyword.
							 | 
						|
								 * So "$C", "$Co", and "$Com" could be used for "$Comp" and the old parser would allow
							 | 
						|
								 * this.  This parser is not that forgiving and sticks to the legacy file format document.
							 | 
						|
								 *
							 | 
						|
								 * As with all SCH_PLUGINs there is no UI dependencies i.e. windowing calls allowed.
							 | 
						|
								 */
							 | 
						|
								class SCH_LEGACY_PLUGIN : public SCH_PLUGIN
							 | 
						|
								{
							 | 
						|
								public:
							 | 
						|
								
							 | 
						|
								    SCH_LEGACY_PLUGIN();
							 | 
						|
								    virtual ~SCH_LEGACY_PLUGIN();
							 | 
						|
								
							 | 
						|
								    const wxString GetName() const override
							 | 
						|
								    {
							 | 
						|
								        return wxT( "Eeschema-Legacy" );
							 | 
						|
								    }
							 | 
						|
								
							 | 
						|
								    const wxString GetFileExtension() const override
							 | 
						|
								    {
							 | 
						|
								        return wxT( "sch" );
							 | 
						|
								    }
							 | 
						|
								
							 | 
						|
								    /**
							 | 
						|
								     * const char* PropBuffering
							 | 
						|
								     *
							 | 
						|
								     * is a property used internally by the plugin to enable cache buffering which prevents
							 | 
						|
								     * the library file from being written every time the cache is changed.  This is useful
							 | 
						|
								     * when writing the schematic cache library file or saving a library to a new file name.
							 | 
						|
								     */
							 | 
						|
								    static const char* PropBuffering;
							 | 
						|
								
							 | 
						|
								    /**
							 | 
						|
								     * const char* PropBuffering
							 | 
						|
								     *
							 | 
						|
								     * is a property used internally by the plugin to disable writing the library
							 | 
						|
								     * documentation (.dcm) file when saving the library cache.
							 | 
						|
								     */
							 | 
						|
								    static const char* PropNoDocFile;
							 | 
						|
								
							 | 
						|
								    int GetModifyHash() const override;
							 | 
						|
								
							 | 
						|
								    SCH_SHEET* Load( const wxString& aFileName, KIWAY* aKiway,
							 | 
						|
								                     SCH_SHEET* aAppendToMe = NULL, const PROPERTIES* aProperties = NULL ) override;
							 | 
						|
								
							 | 
						|
								    void Save( const wxString& aFileName, SCH_SCREEN* aScreen, KIWAY* aKiway,
							 | 
						|
								               const PROPERTIES* aProperties = NULL ) override;
							 | 
						|
								
							 | 
						|
								    void Format( SCH_SCREEN* aScreen );
							 | 
						|
								
							 | 
						|
								    size_t GetSymbolLibCount( const wxString&   aLibraryPath,
							 | 
						|
								                              const PROPERTIES* aProperties = NULL ) override;
							 | 
						|
								    void EnumerateSymbolLib( wxArrayString&    aAliasNameList,
							 | 
						|
								                             const wxString&   aLibraryPath,
							 | 
						|
								                             const PROPERTIES* aProperties = NULL ) override;
							 | 
						|
								    void EnumerateSymbolLib( std::vector<LIB_ALIAS*>& aAliasList,
							 | 
						|
								                             const wxString&   aLibraryPath,
							 | 
						|
								                             const PROPERTIES* aProperties = NULL ) override;
							 | 
						|
								    LIB_ALIAS* LoadSymbol( const wxString& aLibraryPath, const wxString& aAliasName,
							 | 
						|
								                           const PROPERTIES* aProperties = NULL ) override;
							 | 
						|
								    void SaveSymbol( const wxString& aLibraryPath, const LIB_PART* aSymbol,
							 | 
						|
								                     const PROPERTIES* aProperties = NULL ) override;
							 | 
						|
								    void DeleteAlias( const wxString& aLibraryPath, const wxString& aAliasName,
							 | 
						|
								                      const PROPERTIES* aProperties = NULL ) override;
							 | 
						|
								    void DeleteSymbol( const wxString& aLibraryPath, const wxString& aAliasName,
							 | 
						|
								                       const PROPERTIES* aProperties = NULL ) override;
							 | 
						|
								    void CreateSymbolLib( const wxString& aLibraryPath,
							 | 
						|
								                          const PROPERTIES* aProperties = NULL ) override;
							 | 
						|
								    bool DeleteSymbolLib( const wxString& aLibraryPath,
							 | 
						|
								                          const PROPERTIES* aProperties = NULL ) override;
							 | 
						|
								    void SaveLibrary( const wxString& aLibraryPath, const PROPERTIES* aProperties = NULL ) override;
							 | 
						|
								
							 | 
						|
								    bool CheckHeader( const wxString& aFileName ) override;
							 | 
						|
								
							 | 
						|
								private:
							 | 
						|
								    void loadHierarchy( SCH_SHEET* aSheet );
							 | 
						|
								    void loadHeader( FILE_LINE_READER& aReader, SCH_SCREEN* aScreen );
							 | 
						|
								    void loadPageSettings( FILE_LINE_READER& aReader, SCH_SCREEN* aScreen );
							 | 
						|
								    void loadFile( const wxString& aFileName, SCH_SCREEN* aScreen );
							 | 
						|
								    SCH_SHEET* loadSheet( FILE_LINE_READER& aReader );
							 | 
						|
								    SCH_BITMAP* loadBitmap( FILE_LINE_READER& aReader );
							 | 
						|
								    SCH_JUNCTION* loadJunction( FILE_LINE_READER& aReader );
							 | 
						|
								    SCH_NO_CONNECT* loadNoConnect( FILE_LINE_READER& aReader );
							 | 
						|
								    SCH_LINE* loadWire( FILE_LINE_READER& aReader );
							 | 
						|
								    SCH_BUS_ENTRY_BASE* loadBusEntry( FILE_LINE_READER& aReader );
							 | 
						|
								    SCH_TEXT* loadText( FILE_LINE_READER& aReader );
							 | 
						|
								    SCH_COMPONENT* loadComponent( FILE_LINE_READER& aReader );
							 | 
						|
								
							 | 
						|
								    void saveComponent( SCH_COMPONENT* aComponent );
							 | 
						|
								    void saveField( SCH_FIELD* aField );
							 | 
						|
								    void saveBitmap( SCH_BITMAP* aBitmap );
							 | 
						|
								    void saveSheet( SCH_SHEET* aSheet );
							 | 
						|
								    void saveJunction( SCH_JUNCTION* aJunction );
							 | 
						|
								    void saveNoConnect( SCH_NO_CONNECT* aNoConnect );
							 | 
						|
								    void saveBusEntry( SCH_BUS_ENTRY_BASE* aBusEntry );
							 | 
						|
								    void saveLine( SCH_LINE* aLine );
							 | 
						|
								    void saveText( SCH_TEXT* aText );
							 | 
						|
								
							 | 
						|
								    void cacheLib( const wxString& aLibraryFileName );
							 | 
						|
								    bool writeDocFile( const PROPERTIES* aProperties );
							 | 
						|
								    bool isBuffering( const PROPERTIES* aProperties );
							 | 
						|
								
							 | 
						|
								protected:
							 | 
						|
								    int               m_version;    ///< Version of file being loaded.
							 | 
						|
								    wxString          m_error;      ///< For throwing exceptions
							 | 
						|
								    wxString          m_path;       ///< Root project path for loading child sheets.
							 | 
						|
								    const PROPERTIES* m_props;      ///< Passed via Save() or Load(), no ownership, may be NULL.
							 | 
						|
								    KIWAY*            m_kiway;      ///< Required for path to legacy component libraries.
							 | 
						|
								    SCH_SHEET*        m_rootSheet;  ///< The root sheet of the schematic being loaded..
							 | 
						|
								    FILE_OUTPUTFORMATTER* m_out;    ///< The output formatter for saving SCH_SCREEN objects.
							 | 
						|
								    SCH_LEGACY_PLUGIN_CACHE* m_cache;
							 | 
						|
								
							 | 
						|
								    /// initialize PLUGIN like a constructor would.
							 | 
						|
								    void init( KIWAY* aKiway, const PROPERTIES* aProperties = NULL );
							 | 
						|
								};
							 | 
						|
								
							 | 
						|
								#endif  // _SCH_LEGACY_PLUGIN_H_
							 |