7
mirror of https://gitlab.com/kicad/code/kicad.git synced 2024-11-25 09:54:59 +00:00
kicad/pcbnew/pcb_io/odbpp/pcb_io_odbpp.cpp
2024-11-20 19:03:15 -05:00

176 lines
4.5 KiB
C++

/*
* This program source code file is part of KiCad, a free EDA CAD application.
*
* Copyright (C) 2024 KiCad Developers, see AUTHORS.txt for contributors.
* Author: SYSUEric <jzzhuang666@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 3 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 "pcb_io_odbpp.h"
#include "progress_reporter.h"
#include "odb_util.h"
#include "odb_attribute.h"
#include "odb_defines.h"
#include "odb_feature.h"
#include "odb_entity.h"
#include "wx/log.h"
double PCB_IO_ODBPP::m_scale = 1.0 / PCB_IU_PER_MM;
double PCB_IO_ODBPP::m_symbolScale = 1.0 / PL_IU_PER_MM;
int PCB_IO_ODBPP::m_sigfig = 4;
std::string PCB_IO_ODBPP::m_unitsStr = "MM";
PCB_IO_ODBPP::~PCB_IO_ODBPP()
{
ClearLoadedFootprints();
}
void PCB_IO_ODBPP::ClearLoadedFootprints()
{
m_loaded_footprints.clear();
}
void PCB_IO_ODBPP::CreateEntity()
{
Make<ODB_FONTS_ENTITY>();
Make<ODB_INPUT_ENTITY>();
Make<ODB_MATRIX_ENTITY>( m_board, this );
Make<ODB_STEP_ENTITY>( m_board, this );
Make<ODB_MISC_ENTITY>();
Make<ODB_SYMBOLS_ENTITY>();
Make<ODB_USER_ENTITY>();
Make<ODB_WHEELS_ENTITY>();
}
bool PCB_IO_ODBPP::GenerateFiles( ODB_TREE_WRITER& writer )
{
for( const auto entity : m_entities )
{
if( !entity->CreateDirectoryTree( writer ) )
{
throw std::runtime_error( "Failed in create directory tree process" );
return false;
}
try
{
entity->GenerateFiles( writer );
}
catch( const std::exception& e )
{
throw std::runtime_error( "Failed in generate files process.\n"
+ std::string( e.what() ) );
return false;
}
}
return true;
}
bool PCB_IO_ODBPP::ExportODB( const wxString& aFileName )
{
try
{
std::shared_ptr<ODB_TREE_WRITER> writer =
std::make_shared<ODB_TREE_WRITER>( aFileName, "odb" );
writer->SetRootPath( writer->GetCurrentPath() );
if( m_progressReporter )
{
m_progressReporter->SetNumPhases( 3 );
m_progressReporter->BeginPhase( 0 );
m_progressReporter->Report( _( "Creating ODB++ Structure" ) );
}
CreateEntity();
if( m_progressReporter )
{
m_progressReporter->SetCurrentProgress( 1.0 );
}
for( auto const& entity : m_entities )
{
entity->InitEntityData();
}
if( m_progressReporter )
{
m_progressReporter->SetCurrentProgress( 1.0 );
m_progressReporter->AdvancePhase( _( "Exporting board to ODB++" ) );
}
if( !GenerateFiles( *writer ) )
return false;
return true;
}
catch( const std::exception& e )
{
wxLogError( "Exception in ODB++ ExportODB process: %s", e.what() );
std::cerr << e.what() << std::endl;
return false;
}
}
std::vector<FOOTPRINT*> PCB_IO_ODBPP::GetImportedCachedLibraryFootprints()
{
std::vector<FOOTPRINT*> retval;
retval.reserve( m_loaded_footprints.size() );
for( const auto& fp : m_loaded_footprints )
{
retval.push_back( static_cast<FOOTPRINT*>( fp->Clone() ) );
}
return retval;
}
void PCB_IO_ODBPP::SaveBoard( const wxString& aFileName, BOARD* aBoard,
const std::map<std::string, UTF8>* aProperties )
{
m_board = aBoard;
if( auto it = aProperties->find( "units" ); it != aProperties->end() )
{
if( it->second == "inch" )
{
m_unitsStr = "INCH";
m_scale = 25.4 / PCB_IU_PER_MM;
m_symbolScale = 25.4 / PL_IU_PER_MM;
}
else
{
m_unitsStr = "MM";
m_scale = 1.0 / PCB_IU_PER_MM;
m_symbolScale = 1.0 / PL_IU_PER_MM;
}
}
if( auto it = aProperties->find( "sigfig" ); it != aProperties->end() )
m_sigfig = std::stoi( it->second );
ExportODB( aFileName );
}