175 lines
6.5 KiB
C++
175 lines
6.5 KiB
C++
/* -*- c++ -*-
|
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
|
*
|
|
* Copyright (C) 2014 Henner Zeller <h.zeller@acm.org>
|
|
* Copyright (C) 2015 KiCad Developers, see change_log.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 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 COMPONENT_TREE_SEARCH_CONTAINER_H
|
|
#define COMPONENT_TREE_SEARCH_CONTAINER_H
|
|
|
|
#include <vector>
|
|
#include <wx/string.h>
|
|
|
|
class LIB_ALIAS;
|
|
class PART_LIB;
|
|
class PART_LIBS;
|
|
class TWO_COLUMN_TREE_LIST;
|
|
class wxArrayString;
|
|
|
|
// class COMPONENT_TREE_SEARCH_CONTAINER
|
|
// A container for components that allows to search them matching their name, keywords
|
|
// and descriptions, updating a wxTreeCtrl with the results (toplevel nodes:
|
|
// libraries, leafs: components), scored by relevance.
|
|
//
|
|
// The scored result list is adpated on each update on the search-term: this allows
|
|
// to have a search-as-you-type experience.
|
|
class COMPONENT_TREE_SEARCH_CONTAINER
|
|
{
|
|
public:
|
|
/** This enum allows a selective filtering of component to list
|
|
* currently: no filtering
|
|
* list power components only
|
|
*/
|
|
enum CMP_FILTER_TYPE
|
|
{
|
|
CMP_FILTER_NONE, ///< no filtering
|
|
CMP_FILTER_POWER ///< list components flagged PWR
|
|
};
|
|
|
|
public:
|
|
COMPONENT_TREE_SEARCH_CONTAINER( PART_LIBS* aLibs );
|
|
~COMPONENT_TREE_SEARCH_CONTAINER();
|
|
|
|
void SetFilter( CMP_FILTER_TYPE aFilter )
|
|
{
|
|
m_filter = aFilter;
|
|
}
|
|
|
|
/** Function AddLibrary
|
|
* Add all the components and their aliases of this library to be searched.
|
|
* To be called in the setup phase to fill this container.
|
|
*
|
|
* @param aLib containting all the components to be added.
|
|
*/
|
|
void AddLibrary( PART_LIB& aLib );
|
|
|
|
/**
|
|
* Add the given list of components, given by name, to be searched.
|
|
* To be called in the setup phase to fill this container.
|
|
*
|
|
* @param aNodeName The parent node name the components will show up as leaf.
|
|
* @param aAliasNameList List of alias names.
|
|
* @param aOptionalLib Library to look up the component names (if NULL: global lookup)
|
|
*/
|
|
void AddAliasList( const wxString& aNodeName, const wxArrayString& aAliasNameList,
|
|
PART_LIB* aOptionalLib );
|
|
|
|
/**
|
|
* Add the given list of components, given by alias, to be searched.
|
|
* To be called in the setup phase to fill this container.
|
|
*
|
|
* @param aNodeName The parent node name the components will show up as leaf.
|
|
* @param aAliasList List of aliases.
|
|
* @param aOptionalLib Library to look up the component names (if NULL: global lookup)
|
|
*/
|
|
void AddAliasList( const wxString& aNodeName, const std::vector<LIB_ALIAS*>& aAliasList,
|
|
PART_LIB* aOptionalLib );
|
|
|
|
/** Function SetPreselectNode
|
|
* Set the component name to be selected in absence of any search-result.
|
|
*
|
|
* @param aComponentName the component name to be selected.
|
|
* @param aUnit the component unit to be selected (if > 0).
|
|
*/
|
|
void SetPreselectNode( const wxString& aComponentName, int aUnit );
|
|
|
|
/**
|
|
* Set whether units should be shown under parts. Default: true
|
|
*
|
|
* Must be called before AddLibrary, as this is when the list is populated!
|
|
*/
|
|
void ShowUnits( bool aShowUnits );
|
|
|
|
/** Function SetTree
|
|
* Set the tree to be manipulated.
|
|
* Each update of the search term will update the tree, with the most
|
|
* scoring component at the top and selected. If a preselect node is set, this
|
|
* is displayed. Does not take ownership of the tree.
|
|
*
|
|
* After calling SetTree(), UpdateSearchTerm( wxEmptyString ) should be
|
|
* called. Note the warning with respsect to calling UpdateSearchTerm() in
|
|
* dialog constructors.
|
|
*
|
|
* @param aTree that is to be modified on search updates.
|
|
*/
|
|
void SetTree( TWO_COLUMN_TREE_LIST* aTree );
|
|
|
|
/** Function UpdateSearchTerm
|
|
* Update the search string provided by the user and narrow down the result list.
|
|
*
|
|
* XXX WARNING: Do not call this method in a dialog constructor until the
|
|
* dialog has been otherwise fully initialized (i.e. this should be the last
|
|
* thing called in the constructor). Some wx ports pump the event loop inside
|
|
* this method, which can result in event handlers being called before things
|
|
* they access are initialized.
|
|
*
|
|
* This string is a space-separated list of terms, each of which
|
|
* is applied to the components list to narrow it down. Results are scored by
|
|
* relevancy (e.g. exact match scores higher than prefix-match which in turn scores
|
|
* higher than substring match). This updates the search and tree on each call.
|
|
*
|
|
* @param aSearch is the user-provided search string.
|
|
*/
|
|
void UpdateSearchTerm( const wxString& aSearch );
|
|
|
|
/** Function GetSelectedAlias
|
|
*
|
|
* @param aUnit : if not NULL, the selected sub-unit is set here.
|
|
* @return the selected alias or NULL if there is none, or there is no tree.
|
|
*/
|
|
LIB_ALIAS* GetSelectedAlias( int* aUnit );
|
|
|
|
/**
|
|
* Function GetComponentsCount
|
|
* @return the number of components loaded in the tree
|
|
*/
|
|
int GetComponentsCount() { return m_components_added; }
|
|
|
|
|
|
private:
|
|
struct TREE_NODE;
|
|
static bool scoreComparator( const TREE_NODE* a1, const TREE_NODE* a2 );
|
|
|
|
std::vector<TREE_NODE*> m_nodes;
|
|
TWO_COLUMN_TREE_LIST* m_tree;
|
|
int m_libraries_added;
|
|
int m_components_added;
|
|
|
|
wxString m_preselect_node_name;
|
|
int m_preselect_unit_number;
|
|
bool m_show_units;
|
|
|
|
PART_LIBS* m_libs; // no ownership
|
|
|
|
enum CMP_FILTER_TYPE m_filter; // the current filter
|
|
};
|
|
|
|
#endif /* COMPONENT_TREE_SEARCH_CONTAINER_H */
|