2007-08-23 04:28:46 +00:00
|
|
|
/*
|
2011-09-30 18:15:37 +00:00
|
|
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
2007-08-23 04:28:46 +00:00
|
|
|
*
|
2008-01-22 20:35:46 +00:00
|
|
|
* Copyright (C) 2007-2008 SoftPLC Corporation, Dick Hollenbeck <dick@softplc.com>
|
2011-09-30 18:15:37 +00:00
|
|
|
* Copyright (C) 2004-2007 KiCad Developers, see change_log.txt for contributors.
|
2008-02-19 16:54:57 +00:00
|
|
|
*
|
2007-08-23 04:28:46 +00:00
|
|
|
* 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.
|
2008-02-19 16:54:57 +00:00
|
|
|
*
|
2007-08-23 04:28:46 +00:00
|
|
|
* 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.
|
2008-02-19 16:54:57 +00:00
|
|
|
*
|
2007-08-23 04:28:46 +00:00
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, you may find one here:
|
2008-02-19 16:54:57 +00:00
|
|
|
* 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.,
|
2007-08-23 04:28:46 +00:00
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
|
|
|
*/
|
|
|
|
|
2011-09-23 13:57:12 +00:00
|
|
|
/**
|
|
|
|
* @file collectors.h
|
|
|
|
*/
|
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
#ifndef COLLECTORS_H
|
|
|
|
#define COLLECTORS_H
|
|
|
|
|
|
|
|
|
|
|
|
/* This module contains a number of COLLECTOR implementations which are used
|
2011-03-01 19:26:17 +00:00
|
|
|
to augment the functionality of class PCB_EDIT_FRAME.
|
2007-08-23 04:28:46 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
2012-01-23 04:33:36 +00:00
|
|
|
#include <class_collector.h>
|
|
|
|
#include <layers_id_colors_and_visibility.h> // LAYER_COUNT, layer defs
|
2011-09-23 13:57:12 +00:00
|
|
|
|
|
|
|
|
|
|
|
class BOARD_ITEM;
|
2007-08-23 04:28:46 +00:00
|
|
|
|
2007-08-30 03:53:26 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Class COLLECTORS_GUIDE
|
2008-02-19 16:54:57 +00:00
|
|
|
* is an abstract base class whose derivatives may be passed to a GENERAL_COLLECTOR,
|
|
|
|
* telling GENERAL_COLLECTOR what should be collected (aside from HitTest()ing
|
|
|
|
* and KICAD_T scanTypes[], information which are provided to the GENERAL_COLLECTOR
|
|
|
|
* through attributes or arguments separately).
|
2007-08-30 22:20:52 +00:00
|
|
|
* <p>
|
|
|
|
* A justification for this class is to keep the structural storage details of
|
2008-02-19 16:54:57 +00:00
|
|
|
* the program's "global preferences" or "configuration options" out of
|
2007-08-30 22:20:52 +00:00
|
|
|
* GENERAL_COLLECTOR::Inspect(). This class carries all the necessary details
|
|
|
|
* in with it to the Inspect() call. The constructors or other functions of
|
|
|
|
* this class's derivatives are then the only place where knowledge of the
|
2008-02-19 16:54:57 +00:00
|
|
|
* specific structure of the global preference storage is needed. Thus,
|
|
|
|
* GENERAL_COLLECTOR::Inspect() can be kept as simple as possible, and insulated
|
|
|
|
* from changes in global preference storage (and even then it is
|
2007-08-30 22:20:52 +00:00
|
|
|
* not simple enough).
|
2007-08-30 03:53:26 +00:00
|
|
|
* <p>
|
|
|
|
* This class introduces the notion of layer locking.
|
|
|
|
*/
|
2008-02-19 16:54:57 +00:00
|
|
|
class COLLECTORS_GUIDE
|
2007-08-30 03:53:26 +00:00
|
|
|
{
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-08-30 03:53:26 +00:00
|
|
|
public:
|
|
|
|
virtual ~COLLECTORS_GUIDE() {}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function IsLayerLocked
|
|
|
|
* @return bool - true if the given layer is locked, else false.
|
|
|
|
*/
|
2014-06-24 16:17:18 +00:00
|
|
|
virtual bool IsLayerLocked( LAYER_ID layer ) const = 0;
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-08-30 03:53:26 +00:00
|
|
|
/**
|
|
|
|
* Function IsLayerVisible
|
|
|
|
* @return bool - true if the given layer is visible, else false.
|
|
|
|
*/
|
2014-06-24 16:17:18 +00:00
|
|
|
virtual bool IsLayerVisible( LAYER_ID layer ) const = 0;
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-08-30 03:53:26 +00:00
|
|
|
/**
|
|
|
|
* Function IgnoreLockedLayers
|
2007-08-30 22:20:52 +00:00
|
|
|
* @return bool - true if should ignore locked layers, else false.
|
2007-08-30 03:53:26 +00:00
|
|
|
*/
|
|
|
|
virtual bool IgnoreLockedLayers() const = 0;
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-08-30 03:53:26 +00:00
|
|
|
/**
|
|
|
|
* Function IgnoredNonVisibleLayers
|
|
|
|
* @return bool - true if should ignore non-visible layers, else false.
|
|
|
|
*/
|
|
|
|
virtual bool IgnoreNonVisibleLayers() const = 0;
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-08-30 03:53:26 +00:00
|
|
|
/**
|
|
|
|
* Function GetPreferredLayer
|
|
|
|
* @return int - the preferred layer for HitTest()ing.
|
|
|
|
*/
|
2014-06-24 16:17:18 +00:00
|
|
|
virtual LAYER_ID GetPreferredLayer() const = 0;
|
2007-08-30 22:20:52 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function IgnorePreferredLayer
|
|
|
|
* provides wildcard behavior regarding the preferred layer.
|
|
|
|
* @return bool - true if should ignore preferred layer, else false.
|
|
|
|
*/
|
|
|
|
virtual bool IgnorePreferredLayer() const = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function IgnoreLockedItems
|
|
|
|
* @return bool - true if should ignore locked items, else false.
|
|
|
|
*/
|
|
|
|
virtual bool IgnoreLockedItems() const = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function IncludeSecondary
|
|
|
|
* determines if the secondary criteria, or 2nd choice items should be
|
|
|
|
* included.
|
|
|
|
* @return bool - true if should include, else false.
|
|
|
|
*/
|
|
|
|
virtual bool IncludeSecondary() const = 0;
|
2007-09-01 12:00:30 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function IgnoreMTextsMarkedNoShow
|
2007-10-31 20:02:34 +00:00
|
|
|
* @return bool - true if MTexts marked as "no show" should be ignored.
|
2007-09-01 12:00:30 +00:00
|
|
|
*/
|
|
|
|
virtual bool IgnoreMTextsMarkedNoShow() const = 0;
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-09-01 12:00:30 +00:00
|
|
|
/**
|
|
|
|
* Function IgnoreZones
|
|
|
|
* @return bool - true if should ignore zones.
|
|
|
|
virtual bool IgnoreZones() const = 0;
|
2011-10-01 19:24:27 +00:00
|
|
|
can simply omit from scanTypes[] PCB_ZONE_T */
|
2007-09-01 12:00:30 +00:00
|
|
|
|
|
|
|
/**
|
2014-09-11 16:35:19 +00:00
|
|
|
* Function IgnoreMTextsOnBack
|
|
|
|
* @return bool - true if should ignore MTexts on back layers
|
2007-09-01 12:00:30 +00:00
|
|
|
*/
|
2014-09-11 16:35:19 +00:00
|
|
|
virtual bool IgnoreMTextsOnBack() const = 0;
|
2007-09-01 12:00:30 +00:00
|
|
|
|
|
|
|
/**
|
2014-09-11 16:35:19 +00:00
|
|
|
* Function IgnoreMTextsOnFront
|
|
|
|
* @return bool - true if should ignore MTexts on front layers.
|
2007-09-01 12:00:30 +00:00
|
|
|
*/
|
2014-09-11 16:35:19 +00:00
|
|
|
virtual bool IgnoreMTextsOnFront() const = 0;
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-09-01 12:00:30 +00:00
|
|
|
/**
|
2014-09-11 16:35:19 +00:00
|
|
|
* Function IgnoreModulesOnBack
|
2010-02-05 10:56:23 +00:00
|
|
|
* @return bool - true if should ignore MODULEs on Back Side.
|
2007-09-01 12:00:30 +00:00
|
|
|
*/
|
2014-09-11 16:35:19 +00:00
|
|
|
virtual bool IgnoreModulesOnBack() const = 0;
|
2007-09-01 12:00:30 +00:00
|
|
|
|
|
|
|
/**
|
2014-09-11 16:35:19 +00:00
|
|
|
* Function IgnoreModulesOnFront
|
2010-02-05 10:56:23 +00:00
|
|
|
* @return bool - ture if should ignore MODULEs on Front Side.
|
2007-09-01 12:00:30 +00:00
|
|
|
*/
|
2014-09-11 16:35:19 +00:00
|
|
|
virtual bool IgnoreModulesOnFront() const = 0;
|
2007-09-25 15:10:01 +00:00
|
|
|
|
2010-02-05 10:56:23 +00:00
|
|
|
/**
|
|
|
|
* Function IgnorePadsOnBack
|
|
|
|
* @return bool - true if should ignore Pads on Back Side.
|
|
|
|
*/
|
|
|
|
virtual bool IgnorePadsOnBack() const = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function IgnorePadsOnFront
|
|
|
|
* @return bool - ture if should ignore PADSs on Front Side.
|
|
|
|
*/
|
|
|
|
virtual bool IgnorePadsOnFront() const = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function IgnorePads
|
|
|
|
* @return bool - true if should ignore PADSs on Front side and Back side.
|
|
|
|
*/
|
|
|
|
virtual bool IgnorePads() const
|
|
|
|
{
|
|
|
|
return IgnorePadsOnFront() && IgnorePadsOnBack();
|
|
|
|
}
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2011-12-14 22:35:03 +00:00
|
|
|
/**
|
|
|
|
* Function IgnoreModulesVals
|
|
|
|
* @return bool - true if should ignore modules values.
|
|
|
|
*/
|
|
|
|
virtual bool IgnoreModulesVals() const = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function IgnoreModulesRefs
|
|
|
|
* @return bool - true if should ignore module references.
|
|
|
|
*/
|
|
|
|
virtual bool IgnoreModulesRefs() const = 0;
|
|
|
|
|
2007-08-30 22:20:52 +00:00
|
|
|
/**
|
|
|
|
* Function UseHitTesting
|
|
|
|
* @return bool - true if Inspect() should use BOARD_ITEM::HitTest()
|
|
|
|
* or false if Inspect() should use BOARD_ITEM::BoundsTest().
|
|
|
|
virtual bool UseHitTesting() const = 0;
|
|
|
|
*/
|
2007-08-30 03:53:26 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
/**
|
2007-08-30 22:20:52 +00:00
|
|
|
* Class GENERAL_COLLECTOR
|
2008-02-19 16:54:57 +00:00
|
|
|
* is intended for use when the right click button is pressed, or when the
|
2007-08-23 04:28:46 +00:00
|
|
|
* plain "arrow" tool is in effect. This class can be used by window classes
|
2011-03-01 19:26:17 +00:00
|
|
|
* such as PCB_EDIT_FRAME.
|
2007-08-23 04:28:46 +00:00
|
|
|
*
|
2007-08-24 03:40:04 +00:00
|
|
|
* Philosophy: this class knows nothing of the context in which a BOARD is used
|
2008-02-19 16:54:57 +00:00
|
|
|
* and that means it knows nothing about which layers are visible or current,
|
2007-08-23 04:28:46 +00:00
|
|
|
* but can handle those concerns by the SetPreferredLayer() function and the
|
2014-06-24 16:17:18 +00:00
|
|
|
* SetLayerSet() function.
|
2007-08-23 04:28:46 +00:00
|
|
|
*/
|
2007-08-30 22:20:52 +00:00
|
|
|
class GENERAL_COLLECTOR : public COLLECTOR
|
2007-08-23 04:28:46 +00:00
|
|
|
{
|
2008-02-19 16:54:57 +00:00
|
|
|
protected:
|
2007-08-23 04:28:46 +00:00
|
|
|
/**
|
2008-02-19 16:54:57 +00:00
|
|
|
* 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
|
2007-08-23 04:28:46 +00:00
|
|
|
* "list" at the end of the search.
|
|
|
|
*/
|
2007-08-30 22:20:52 +00:00
|
|
|
std::vector<BOARD_ITEM*> m_List2nd;
|
2008-02-19 16:54:57 +00:00
|
|
|
|
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
/**
|
2007-08-30 22:20:52 +00:00
|
|
|
* Determines which items are to be collected by Inspect()
|
2007-08-23 04:28:46 +00:00
|
|
|
*/
|
2007-09-11 04:15:39 +00:00
|
|
|
const COLLECTORS_GUIDE* m_Guide;
|
2008-02-19 16:54:57 +00:00
|
|
|
|
|
|
|
|
2007-09-12 02:14:07 +00:00
|
|
|
/**
|
2008-02-19 16:54:57 +00:00
|
|
|
* The number of items that were originally in the primary list before the
|
2007-09-12 02:14:07 +00:00
|
|
|
* m_List2nd was concatonated onto the end of it.
|
|
|
|
*/
|
|
|
|
int m_PrimaryLength;
|
2007-08-30 22:20:52 +00:00
|
|
|
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
public:
|
|
|
|
|
2007-09-11 04:15:39 +00:00
|
|
|
/**
|
|
|
|
* A scan list for all editable board items, like PcbGeneralLocateAndDisplay()
|
|
|
|
*/
|
2007-08-23 04:28:46 +00:00
|
|
|
static const KICAD_T AllBoardItems[];
|
|
|
|
|
|
|
|
|
2007-09-25 15:10:01 +00:00
|
|
|
/**
|
|
|
|
* A scan list for all editable board items, except zones
|
|
|
|
*/
|
|
|
|
static const KICAD_T AllButZones[];
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2011-05-12 11:06:32 +00:00
|
|
|
/**
|
|
|
|
* A scan list for zones outlines only
|
|
|
|
*/
|
|
|
|
static const KICAD_T Zones[];
|
|
|
|
|
2008-02-19 16:54:57 +00:00
|
|
|
|
|
|
|
/**
|
2007-09-11 04:15:39 +00:00
|
|
|
* A scan list for all primary board items, omitting items which are subordinate to
|
2007-09-06 04:34:03 +00:00
|
|
|
* a MODULE, such as D_PAD and TEXTEMODULE.
|
|
|
|
static const KICAD_T PrimaryItems[];
|
2007-10-10 14:08:26 +00:00
|
|
|
*/
|
2007-09-12 02:14:07 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A scan list for only MODULEs
|
|
|
|
*/
|
2014-07-09 11:50:27 +00:00
|
|
|
static const KICAD_T Modules[];
|
2007-09-12 02:14:07 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A scan list for PADs or MODULEs
|
|
|
|
*/
|
|
|
|
static const KICAD_T PadsOrModules[];
|
|
|
|
|
2007-12-13 06:24:09 +00:00
|
|
|
/**
|
|
|
|
* A scan list for PADs, TRACKs, VIAs, or ZONEs
|
|
|
|
*/
|
2008-02-19 16:54:57 +00:00
|
|
|
static const KICAD_T PadsTracksOrZones[];
|
|
|
|
|
2007-12-13 06:24:09 +00:00
|
|
|
|
2007-10-27 18:05:50 +00:00
|
|
|
/**
|
|
|
|
* A scan list for MODULEs and their items (for Modedit)
|
|
|
|
*/
|
|
|
|
static const KICAD_T ModulesAndTheirItems[];
|
|
|
|
|
2007-09-12 02:14:07 +00:00
|
|
|
|
2014-07-09 11:50:27 +00:00
|
|
|
/**
|
|
|
|
* A scan list for primary module items.
|
|
|
|
*/
|
|
|
|
static const KICAD_T ModuleItems[];
|
|
|
|
|
|
|
|
|
2007-09-12 02:14:07 +00:00
|
|
|
/**
|
|
|
|
* A scan list for only TRACKS
|
|
|
|
*/
|
|
|
|
static const KICAD_T Tracks[];
|
2008-02-19 16:54:57 +00:00
|
|
|
|
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
/**
|
2007-08-24 03:40:04 +00:00
|
|
|
* Constructor GENERALCOLLECTOR
|
2008-02-19 16:54:57 +00:00
|
|
|
*/
|
2007-08-30 22:20:52 +00:00
|
|
|
GENERAL_COLLECTOR()
|
2007-08-23 04:28:46 +00:00
|
|
|
{
|
|
|
|
SetScanTypes( AllBoardItems );
|
|
|
|
}
|
|
|
|
|
|
|
|
void Empty2nd()
|
|
|
|
{
|
2007-08-30 22:20:52 +00:00
|
|
|
m_List2nd.clear();
|
2007-08-23 04:28:46 +00:00
|
|
|
}
|
|
|
|
|
2007-08-24 03:40:04 +00:00
|
|
|
void Append2nd( BOARD_ITEM* item )
|
2007-08-23 04:28:46 +00:00
|
|
|
{
|
2007-08-30 22:20:52 +00:00
|
|
|
m_List2nd.push_back( item );
|
2007-08-23 04:28:46 +00:00
|
|
|
}
|
|
|
|
|
2007-08-30 22:20:52 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function SetGuide
|
2007-09-11 04:15:39 +00:00
|
|
|
* records which COLLECTORS_GUIDE to use.
|
2007-08-30 22:20:52 +00:00
|
|
|
* @param aGuide Which guide to use in the collection.
|
|
|
|
*/
|
|
|
|
void SetGuide( const COLLECTORS_GUIDE* aGuide ) { m_Guide = aGuide; }
|
2008-02-19 16:54:57 +00:00
|
|
|
|
|
|
|
|
2007-08-24 03:40:04 +00:00
|
|
|
/**
|
|
|
|
* Function operator[int]
|
|
|
|
* overloads COLLECTOR::operator[](int) to return a BOARD_ITEM* instead of
|
2010-12-08 20:12:46 +00:00
|
|
|
* an EDA_ITEM* type.
|
2007-08-24 03:40:04 +00:00
|
|
|
* @param ndx The index into the list.
|
|
|
|
* @return BOARD_ITEM* - or something derived from it, or NULL.
|
|
|
|
*/
|
|
|
|
BOARD_ITEM* operator[]( int ndx ) const
|
|
|
|
{
|
|
|
|
if( (unsigned)ndx < (unsigned)GetCount() )
|
2007-08-30 22:20:52 +00:00
|
|
|
return (BOARD_ITEM*) m_List[ ndx ];
|
2007-08-24 03:40:04 +00:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-09-12 02:14:07 +00:00
|
|
|
/**
|
|
|
|
* Function GetPrimaryCount
|
|
|
|
* @return int - The number if items which met the primary search criteria
|
|
|
|
*/
|
|
|
|
int GetPrimaryCount() { return m_PrimaryLength; }
|
2008-02-19 16:54:57 +00:00
|
|
|
|
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
/**
|
|
|
|
* Function Inspect
|
2008-02-19 16:54:57 +00:00
|
|
|
* is the examining function within the INSPECTOR which is passed to the
|
2007-08-23 04:28:46 +00:00
|
|
|
* Iterate function.
|
|
|
|
*
|
2010-12-08 20:12:46 +00:00
|
|
|
* @param testItem An EDA_ITEM to examine.
|
2007-08-23 04:28:46 +00:00
|
|
|
* @param testData is not used in this class.
|
|
|
|
* @return SEARCH_RESULT - SEARCH_QUIT if the Iterator is to stop the scan,
|
|
|
|
* else SCAN_CONTINUE;
|
2008-02-19 16:54:57 +00:00
|
|
|
*/
|
2010-12-08 20:12:46 +00:00
|
|
|
SEARCH_RESULT Inspect( EDA_ITEM* testItem, const void* testData );
|
2008-02-19 16:54:57 +00:00
|
|
|
|
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
/**
|
2007-08-30 22:20:52 +00:00
|
|
|
* Function Collect
|
2007-10-31 20:02:34 +00:00
|
|
|
* scans a BOARD_ITEM using this class's Inspector method, which does the collection.
|
2007-09-11 04:15:39 +00:00
|
|
|
* @param aItem A BOARD_ITEM to scan, may be a BOARD or MODULE, or whatever.
|
2008-02-19 16:54:57 +00:00
|
|
|
* @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
|
2007-09-11 04:15:39 +00:00
|
|
|
* collection in "m_List".
|
2007-08-30 22:20:52 +00:00
|
|
|
* @param aRefPos A wxPoint to use in hit-testing.
|
|
|
|
* @param aGuide The COLLECTORS_GUIDE to use in collecting items.
|
2007-08-30 03:53:26 +00:00
|
|
|
*/
|
2008-02-19 16:54:57 +00:00
|
|
|
void Collect( BOARD_ITEM* aItem, const KICAD_T aScanList[],
|
|
|
|
const wxPoint& aRefPos, const COLLECTORS_GUIDE& aGuide );
|
2007-08-23 04:28:46 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2007-08-30 22:20:52 +00:00
|
|
|
/**
|
|
|
|
* Class GENERAL_COLLECTORS_GUIDE
|
|
|
|
* is a general implementation of a COLLECTORS_GUIDE. One of its constructors is
|
|
|
|
* entitled to grab information from the program's global preferences.
|
2008-02-19 16:54:57 +00:00
|
|
|
*/
|
2007-08-30 22:20:52 +00:00
|
|
|
class GENERAL_COLLECTORS_GUIDE : public COLLECTORS_GUIDE
|
|
|
|
{
|
|
|
|
private:
|
2008-02-19 16:54:57 +00:00
|
|
|
// the storage architecture here is not important, since this is only
|
2007-08-30 22:20:52 +00:00
|
|
|
// a carrier object and its functions are what is used, and data only indirectly.
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2014-06-24 16:17:18 +00:00
|
|
|
LAYER_ID m_PreferredLayer;
|
2007-08-30 22:20:52 +00:00
|
|
|
bool m_IgnorePreferredLayer;
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2014-06-24 16:17:18 +00:00
|
|
|
LSET m_LayerLocked; ///< bit-mapped layer locked bits
|
2007-08-30 22:20:52 +00:00
|
|
|
bool m_IgnoreLockedLayers;
|
|
|
|
|
2014-06-24 16:17:18 +00:00
|
|
|
LSET m_LayerVisible; ///< bit-mapped layer visible bits
|
2007-08-30 22:20:52 +00:00
|
|
|
bool m_IgnoreNonVisibleLayers;
|
2008-02-19 16:54:57 +00:00
|
|
|
|
|
|
|
bool m_IgnoreLockedItems;
|
2007-08-30 22:20:52 +00:00
|
|
|
bool m_IncludeSecondary;
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-09-01 12:00:30 +00:00
|
|
|
bool m_IgnoreMTextsMarkedNoShow;
|
2014-09-11 16:35:19 +00:00
|
|
|
bool m_IgnoreMTextsOnBack;
|
|
|
|
bool m_IgnoreMTextsOnFront;
|
|
|
|
bool m_IgnoreModulesOnBack;
|
|
|
|
bool m_IgnoreModulesOnFront;
|
2010-02-05 10:56:23 +00:00
|
|
|
bool m_IgnorePadsOnFront;
|
|
|
|
bool m_IgnorePadsOnBack;
|
2011-12-14 22:35:03 +00:00
|
|
|
bool m_IgnoreModulesVals;
|
|
|
|
bool m_IgnoreModulesRefs;
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-08-30 22:20:52 +00:00
|
|
|
public:
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructor GENERAL_COLLECTORS_GUIDE
|
|
|
|
* grabs stuff from global preferences and uses reasonable defaults.
|
|
|
|
* Add more constructors as needed.
|
2010-12-29 17:47:32 +00:00
|
|
|
* @param aVisibleLayerMask = current visible layers (bit mask)
|
|
|
|
* @param aPreferredLayer = the layer to search first
|
2007-08-30 22:20:52 +00:00
|
|
|
*/
|
2014-06-24 16:17:18 +00:00
|
|
|
GENERAL_COLLECTORS_GUIDE( LSET aVisibleLayerMask, LAYER_ID aPreferredLayer )
|
2007-08-30 22:20:52 +00:00
|
|
|
{
|
2014-06-24 16:17:18 +00:00
|
|
|
m_PreferredLayer = aPreferredLayer;
|
2007-08-30 22:20:52 +00:00
|
|
|
m_IgnorePreferredLayer = false;
|
2008-02-19 16:54:57 +00:00
|
|
|
m_LayerVisible = aVisibleLayerMask;
|
2007-08-30 22:20:52 +00:00
|
|
|
m_IgnoreLockedLayers = true;
|
|
|
|
m_IgnoreNonVisibleLayers = true;
|
2007-09-05 04:48:47 +00:00
|
|
|
m_IgnoreLockedItems = false;
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-08-30 22:20:52 +00:00
|
|
|
#if defined(USE_MATCH_LAYER)
|
|
|
|
m_IncludeSecondary = false;
|
2008-02-19 16:54:57 +00:00
|
|
|
#else
|
2007-08-30 22:20:52 +00:00
|
|
|
m_IncludeSecondary = true;
|
2008-02-19 16:54:57 +00:00
|
|
|
#endif
|
2007-09-01 12:00:30 +00:00
|
|
|
|
2007-09-05 04:48:47 +00:00
|
|
|
m_IgnoreMTextsMarkedNoShow = true; // g_ModuleTextNOVColor;
|
2014-09-11 16:35:19 +00:00
|
|
|
m_IgnoreMTextsOnBack = true;
|
|
|
|
m_IgnoreMTextsOnFront = false;
|
|
|
|
m_IgnoreModulesOnBack = true; // !Show_Modules_Cmp;
|
|
|
|
m_IgnoreModulesOnFront = false;
|
2010-12-29 17:47:32 +00:00
|
|
|
|
2010-02-05 10:56:23 +00:00
|
|
|
m_IgnorePadsOnFront = false;
|
|
|
|
m_IgnorePadsOnBack = false;
|
2011-12-14 22:35:03 +00:00
|
|
|
|
|
|
|
m_IgnoreModulesVals = false;
|
|
|
|
m_IgnoreModulesRefs = false;
|
2007-09-05 04:48:47 +00:00
|
|
|
}
|
2008-02-19 16:54:57 +00:00
|
|
|
|
|
|
|
|
2007-08-30 22:20:52 +00:00
|
|
|
/**
|
|
|
|
* Function IsLayerLocked
|
|
|
|
* @return bool - true if the given layer is locked, else false.
|
|
|
|
*/
|
2014-06-24 16:17:18 +00:00
|
|
|
bool IsLayerLocked( LAYER_ID aLayerId ) const
|
2007-08-30 22:20:52 +00:00
|
|
|
{
|
2014-06-24 16:17:18 +00:00
|
|
|
return m_LayerLocked[aLayerId];
|
2007-08-30 22:20:52 +00:00
|
|
|
}
|
|
|
|
|
2014-06-24 16:17:18 +00:00
|
|
|
void SetLayerLocked( LAYER_ID aLayerId, bool isLocked )
|
|
|
|
{
|
|
|
|
m_LayerLocked.set( aLayerId, isLocked );
|
|
|
|
}
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-08-30 22:20:52 +00:00
|
|
|
/**
|
|
|
|
* Function IsLayerVisible
|
|
|
|
* @return bool - true if the given layer is visible, else false.
|
|
|
|
*/
|
2014-06-24 16:17:18 +00:00
|
|
|
bool IsLayerVisible( LAYER_ID aLayerId ) const
|
|
|
|
{
|
|
|
|
return m_LayerVisible[aLayerId];
|
2013-03-30 17:24:04 +00:00
|
|
|
}
|
2014-06-24 16:17:18 +00:00
|
|
|
void SetLayerVisible( LAYER_ID aLayerId, bool isVisible )
|
2007-08-30 22:20:52 +00:00
|
|
|
{
|
2014-06-24 16:17:18 +00:00
|
|
|
m_LayerVisible.set( aLayerId, isVisible );
|
2007-08-30 22:20:52 +00:00
|
|
|
}
|
2014-06-24 16:17:18 +00:00
|
|
|
void SetLayerVisibleBits( LSET aLayerBits ) { m_LayerVisible = aLayerBits; }
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-08-30 22:20:52 +00:00
|
|
|
/**
|
|
|
|
* Function IgnoreLockedLayers
|
|
|
|
* @return bool - true if should ignore locked layers, else false.
|
|
|
|
*/
|
2014-06-24 16:17:18 +00:00
|
|
|
bool IgnoreLockedLayers() const { return m_IgnoreLockedLayers; }
|
|
|
|
void SetIgnoreLockedLayers( bool ignore ) { m_IgnoreLockedLayers = ignore; }
|
2008-02-19 16:54:57 +00:00
|
|
|
|
|
|
|
|
2007-08-30 22:20:52 +00:00
|
|
|
/**
|
|
|
|
* Function IgnoredNonVisibleLayers
|
|
|
|
* @return bool - true if should ignore non-visible layers, else false.
|
|
|
|
*/
|
2014-06-24 16:17:18 +00:00
|
|
|
bool IgnoreNonVisibleLayers() const { return m_IgnoreNonVisibleLayers; }
|
|
|
|
void SetIgnoreNonVisibleLayers( bool ignore ) { m_IgnoreLockedLayers = ignore; }
|
2007-08-30 22:20:52 +00:00
|
|
|
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-08-30 22:20:52 +00:00
|
|
|
/**
|
|
|
|
* Function GetPreferredLayer
|
|
|
|
* @return int - the preferred layer for HitTest()ing.
|
|
|
|
*/
|
2014-06-24 16:17:18 +00:00
|
|
|
LAYER_ID GetPreferredLayer() const { return m_PreferredLayer; }
|
|
|
|
void SetPreferredLayer( LAYER_ID aLayer ) { m_PreferredLayer = aLayer; }
|
2007-08-30 22:20:52 +00:00
|
|
|
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-08-30 22:20:52 +00:00
|
|
|
/**
|
|
|
|
* Function IgnorePreferredLayer
|
|
|
|
* provides wildcard behavior regarding the preferred layer.
|
|
|
|
* @return bool - true if should ignore preferred layer, else false.
|
|
|
|
*/
|
2014-06-24 16:17:18 +00:00
|
|
|
bool IgnorePreferredLayer() const { return m_IgnorePreferredLayer; }
|
|
|
|
void SetIgnorePreferredLayer( bool ignore ) { m_IgnorePreferredLayer = ignore; }
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-08-30 22:20:52 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function IgnoreLockedItems
|
|
|
|
* @return bool - true if should ignore locked items, else false.
|
|
|
|
*/
|
2014-06-24 16:17:18 +00:00
|
|
|
bool IgnoreLockedItems() const { return m_IgnoreLockedItems; }
|
|
|
|
void SetIgnoreLockedItems( bool ignore ) { m_IgnoreLockedItems = ignore; }
|
2007-08-30 22:20:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function IncludeSecondary
|
|
|
|
* determines if the secondary criteria, or 2nd choice items should be
|
|
|
|
* included.
|
|
|
|
* @return bool - true if should include, else false.
|
|
|
|
*/
|
|
|
|
bool IncludeSecondary() const { return m_IncludeSecondary; }
|
2007-09-01 12:00:30 +00:00
|
|
|
void SetIncludeSecondary( bool include ) { m_IncludeSecondary = include; }
|
|
|
|
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-09-01 12:00:30 +00:00
|
|
|
/**
|
|
|
|
* Function IgnoreMTextsMarkedNoShow
|
2007-10-31 20:02:34 +00:00
|
|
|
* @return bool - true if MTexts marked as "no show" should be ignored.
|
2007-09-01 12:00:30 +00:00
|
|
|
*/
|
|
|
|
bool IgnoreMTextsMarkedNoShow() const { return m_IgnoreMTextsMarkedNoShow; }
|
|
|
|
void SetIgnoreMTextsMarkedNoShow( bool ignore ) { m_IgnoreMTextsMarkedNoShow = ignore; }
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-09-01 12:00:30 +00:00
|
|
|
/**
|
|
|
|
* Function IgnoreMTextsOnCu
|
2014-09-11 16:35:19 +00:00
|
|
|
* @return bool - true if should ignore MTexts on back layers
|
2007-09-01 12:00:30 +00:00
|
|
|
*/
|
2014-09-11 16:35:19 +00:00
|
|
|
bool IgnoreMTextsOnBack() const { return m_IgnoreMTextsOnBack; }
|
|
|
|
void SetIgnoreMTextsOnBack( bool ignore ) { m_IgnoreMTextsOnBack = ignore; }
|
2007-09-01 12:00:30 +00:00
|
|
|
|
|
|
|
/**
|
2014-09-11 16:35:19 +00:00
|
|
|
* Function IgnoreMTextsOnFront
|
|
|
|
* @return bool - true if should ignore MTexts on front layers
|
2007-09-01 12:00:30 +00:00
|
|
|
*/
|
2014-09-11 16:35:19 +00:00
|
|
|
bool IgnoreMTextsOnFront() const { return m_IgnoreMTextsOnFront; }
|
|
|
|
void SetIgnoreMTextsOnFront( bool ignore ) { m_IgnoreMTextsOnFront = ignore; }
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2007-09-01 12:00:30 +00:00
|
|
|
/**
|
2014-09-11 16:35:19 +00:00
|
|
|
* Function IgnoreModulesOnBack
|
|
|
|
* @return bool - true if should ignore MODULEs on the back side
|
2007-09-01 12:00:30 +00:00
|
|
|
*/
|
2014-09-11 16:35:19 +00:00
|
|
|
bool IgnoreModulesOnBack() const { return m_IgnoreModulesOnBack; }
|
|
|
|
void SetIgnoreModulesOnBack( bool ignore ) { m_IgnoreModulesOnBack = ignore; }
|
2007-09-01 12:00:30 +00:00
|
|
|
|
|
|
|
/**
|
2014-09-11 16:35:19 +00:00
|
|
|
* Function IgnoreModulesOnFront
|
2010-02-05 10:56:23 +00:00
|
|
|
* @return bool - true if should ignore MODULEs on component layer.
|
2007-09-01 12:00:30 +00:00
|
|
|
*/
|
2014-09-11 16:35:19 +00:00
|
|
|
bool IgnoreModulesOnFront() const { return m_IgnoreModulesOnFront; }
|
|
|
|
void SetIgnoreModulesOnFront( bool ignore ) { m_IgnoreModulesOnFront = ignore; }
|
2010-02-05 10:56:23 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function IgnorePadsOnBack
|
|
|
|
* @return bool - true if should ignore Pads on Back Side.
|
|
|
|
*/
|
|
|
|
bool IgnorePadsOnBack() const { return m_IgnorePadsOnBack; }
|
|
|
|
void SetIgnorePadsOnBack(bool ignore) { m_IgnorePadsOnBack = ignore; }
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function IgnorePadsOnFront
|
|
|
|
* @return bool - true if should ignore PADSs on Front Side.
|
|
|
|
*/
|
|
|
|
bool IgnorePadsOnFront() const { return m_IgnorePadsOnFront; }
|
|
|
|
void SetIgnorePadsOnFront(bool ignore) { m_IgnorePadsOnFront = ignore; }
|
2011-12-14 22:35:03 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function IgnoreModulesVals
|
|
|
|
* @return bool - true if should ignore modules values.
|
|
|
|
*/
|
|
|
|
bool IgnoreModulesVals() const { return m_IgnoreModulesVals; }
|
|
|
|
void SetIgnoreModulesVals(bool ignore) { m_IgnoreModulesVals = ignore; }
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function IgnoreModulesRefs
|
|
|
|
* @return bool - true if should ignore modules references.
|
|
|
|
*/
|
|
|
|
bool IgnoreModulesRefs() const { return m_IgnoreModulesRefs; }
|
|
|
|
void SetIgnoreModulesRefs(bool ignore) { m_IgnoreModulesRefs = ignore; }
|
2007-08-30 22:20:52 +00:00
|
|
|
};
|
|
|
|
|
2008-01-22 20:35:46 +00:00
|
|
|
|
|
|
|
/**
|
Modular KiCad Blueprint Milestone B), major portions:
*) When kicad.exe closes a project, close any open KIFACEs so that they cannot
get disassociated from their true PROJECT.
*) Allow loading eeschema library editor from kicad.exe
*) Allow loading pcbnew library editor from kicad.exe
*) Rename LIB_COMPONENT to LIB_PART.
*) Add class PART_LIBS, and PART_LIB.
*) Make PART_LIBS non-global, i.e. PROJECT specific.
*) Implement "data on demand" for PART_LIBS
*) Implement "data on demand" for schematic SEARCH_STACK.
*) Use RSTRINGs to retain eeschema editor's notion of last library and part being edited.
*) Get rid of library search on every SCH_COMPONENT::Draw() call, instead use
a weak pointer.
*) Remove all chdir() calls so projects don't need to be CWD.
*) Romove APPEND support from OpenProjectFiles().
*) Make OpenProjectFiles() robust, even for creating new projects.
*) Load EESCHEMA colors in the KIWAY::OnKiwayStart() rather in window open,
and save them in the .eeschema config file, not in the project file.
*) Fix bug with wxDir() while accessing protected dirs in kicad.exe
*) Consolidate template copying into PROJECT class, not in kicad.exe source.
*) Generally untangle eeschema, making its libraries not global but rather
held in the PROJECT.
2014-08-13 20:28:54 +00:00
|
|
|
* Class PCB_TYPE_COLLECTOR
|
2008-01-22 20:35:46 +00:00
|
|
|
* merely gathers up all BOARD_ITEMs of a given set of KICAD_T type(s).
|
|
|
|
* @see class COLLECTOR
|
|
|
|
*/
|
Modular KiCad Blueprint Milestone B), major portions:
*) When kicad.exe closes a project, close any open KIFACEs so that they cannot
get disassociated from their true PROJECT.
*) Allow loading eeschema library editor from kicad.exe
*) Allow loading pcbnew library editor from kicad.exe
*) Rename LIB_COMPONENT to LIB_PART.
*) Add class PART_LIBS, and PART_LIB.
*) Make PART_LIBS non-global, i.e. PROJECT specific.
*) Implement "data on demand" for PART_LIBS
*) Implement "data on demand" for schematic SEARCH_STACK.
*) Use RSTRINGs to retain eeschema editor's notion of last library and part being edited.
*) Get rid of library search on every SCH_COMPONENT::Draw() call, instead use
a weak pointer.
*) Remove all chdir() calls so projects don't need to be CWD.
*) Romove APPEND support from OpenProjectFiles().
*) Make OpenProjectFiles() robust, even for creating new projects.
*) Load EESCHEMA colors in the KIWAY::OnKiwayStart() rather in window open,
and save them in the .eeschema config file, not in the project file.
*) Fix bug with wxDir() while accessing protected dirs in kicad.exe
*) Consolidate template copying into PROJECT class, not in kicad.exe source.
*) Generally untangle eeschema, making its libraries not global but rather
held in the PROJECT.
2014-08-13 20:28:54 +00:00
|
|
|
class PCB_TYPE_COLLECTOR : public COLLECTOR
|
2008-01-22 20:35:46 +00:00
|
|
|
{
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2008-01-22 20:35:46 +00:00
|
|
|
public:
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function operator[int]
|
|
|
|
* overloads COLLECTOR::operator[](int) to return a BOARD_ITEM* instead of
|
2010-12-08 20:12:46 +00:00
|
|
|
* an EDA_ITEM* type.
|
2008-01-22 20:35:46 +00:00
|
|
|
* @param ndx The index into the list.
|
|
|
|
* @return BOARD_ITEM* - or something derived from it, or NULL.
|
|
|
|
*/
|
|
|
|
BOARD_ITEM* operator[]( int ndx ) const
|
|
|
|
{
|
|
|
|
if( (unsigned)ndx < (unsigned)GetCount() )
|
|
|
|
return (BOARD_ITEM*) m_List[ ndx ];
|
|
|
|
return NULL;
|
|
|
|
}
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2008-01-22 20:35:46 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function Inspect
|
2008-02-19 16:54:57 +00:00
|
|
|
* is the examining function within the INSPECTOR which is passed to the
|
2008-01-22 20:35:46 +00:00
|
|
|
* Iterate function.
|
|
|
|
*
|
2010-12-08 20:12:46 +00:00
|
|
|
* @param testItem An EDA_ITEM to examine.
|
2008-01-22 20:35:46 +00:00
|
|
|
* @param testData is not used in this class.
|
|
|
|
* @return SEARCH_RESULT - SEARCH_QUIT if the Iterator is to stop the scan,
|
|
|
|
* else SCAN_CONTINUE;
|
2008-02-19 16:54:57 +00:00
|
|
|
*/
|
2010-12-08 20:12:46 +00:00
|
|
|
SEARCH_RESULT Inspect( EDA_ITEM* testItem, const void* testData );
|
2008-02-19 16:54:57 +00:00
|
|
|
|
2008-01-22 20:35:46 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function Collect
|
2008-02-19 16:54:57 +00:00
|
|
|
* scans a BOARD_ITEM using this class's Inspector method, which does
|
2008-01-22 20:35:46 +00:00
|
|
|
* the collection.
|
|
|
|
* @param aBoard The BOARD_ITEM to scan.
|
|
|
|
* @param aScanList The KICAD_Ts to gather up.
|
|
|
|
*/
|
|
|
|
void Collect( BOARD_ITEM* aBoard, const KICAD_T aScanList[] );
|
|
|
|
};
|
|
|
|
|
2007-08-23 04:28:46 +00:00
|
|
|
#endif // COLLECTORS_H
|