/* -*- c++ -*- * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2014 Henner Zeller * 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 #include class LIB_ALIAS; class PART_LIB; class PART_LIBS; class wxTreeCtrl; 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 ); /** Function AddComponentList * 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 ); /** 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 ); /** 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. * * @param aTree that is to be modified on search updates. */ void SetTree( wxTreeCtrl* aTree ); /** Function UpdateSearchTerm * Update the search string provided by the user and narrow down the result list. * * 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 m_nodes; wxTreeCtrl* m_tree; int m_libraries_added; int m_components_added; wxString m_preselect_node_name; int m_preselect_unit_number; PART_LIBS* m_libs; // no ownership enum CMP_FILTER_TYPE m_filter; // the current filter }; #endif /* COMPONENT_TREE_SEARCH_CONTAINER_H */