21#include <magic_enum.hpp>
23#include <api/schematic/schematic_types.pb.h>
29const wxChar*
const traceApi = wxT(
"KICAD_API" );
37 if( aMessage.type_url() ==
"type.googleapis.com/kiapi.schematic.types.BusEntry" )
39 kiapi::schematic::types::BusEntry entry;
41 if( !aMessage.UnpackTo( &entry ) )
44 switch( entry.type() )
46 case kiapi::schematic::types::BET_WIRE_TO_BUS:
49 case kiapi::schematic::types::BET_BUS_TO_BUS:
57 static const std::map<std::string, KICAD_T> s_types = {
58 {
"type.googleapis.com/kiapi.board.types.Track",
PCB_TRACE_T },
59 {
"type.googleapis.com/kiapi.board.types.Arc",
PCB_ARC_T },
60 {
"type.googleapis.com/kiapi.board.types.Via",
PCB_VIA_T },
61 {
"type.googleapis.com/kiapi.board.types.BoardText",
PCB_TEXT_T },
62 {
"type.googleapis.com/kiapi.board.types.BoardTextBox",
PCB_TEXTBOX_T },
63 {
"type.googleapis.com/kiapi.board.types.BoardGraphicShape",
PCB_SHAPE_T },
64 {
"type.googleapis.com/kiapi.board.types.Barcode",
PCB_BARCODE_T },
65 {
"type.googleapis.com/kiapi.board.types.Pad",
PCB_PAD_T },
66 {
"type.googleapis.com/kiapi.board.types.Zone",
PCB_ZONE_T },
69 {
"type.googleapis.com/kiapi.board.types.Group",
PCB_GROUP_T },
70 {
"type.googleapis.com/kiapi.board.types.Field",
PCB_FIELD_T },
71 {
"type.googleapis.com/kiapi.board.types.FootprintInstance",
PCB_FOOTPRINT_T },
72 {
"type.googleapis.com/kiapi.schematic.types.Junction",
SCH_JUNCTION_T },
73 {
"type.googleapis.com/kiapi.schematic.types.NoConnectMarker",
SCH_NO_CONNECT_T },
75 {
"type.googleapis.com/kiapi.schematic.types.SchematicLine",
SCH_LINE_T },
76 {
"type.googleapis.com/kiapi.schematic.types.SchematicGraphicShape",
SCH_SHAPE_T },
77 {
"type.googleapis.com/kiapi.schematic.types.SchematicImage",
SCH_BITMAP_T },
78 {
"type.googleapis.com/kiapi.schematic.types.SchematicTextBox",
SCH_TEXTBOX_T },
79 {
"type.googleapis.com/kiapi.schematic.types.SchematicText",
SCH_TEXT_T },
80 {
"type.googleapis.com/kiapi.schematic.types.Table",
SCH_TABLE_T },
81 {
"type.googleapis.com/kiapi.schematic.types.LocalLabel",
SCH_LABEL_T },
83 {
"type.googleapis.com/kiapi.schematic.types.HierarchicalLabel",
SCH_HIER_LABEL_T },
85 {
"type.googleapis.com/kiapi.schematic.types.Group",
SCH_GROUP_T },
86 {
"type.googleapis.com/kiapi.schematic.types.SheetSymbol",
SCH_SHEET_T },
87 {
"type.googleapis.com/kiapi.schematic.types.SchematicSymbolInstance",
SCH_SYMBOL_T },
88 {
"type.googleapis.com/kiapi.schematic.types.SchematicPin",
SCH_PIN_T },
91 auto it = s_types.find( aMessage.type_url() );
93 if( it != s_types.end() )
96 wxLogTrace(
traceApi, wxString::Format( wxS(
"Any message type %s is not known" ),
97 aMessage.type_url() ) );
105 return LIB_ID( aId.library_nickname(), aId.entry_name() );
118 aOutput.set_x_nm( aScale.
IUToNm( aInput.
x ) );
119 aOutput.set_y_nm( aScale.
IUToNm( aInput.
y ) );
131 aOutput.set_x_nm( aInput.
x );
132 aOutput.set_y_nm( aInput.
y );
133 aOutput.set_z_nm( aInput.
z );
139 return VECTOR3D( aInput.x_nm(), aInput.y_nm(), aInput.z_nm() );
158 aOutput.set_value_nm( aScale.
IUToNm( aInput ) );
164 return aScale.
NmToIU( aInput.value_nm() );
177 types::PolyLineNode* node = aOutput.mutable_nodes()->Add();
185 types::PolyLineNode* node = aOutput.mutable_nodes()->Add();
190 aOutput.set_closed( aSlc.
IsClosed() );
198 for(
const types::PolyLineNode& node : aInput.nodes() )
200 if( node.has_point() )
204 else if( node.has_arc() )
228 types::PolygonWithHoles* polyMsg = aOutput.mutable_polygons()->Add();
229 PackPolyLine( *polyMsg->mutable_outline(), poly.front(), aScale );
231 if( poly.size() > 1 )
233 for(
size_t hole = 1; hole < poly.size(); ++hole )
235 types::PolyLine* pl = polyMsg->mutable_holes()->Add();
247 for(
const types::PolygonWithHoles& polygonWithHoles : aInput.polygons() )
251 polygon.emplace_back(
UnpackPolyLine( polygonWithHoles.outline(), aScale ) );
253 for(
const types::PolyLine& holeMsg : polygonWithHoles.holes() )
265 aOutput.set_r( aInput.
r );
266 aOutput.set_g( aInput.
g );
267 aOutput.set_b( aInput.
b );
268 aOutput.set_a( aInput.
a );
274 double r = std::clamp( aInput.r(), 0.0, 1.0 );
275 double g = std::clamp( aInput.g(), 0.0, 1.0 );
276 double b = std::clamp( aInput.b(), 0.0, 1.0 );
277 double a = std::clamp( aInput.a(), 0.0, 1.0 );
284 aOutput.clear_path();
286 for(
const KIID& entry : aInput )
287 aOutput.add_path()->set_value( entry.AsStdString() );
294 for(
const types::KIID& sheet : aInput.path() )
constexpr const Vec & GetOrigin() const
constexpr const SizeVec & GetSize() const
A color representation with 4 components: red, green, blue, alpha.
A logical library item identifier and consists of various portions much like a URI.
const UTF8 & GetLibItemName() const
const UTF8 & GetLibNickname() const
Return the logical library name portion of a LIB_ID.
Container for project specific data.
virtual const wxString GetProjectPath() const
Return the full path of the project.
virtual const wxString GetProjectName() const
Return the short name of the project.
const VECTOR2I & GetArcMid() const
const VECTOR2I & GetP1() const
const VECTOR2I & GetP0() const
Represent a polyline containing arcs as well as line segments: A chain of connected line and/or arc s...
bool IsPtOnArc(size_t aPtIndex) const
const SHAPE_ARC & Arc(size_t aArc) const
bool IsClosed() const override
void SetClosed(bool aClosed)
Mark the line chain as closed (i.e.
int PointCount() const
Return the number of points (vertices) in this line chain.
ssize_t ArcIndex(size_t aSegment) const
Return the arc index for the given segment index.
int NextShape(int aPointIndex) const
Return the vertex index of the next shape in the chain, or -1 if aPointIndex is the last shape.
void Append(int aX, int aY, bool aAllowDuplication=false)
Append a new point at the end of the line chain.
const VECTOR2I & CPoint(int aIndex) const
Return a reference to a given point in the line chain.
bool IsArcStart(size_t aIndex) const
Represent a set of closed polygons.
POLYGON & Polygon(int aIndex)
Return the aIndex-th subpolygon in the set.
int AddPolygon(const POLYGON &apolygon)
Adds a polygon to the set.
std::vector< SHAPE_LINE_CHAIN > POLYGON
represents a single polygon outline with holes.
int OutlineCount() const
Return the number of outlines in the set.
const wxChar *const traceApi
Flag to enable debug output related to the IPC API and its plugin system.
KICOMMON_API void PackProject(types::ProjectSpecifier &aOutput, const PROJECT &aInput)
KICOMMON_API void PackColor(types::Color &aOutput, const KIGFX::COLOR4D &aInput)
KICOMMON_API int UnpackDistance(const types::Distance &aInput, const EDA_IU_SCALE &aScale)
KICOMMON_API KIID_PATH UnpackSheetPath(const types::SheetPath &aInput)
KICOMMON_API std::optional< KICAD_T > TypeNameFromAny(const google::protobuf::Any &aMessage)
KICOMMON_API void PackPolySet(types::PolySet &aOutput, const SHAPE_POLY_SET &aInput, const EDA_IU_SCALE &aScale)
KICOMMON_API VECTOR3D UnpackVector3D(const types::Vector3D &aInput)
KICOMMON_API KIGFX::COLOR4D UnpackColor(const types::Color &aInput)
KICOMMON_API VECTOR2I UnpackVector2(const types::Vector2 &aInput, const EDA_IU_SCALE &aScale)
KICOMMON_API void PackBox2(types::Box2 &aOutput, const BOX2I &aInput, const EDA_IU_SCALE &aScale)
KICOMMON_API void PackDistance(types::Distance &aOutput, int aInput, const EDA_IU_SCALE &aScale)
KICOMMON_API BOX2I UnpackBox2(const types::Box2 &aInput, const EDA_IU_SCALE &aScale)
KICOMMON_API void PackVector2(types::Vector2 &aOutput, const VECTOR2I &aInput, const EDA_IU_SCALE &aScale)
KICOMMON_API SHAPE_LINE_CHAIN UnpackPolyLine(const types::PolyLine &aInput, const EDA_IU_SCALE &aScale)
KICOMMON_API void PackSheetPath(types::SheetPath &aOutput, const KIID_PATH &aInput)
KICOMMON_API void PackLibId(types::LibraryIdentifier *aOutput, const LIB_ID &aId)
KICOMMON_API LIB_ID UnpackLibId(const types::LibraryIdentifier &aId)
KICOMMON_API void PackPolyLine(types::PolyLine &aOutput, const SHAPE_LINE_CHAIN &aSlc, const EDA_IU_SCALE &aScale)
KICOMMON_API SHAPE_POLY_SET UnpackPolySet(const types::PolySet &aInput, const EDA_IU_SCALE &aScale)
KICOMMON_API void PackVector3D(types::Vector3D &aOutput, const VECTOR3D &aInput)
constexpr int NmToIU(int64_t nm) const
constexpr int64_t IUToNm(int iu) const
@ PCB_SHAPE_T
class PCB_SHAPE, a segment not on copper layers
@ PCB_VIA_T
class PCB_VIA, a via (like a track segment on a copper layer)
@ PCB_GROUP_T
class PCB_GROUP, a set of BOARD_ITEMs
@ PCB_TEXTBOX_T
class PCB_TEXTBOX, wrapped text on a layer
@ PCB_ZONE_T
class ZONE, a copper pour area
@ PCB_TEXT_T
class PCB_TEXT, text on a layer
@ PCB_REFERENCE_IMAGE_T
class PCB_REFERENCE_IMAGE, bitmap on a layer
@ PCB_FIELD_T
class PCB_FIELD, text associated with a footprint property
@ PCB_BARCODE_T
class PCB_BARCODE, a barcode (graphic item)
@ PCB_FOOTPRINT_T
class FOOTPRINT, a footprint
@ PCB_PAD_T
class PAD, a pad in a footprint
@ PCB_ARC_T
class PCB_ARC, an arc track segment on a copper layer
@ PCB_DIMENSION_T
class PCB_DIMENSION_BASE: abstract dimension meta-type
@ PCB_TRACE_T
class PCB_TRACK, a track segment (segment on a copper layer)
VECTOR2< int32_t > VECTOR2I
VECTOR3< double > VECTOR3D