/* * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2020 Brian Piccioni brian@documenteddesigns.com * Copyright (C) 1992-2021 KiCad Developers, see AUTHORS.txt for contributors. * @author Brian Piccioni * * 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 */ #ifndef DIALOG_BOARD_REANNOTATE_H_ #define DIALOG_BOARD_REANNOTATE_H_ #include #include #include #include #include #include #include #include #include #include #include #include #include #define SORTXFIRST 0b000 // Sort on X #define SORTYFIRST 0b100 // Sort on Y #define ASCENDINGFIRST 0b000 // Sort low to high #define DESCENDINGFIRST 0b010 // Sort high to low #define ASCENDINGSECOND 0b000 // Sort low to high #define DESCENDINGSECOND 0b001 // Sort high to low #define MINGRID 1000 #define MAXERROR 10 #define VALIDPREFIX "_-+=/\\" // Prefixs can be alpha or these symbols enum ActionCode { UpdateRefDes, EmptyRefDes, InvalidRefDes, Exclude }; enum AnnotationChoice { AnnotateAll, AnnotateFront, AnnotateBack, AnnotateSelected }; struct RefDesChange { KIID Uuid; wxString NewRefDes; // The new reference designation (F_U21) wxString OldRefDesString; // What the old refdes preamble + number was bool Front; // True if on the front of the board ActionCode Action; // Used to skip (if #, etc) }; struct RefDesInfo { KIID Uuid; bool Front; // True if on the front of the board wxString RefDesString; // What its refdes is R1, C2 wxString RefDesType; // ie R, C, etc int x, y; // The coordinates int roundedx, roundedy; // The coordinates after rounding. ActionCode Action; // Used to skip (if #, etc) LIB_ID FPID; }; struct RefDesTypeStr { wxString RefDesType; unsigned int RefDesCount; }; class DIALOG_BOARD_REANNOTATE : public DIALOG_BOARD_REANNOTATE_BASE { public: DIALOG_BOARD_REANNOTATE( PCB_EDIT_FRAME* aParentFrame ); ~DIALOG_BOARD_REANNOTATE(); private: std::vector m_sortButtons = { m_Down_Right, m_Right_Down, m_Down_Left, m_Left_Down, m_Up_Right, m_Right_Up, m_Up_Left, m_Left_Up }; std::vector AnnotateWhat = { m_AnnotateAll, m_AnnotateFront, m_AnnotateBack, m_AnnotateSelection }; std::vector Bitmaps = { reannotate_down_right_bitmap, reannotate_right_down_bitmap, reannotate_down_left_bitmap, reannotate_left_down_bitmap, reannotate_up_right_bitmap, reannotate_right_up_bitmap, reannotate_up_left_bitmap, reannotate_left_up_bitmap }; void GetParameters( void ); /// Copy saved app settings to the dialog. void InitValues( void ); void OnApplyClick( wxCommandEvent& event ) override; void OnCloseClick( wxCommandEvent& event ) override; void FilterFrontPrefix( wxCommandEvent& event ) override; void FilterBackPrefix( wxCommandEvent& event ) override; /// Break report into strings separated by \n and sent to the reporter. void ShowReport( wxString aMessage, SEVERITY aSeverity ); /// Create a list of the footprints and their coordinates. void LogFootprints( const wxString& aMessage, const std::vector& aFootprints ); /// Create an audit trail of the changes. void LogChangePlan( void ); /// Actually reannotate the board. /// @return false if fail, true if success. bool ReannotateBoard( void ); /// Build the footprint lists, sort it, filter for excludes, then build the change list. /// @return true if success, false if errors bool BuildFootprintList( std::vector& aBadRefDes ); /// Scan through the footprint arrays and create the from -> to array. void BuildChangeArray( std::vector& aFootprints, unsigned int aStartRefDes, wxString aPrefix, bool aRemovePrefix, std::vector& aBadRefDes ); /// @return the new reference for this footprint. RefDesChange* GetNewRefDes( FOOTPRINT* aFootprint ); /// Round an int coordinate to a suitable grid int RoundToGrid( int aCoord, int aGrid ); /// Convert coordinates to wxString. /// @return the string wxString CoordTowxString( int aX, int aY ); /// Make the text to summarize what is about to happen. void MakeSampleText( wxString& aMessage ); /// Check to make sure the prefix (if there is one) is properly constructed. void FilterPrefix( wxTextCtrl* aPrefix ); PCB_EDIT_FRAME* m_frame; FOOTPRINTS m_footprints; PCB_SCREEN* m_screen; PCB_SELECTION m_selection; std::vector m_changeArray; std::vector m_frontFootprints; std::vector m_backFootprints; std::vector m_refDesTypes; std::vector m_excludeArray; int m_sortCode; int m_gridIndex; int m_annotationChoice; int m_severity; double m_sortGridx; double m_sortGridy; wxString m_frontPrefixString; wxString m_backPrefixString; wxString m_validPrefixes; APP_SETTINGS_BASE* m_settings; APP_SETTINGS_BASE* m_Config; }; #endif /* DIALOG_BOARD_REANNOTATECLASSES_H_ */