You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							134 lines
						
					
					
						
							3.9 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							134 lines
						
					
					
						
							3.9 KiB
						
					
					
				
								/*
							 | 
						|
								 * This program source code file is part of KiCad, a free EDA CAD application.
							 | 
						|
								 *
							 | 
						|
								 * Copyright (C) 2017 KiCad Developers, see AUTHORS.txt for contributors.
							 | 
						|
								 *
							 | 
						|
								 * 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/>.
							 | 
						|
								 */
							 | 
						|
								
							 | 
						|
								#ifndef GERBER_COLLECTORS_H
							 | 
						|
								#define GERBER_COLLECTORS_H
							 | 
						|
								
							 | 
						|
								#include <collector.h>
							 | 
						|
								
							 | 
						|
								/**
							 | 
						|
								 * Class GERBER_COLLECTOR
							 | 
						|
								 * is intended for use when the right click button is pressed, or when the
							 | 
						|
								 * plain "arrow" tool is in effect.
							 | 
						|
								 */
							 | 
						|
								class GERBER_COLLECTOR : public COLLECTOR
							 | 
						|
								{
							 | 
						|
								protected:
							 | 
						|
								    /**
							 | 
						|
								     * A place to hold collected objects which don't match precisely the search
							 | 
						|
								     * criteria, but would be acceptable if nothing else is found.
							 | 
						|
								     * "2nd" choice, which will be appended to the end of COLLECTOR's prime
							 | 
						|
								     * "list" at the end of the search.
							 | 
						|
								     */
							 | 
						|
								    std::vector<EDA_ITEM*> m_List2nd;
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								    /**
							 | 
						|
								     * Determines which items are to be collected by Inspect()
							 | 
						|
								     */
							 | 
						|
								    //const COLLECTORS_GUIDE* m_Guide;
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								    /**
							 | 
						|
								     * The number of items that were originally in the primary list before the
							 | 
						|
								     * m_List2nd was concatenated onto the end of it.
							 | 
						|
								     */
							 | 
						|
								    int m_PrimaryLength;
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								public:
							 | 
						|
								
							 | 
						|
								    /**
							 | 
						|
								     * A scan list for all selectable gerber items
							 | 
						|
								     */
							 | 
						|
								    static const KICAD_T AllItems[];
							 | 
						|
								
							 | 
						|
								    GERBER_COLLECTOR()
							 | 
						|
								    {
							 | 
						|
								        //m_Guide = NULL;
							 | 
						|
								        m_PrimaryLength = 0;
							 | 
						|
								        SetScanTypes( AllItems );
							 | 
						|
								    }
							 | 
						|
								
							 | 
						|
								    void Empty2nd()
							 | 
						|
								    {
							 | 
						|
								        m_List2nd.clear();
							 | 
						|
								    }
							 | 
						|
								
							 | 
						|
								    /*void Append2nd( BOARD_ITEM* item )
							 | 
						|
								    {
							 | 
						|
								        m_List2nd.push_back( item );
							 | 
						|
								    }*/
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								    /**
							 | 
						|
								     * Function SetGuide
							 | 
						|
								     * records which COLLECTORS_GUIDE to use.
							 | 
						|
								     * @param aGuide Which guide to use in the collection.
							 | 
						|
								     */
							 | 
						|
								    //void SetGuide( const COLLECTORS_GUIDE* aGuide ) { m_Guide = aGuide; }
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								    /**
							 | 
						|
								     * Function operator[int]
							 | 
						|
								     * overloads COLLECTOR::operator[](int) to return a EDA_ITEM* instead of
							 | 
						|
								     * an EDA_ITEM* type.
							 | 
						|
								     * @param ndx The index into the list.
							 | 
						|
								     * @return EDA_ITEM* - or something derived from it, or NULL.
							 | 
						|
								     */
							 | 
						|
								    EDA_ITEM* operator[]( int ndx ) const
							 | 
						|
								    {
							 | 
						|
								        if( (unsigned)ndx < (unsigned)GetCount() )
							 | 
						|
								            return (EDA_ITEM*) m_List[ ndx ];
							 | 
						|
								        return NULL;
							 | 
						|
								    }
							 | 
						|
								
							 | 
						|
								    /**
							 | 
						|
								     * Function GetPrimaryCount
							 | 
						|
								     * @return int - The number if items which met the primary search criteria
							 | 
						|
								     */
							 | 
						|
								    int GetPrimaryCount() { return m_PrimaryLength; }
							 | 
						|
								
							 | 
						|
								    /**
							 | 
						|
								     * Function Inspect
							 | 
						|
								     * is the examining function within the INSPECTOR which is passed to the
							 | 
						|
								     * Iterate function.
							 | 
						|
								     *
							 | 
						|
								     * @param testItem An EDA_ITEM to examine.
							 | 
						|
								     * @param testData is not used in this class.
							 | 
						|
								     * @return SEARCH_RESULT - SEARCH_QUIT if the Iterator is to stop the scan,
							 | 
						|
								     *   else SCAN_CONTINUE;
							 | 
						|
								     */
							 | 
						|
								    SEARCH_RESULT Inspect( EDA_ITEM* testItem, void* testData )  override;
							 | 
						|
								
							 | 
						|
								    /**
							 | 
						|
								     * Function Collect
							 | 
						|
								     * scans an EDA_ITEM using this class's Inspector method, which does the collection.
							 | 
						|
								     * @param aItem An EDA_ITEM to scan
							 | 
						|
								     * @param aScanList A list of KICAD_Ts with a terminating EOT, that specs
							 | 
						|
								     *  what is to be collected and the priority order of the resultant
							 | 
						|
								     *  collection in "m_List".
							 | 
						|
								     * @param aRefPos A wxPoint to use in hit-testing.
							 | 
						|
								     * @param aGuide The COLLECTORS_GUIDE to use in collecting items.
							 | 
						|
								     */
							 | 
						|
								    void Collect( EDA_ITEM* aItem, const KICAD_T aScanList[],
							 | 
						|
								                 const wxPoint& aRefPos/*, const COLLECTORS_GUIDE& aGuide */);
							 | 
						|
								};
							 | 
						|
								
							 | 
						|
								#endif
							 |