2012-12-28 20:52:12 +00:00
|
|
|
/*
|
|
|
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
|
|
|
*
|
2020-12-18 15:40:13 +00:00
|
|
|
* Copyright (C) 2012-2020 Wayne Stambaugh <stambaughw@verizon.net>
|
2023-08-13 02:26:06 +00:00
|
|
|
* Copyright (C) 2012-2023 KiCad Developers, see AUTHORS.txt for contributors.
|
2012-12-28 20:52:12 +00:00
|
|
|
*
|
|
|
|
* 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, you may find one here:
|
|
|
|
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
|
|
|
|
* or you may search the http://www.gnu.org website for the version 2 license,
|
|
|
|
* or you may write to the Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file gpcb_plugin.cpp
|
|
|
|
* @brief Geda PCB file plugin definition file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _GPCB_PLUGIN_H_
|
|
|
|
#define _GPCB_PLUGIN_H_
|
|
|
|
|
|
|
|
#include <io_mgr.h>
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
|
|
|
|
class GPCB_FPL_CACHE;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2020-12-18 15:40:13 +00:00
|
|
|
* A #PLUGIN derivation for saving and loading Geda PCB files.
|
2012-12-28 20:52:12 +00:00
|
|
|
*
|
|
|
|
* @note This class is not thread safe, but it is re-entrant multiple times in sequence.
|
|
|
|
* @note Currently only reading GPCB footprint files is implemented.
|
|
|
|
*/
|
|
|
|
class GPCB_PLUGIN : public PLUGIN
|
|
|
|
{
|
|
|
|
public:
|
2016-09-25 17:06:49 +00:00
|
|
|
const wxString PluginName() const override
|
2012-12-28 20:52:12 +00:00
|
|
|
{
|
2023-08-13 02:26:06 +00:00
|
|
|
return wxT( "gEDA PCB" );
|
2012-12-28 20:52:12 +00:00
|
|
|
}
|
|
|
|
|
2023-08-13 02:26:06 +00:00
|
|
|
PLUGIN_FILE_DESC GetFootprintFileDesc() const override
|
2012-12-28 20:52:12 +00:00
|
|
|
{
|
2023-08-13 02:26:06 +00:00
|
|
|
return PLUGIN_FILE_DESC( _HKI( "gEDA PCB footprint file" ), { "fp" } );
|
2012-12-28 20:52:12 +00:00
|
|
|
}
|
|
|
|
|
2023-08-13 02:26:06 +00:00
|
|
|
PLUGIN_FILE_DESC GetFootprintLibDesc() const override
|
|
|
|
{
|
|
|
|
return PLUGIN_FILE_DESC( _HKI( "gEDA PCB footprint library directory" ), {}, { "fp" },
|
|
|
|
false );
|
|
|
|
}
|
|
|
|
|
|
|
|
FOOTPRINT* ImportFootprint( const wxString& aFootprintPath, wxString& aFootprintNameOut,
|
|
|
|
const STRING_UTF8_MAP* aProperties ) override;
|
|
|
|
|
2017-06-11 20:20:44 +00:00
|
|
|
void FootprintEnumerate( wxArrayString& aFootprintNames, const wxString& aLibraryPath,
|
2021-03-30 09:38:03 +00:00
|
|
|
bool aBestEfforts,
|
2022-11-06 16:51:52 +00:00
|
|
|
const STRING_UTF8_MAP* aProperties = nullptr ) override;
|
2012-12-28 20:52:12 +00:00
|
|
|
|
2020-11-13 15:15:52 +00:00
|
|
|
const FOOTPRINT* GetEnumeratedFootprint( const wxString& aLibraryPath,
|
|
|
|
const wxString& aFootprintName,
|
2022-11-06 16:51:52 +00:00
|
|
|
const STRING_UTF8_MAP* aProperties = nullptr ) override;
|
2018-03-02 23:44:27 +00:00
|
|
|
|
2020-11-13 15:15:52 +00:00
|
|
|
FOOTPRINT* FootprintLoad( const wxString& aLibraryPath, const wxString& aFootprintName,
|
2021-03-30 09:38:03 +00:00
|
|
|
bool aKeepUUID = false,
|
2022-11-06 16:51:52 +00:00
|
|
|
const STRING_UTF8_MAP* aProperties = nullptr ) override;
|
2012-12-28 20:52:12 +00:00
|
|
|
|
2013-12-12 17:42:38 +00:00
|
|
|
void FootprintDelete( const wxString& aLibraryPath, const wxString& aFootprintName,
|
2022-11-06 16:51:52 +00:00
|
|
|
const STRING_UTF8_MAP* aProperties = nullptr ) override;
|
2012-12-28 20:52:12 +00:00
|
|
|
|
2017-06-11 20:20:44 +00:00
|
|
|
bool FootprintLibDelete( const wxString& aLibraryPath,
|
2022-11-06 16:51:52 +00:00
|
|
|
const STRING_UTF8_MAP* aProperties = nullptr ) override;
|
2012-12-28 20:52:12 +00:00
|
|
|
|
2018-03-04 01:13:09 +00:00
|
|
|
long long GetLibraryTimestamp( const wxString& aLibraryPath ) const override;
|
2018-03-02 20:41:37 +00:00
|
|
|
|
2016-09-24 18:53:15 +00:00
|
|
|
bool IsFootprintLibWritable( const wxString& aLibraryPath ) override;
|
2012-12-28 20:52:12 +00:00
|
|
|
|
|
|
|
//-----</PLUGIN API>--------------------------------------------------------
|
|
|
|
|
|
|
|
GPCB_PLUGIN();
|
|
|
|
|
|
|
|
GPCB_PLUGIN( int aControlFlags );
|
|
|
|
|
|
|
|
~GPCB_PLUGIN();
|
|
|
|
|
|
|
|
private:
|
2018-03-02 23:44:27 +00:00
|
|
|
void validateCache( const wxString& aLibraryPath, bool checkModified = true );
|
|
|
|
|
2020-11-13 15:15:52 +00:00
|
|
|
const FOOTPRINT* getFootprint( const wxString& aLibraryPath, const wxString& aFootprintName,
|
2022-11-06 16:51:52 +00:00
|
|
|
const STRING_UTF8_MAP* aProperties, bool checkModified );
|
2012-12-28 20:52:12 +00:00
|
|
|
|
2022-11-06 16:51:52 +00:00
|
|
|
void init( const STRING_UTF8_MAP* aProperties );
|
2020-12-18 15:40:13 +00:00
|
|
|
|
|
|
|
friend class GPCB_FPL_CACHE;
|
|
|
|
|
|
|
|
protected:
|
2022-11-06 16:51:52 +00:00
|
|
|
wxString m_error; ///< for throwing exceptions
|
|
|
|
const STRING_UTF8_MAP* m_props; ///< passed via Save() or Load(), no ownership, may be NULL.
|
|
|
|
GPCB_FPL_CACHE* m_cache; ///< Footprint library cache.
|
|
|
|
int m_ctl;
|
|
|
|
LINE_READER* m_reader; ///< no ownership here.
|
|
|
|
wxString m_filename; ///< for saves only, name is in m_reader for loads
|
2012-12-28 20:52:12 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // _GPCB_PLUGIN_H_
|