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
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2023-12-24 01:21:58 +00:00
|
|
|
* @file pcb_io_geda.cpp
|
2012-12-28 20:52:12 +00:00
|
|
|
* @brief Geda PCB file plugin definition file.
|
|
|
|
*/
|
|
|
|
|
2023-12-24 01:21:58 +00:00
|
|
|
#ifndef PCB_IO_GEDA_H_
|
|
|
|
#define PCB_IO_GEDA_H_
|
2012-12-28 20:52:12 +00:00
|
|
|
|
|
|
|
#include <string>
|
|
|
|
|
2023-12-19 17:39:26 +00:00
|
|
|
#include <pcb_io/pcb_io.h>
|
|
|
|
#include <pcb_io/pcb_io_mgr.h>
|
2012-12-28 20:52:12 +00:00
|
|
|
|
|
|
|
class GPCB_FPL_CACHE;
|
2023-12-27 22:08:31 +00:00
|
|
|
class LINE_READER;
|
2012-12-28 20:52:12 +00:00
|
|
|
|
|
|
|
/**
|
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.
|
|
|
|
*/
|
2023-12-24 01:21:58 +00:00
|
|
|
class PCB_IO_GEDA : public PCB_IO
|
2012-12-28 20:52:12 +00:00
|
|
|
{
|
|
|
|
public:
|
2023-12-27 16:34:59 +00:00
|
|
|
const IO_BASE::IO_FILE_DESC GetLibraryFileDesc() const override
|
2012-12-28 20:52:12 +00:00
|
|
|
{
|
2023-12-27 16:34:59 +00:00
|
|
|
return IO_BASE::IO_FILE_DESC( _HKI( "gEDA PCB footprint file" ), { "fp" } );
|
2012-12-28 20:52:12 +00:00
|
|
|
}
|
|
|
|
|
2023-12-27 16:34:59 +00:00
|
|
|
const IO_BASE::IO_FILE_DESC GetLibraryDesc() const override
|
2023-08-13 02:26:06 +00:00
|
|
|
{
|
2023-12-27 16:34:59 +00:00
|
|
|
return IO_BASE::IO_FILE_DESC( _HKI( "gEDA PCB footprint library directory" ), {}, { "fp" },
|
|
|
|
false );
|
2023-08-13 02:26:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
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
|
|
|
|
2023-12-27 00:25:41 +00:00
|
|
|
bool DeleteLibrary( const wxString& aLibraryPath,
|
|
|
|
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
|
|
|
|
2023-12-27 00:25:41 +00:00
|
|
|
bool IsLibraryWritable( const wxString& aLibraryPath ) override;
|
2012-12-28 20:52:12 +00:00
|
|
|
|
|
|
|
//-----</PLUGIN API>--------------------------------------------------------
|
|
|
|
|
2023-12-24 01:21:58 +00:00
|
|
|
PCB_IO_GEDA();
|
2012-12-28 20:52:12 +00:00
|
|
|
|
2023-12-24 01:21:58 +00:00
|
|
|
PCB_IO_GEDA( int aControlFlags );
|
2012-12-28 20:52:12 +00:00
|
|
|
|
2023-12-24 01:21:58 +00:00
|
|
|
~PCB_IO_GEDA();
|
2012-12-28 20:52:12 +00:00
|
|
|
|
|
|
|
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
|
|
|
|
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
|
|
|
};
|
|
|
|
|
2023-12-24 01:21:58 +00:00
|
|
|
#endif // PCB_IO_GEDA_H_
|