KiCad PCB EDA Suite
Loading...
Searching...
No Matches
command_sch_export_plot.cpp
Go to the documentation of this file.
1/*
2 * This program source code file is part of KiCad, a free EDA CAD application.
3 *
4 * Copyright (C) 2022 Mark Roszko <[email protected]>
5 * Copyright (C) 1992-2023 KiCad Developers, see AUTHORS.txt for contributors.
6 *
7 * This program is free software: you can redistribute it and/or modify it
8 * under the terms of the GNU General Public License as published by the
9 * Free Software Foundation, either version 3 of the License, or (at your
10 * option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License along
18 * with this program. If not, see <http://www.gnu.org/licenses/>.
19 */
20
21#include <kiface_base.h>
22#include <sch_plotter.h>
24#include <cli/exit_codes.h>
26#include <layer_ids.h>
27#include <wx/crt.h>
28#include <string_utils.h>
29
30#include <macros.h>
31#include <wx/tokenzr.h>
32
33#define ARG_EXCLUDE_DRAWING_SHEET "--exclude-drawing-sheet"
34#define ARG_NO_BACKGROUND_COLOR "--no-background-color"
35#define ARG_HPGL_PEN_SIZE "--pen-size"
36#define ARG_HPGL_ORIGIN "--origin"
37#define ARG_PAGES "--pages"
38#define ARG_EXCLUDE_PDF_PROPERTY_POPUPS "--exclude-pdf-property-popups"
39#define ARG_EXCLUDE_PDF_METADATA "--exclude-pdf-metadata"
40
46};
47
49 const std::string& aDescription,
50 SCH_PLOT_FORMAT aPlotFormat,
51 bool aOutputIsDir ) :
52 COMMAND( aName ),
53 m_plotFormat( aPlotFormat )
54{
55 m_argParser.add_description( aDescription );
56
57 addCommonArgs( true, true, false, aOutputIsDir );
60
61 if( aPlotFormat != SCH_PLOT_FORMAT::HPGL )
62 {
63 m_argParser.add_argument( "-t", ARG_THEME )
64 .default_value( std::string() )
65 .help( UTF8STDSTR( _( "Color theme to use (will default to schematic "
66 "settings)" ) ) )
67 .metavar( "THEME_NAME" );
68 m_argParser.add_argument( "-b", ARG_BLACKANDWHITE )
70 .flag();
71 }
72
73 m_argParser.add_argument( "-e", ARG_EXCLUDE_DRAWING_SHEET )
74 .help( UTF8STDSTR( _( "No drawing sheet" ) ) )
75 .implicit_value( true )
76 .default_value( false );
77
78 if( aPlotFormat == SCH_PLOT_FORMAT::PDF )
79 {
81 .help( UTF8STDSTR( _( "Do not generate property popups in PDF" ) ) )
82 .flag();
83
85 .help( UTF8STDSTR( _( "Do not generate PDF metadata from AUTHOR and SUBJECT variables" ) ) )
86 .flag();
87 }
88
89 if( aPlotFormat == SCH_PLOT_FORMAT::PDF
90 || aPlotFormat == SCH_PLOT_FORMAT::POST
91 || aPlotFormat == SCH_PLOT_FORMAT::SVG )
92 {
93 m_argParser.add_argument( "-n", ARG_NO_BACKGROUND_COLOR )
94 .help( UTF8STDSTR( _( "Avoid setting a background color (regardless of theme)" ) ) )
95 .flag();
96 }
97
98 m_argParser.add_argument( "-p", ARG_PAGES )
99 .default_value( std::string() )
100 .help( UTF8STDSTR( _( "List of page numbers separated by comma to print, blank or "
101 "unspecified is equivalent to all pages" ) ) )
102 .metavar( "PAGE_LIST" );
103
104 if( aPlotFormat == SCH_PLOT_FORMAT::HPGL )
105 {
106 m_argParser.add_argument( "-p", ARG_HPGL_PEN_SIZE )
107 .help( UTF8STDSTR( _( "Pen size [mm]" ) ) )
108 .scan<'g', double>()
109 .default_value( 0.5 )
110 .metavar( "PEN_SIZE" );
111
112 m_argParser.add_argument( "-r", ARG_HPGL_ORIGIN )
113 .help( UTF8STDSTR( _( "Origin and scale: 0 bottom left, 1 centered, 2 page fit, 3 "
114 "content fit" ) ) )
115 .scan<'d', int>()
116 .default_value( 1 )
117 .metavar( "ORIGIN" );
118 }
119}
120
121
123{
124 wxString filename = m_argInput;
125 if( !wxFile::Exists( filename ) )
126 {
127 wxFprintf( stderr, _( "Schematic file does not exist or is not accessible\n" ) );
129 }
130
131 std::vector<wxString> pages;
132 wxString pagesStr = From_UTF8( m_argParser.get<std::string>( ARG_PAGES ).c_str() );
133 wxStringTokenizer tokenizer( pagesStr, "," );
134 while( tokenizer.HasMoreTokens() )
135 {
136 pages.push_back( tokenizer.GetNextToken().Trim() );
137 }
138
139 std::unique_ptr<JOB_EXPORT_SCH_PLOT> plotJob =
140 std::make_unique<JOB_EXPORT_SCH_PLOT>( true, m_plotFormat, filename );
141
142 plotJob->m_plotPages = pages;
143 plotJob->m_plotDrawingSheet = !m_argParser.get<bool>( ARG_EXCLUDE_DRAWING_SHEET );
144 plotJob->m_pageSizeSelect = JOB_PAGE_SIZE::PAGE_SIZE_AUTO;
145
146 if( m_plotFormat == SCH_PLOT_FORMAT::PDF
147 || m_plotFormat == SCH_PLOT_FORMAT::POST
148 || m_plotFormat == SCH_PLOT_FORMAT::SVG )
149 {
150 plotJob->m_useBackgroundColor = !m_argParser.get<bool>( ARG_NO_BACKGROUND_COLOR );
151 }
152
153 if ( m_plotFormat != SCH_PLOT_FORMAT::HPGL )
154 {
155 plotJob->m_blackAndWhite = m_argParser.get<bool>( ARG_BLACKANDWHITE );
156 plotJob->m_theme = From_UTF8( m_argParser.get<std::string>( ARG_THEME ).c_str() );
157 }
158
159 if( m_outputArgExpectsDir )
160 plotJob->m_outputDirectory = m_argOutput;
161 else
162 plotJob->m_outputFile = m_argOutput;
163
164 plotJob->m_plotAll = plotJob->m_plotPages.size() == 0;
165
166 plotJob->m_drawingSheet = m_argDrawingSheet;
167 plotJob->SetVarOverrides( m_argDefineVars );
168
169 // HPGL local options
170 if( m_plotFormat == SCH_PLOT_FORMAT::HPGL )
171 {
172 plotJob->m_HPGLPenSize =
173 m_argParser.get<double>( ARG_HPGL_PEN_SIZE ) * schIUScale.IU_PER_MM;
174 int origin = m_argParser.get<int>( ARG_HPGL_ORIGIN );
175 if( origin < 0 || origin > 3 )
176 {
177 wxFprintf( stderr, _( "HPGL origin option must be 0, 1, 2 or 3\n" ) );
179 }
180 plotJob->m_HPGLPlotOrigin = hpgl_origin_ops[origin];
181 }
182 // PDF local options
183 else if( m_plotFormat == SCH_PLOT_FORMAT::PDF )
184 {
185 plotJob->m_PDFPropertyPopups = !m_argParser.get<bool>( ARG_EXCLUDE_PDF_PROPERTY_POPUPS );
186 plotJob->m_PDFMetadata = !m_argParser.get<bool>( ARG_EXCLUDE_PDF_METADATA );
187 }
188
189 int exitCode = aKiway.ProcessJob( KIWAY::FACE_SCH, plotJob.get() );
190
191 return exitCode;
192}
constexpr EDA_IU_SCALE schIUScale
Definition: base_units.h:110
argparse::ArgumentParser m_argParser
Definition: command.h:100
void addDefineArg()
Set up the drawing sheet arg used by many of the export commands.
Definition: command.cpp:169
void addCommonArgs(bool aInput, bool aOutput, bool aInputIsDir, bool aOutputIsDir)
Set up the most common of args used across cli.
Definition: command.cpp:115
void addDrawingSheetArg()
Set up the drawing sheet arg used by many of the export commands.
Definition: command.cpp:157
int doPerform(KIWAY &aKiway) override
The internal handler that should be overloaded to implement command specific processing and work.
SCH_EXPORT_PLOT_COMMAND(const std::string &aName, const std::string &aDescription, SCH_PLOT_FORMAT aPlotFormat, bool aOutputIsDir=true)
A minimalistic software bus for communications between various DLLs/DSOs (DSOs) within the same KiCad...
Definition: kiway.h:279
int ProcessJob(KIWAY::FACE_T aFace, JOB *job)
Definition: kiway.cpp:709
@ FACE_SCH
eeschema DSO
Definition: kiway.h:286
#define UTF8STDSTR(s)
Definition: command.h:27
#define ARG_THEME
#define ARG_BLACKANDWHITE_DESC
#define ARG_BLACKANDWHITE
#define ARG_EXCLUDE_DRAWING_SHEET
#define ARG_EXCLUDE_PDF_PROPERTY_POPUPS
#define ARG_NO_BACKGROUND_COLOR
#define ARG_HPGL_PEN_SIZE
const JOB_HPGL_PLOT_ORIGIN_AND_UNITS hpgl_origin_ops[4]
#define ARG_PAGES
#define ARG_HPGL_ORIGIN
#define ARG_EXCLUDE_PDF_METADATA
#define _(s)
SCH_PLOT_FORMAT
JOB_HPGL_PLOT_ORIGIN_AND_UNITS
This file contains miscellaneous commonly used macros and functions.
static const int ERR_ARGS
Definition: exit_codes.h:31
static const int ERR_INVALID_INPUT_FILE
Definition: exit_codes.h:33
wxString From_UTF8(const char *cstring)
const double IU_PER_MM
Definition: base_units.h:76