 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.
11 years ago  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.
11 years ago |
|
/*
* This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2010 SoftPLC Corporation, Dick Hollenbeck <dick@softplc.com> * Copyright (C) 2014-2020 KiCad Developers, see CHANGELOG.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 _TEMPLATE_FIELDNAME_H_
#define _TEMPLATE_FIELDNAME_H_
#include <richio.h>
#include <macros.h>
#include <template_fieldnames_lexer.h>
class TEMPLATE_FIELDNAMES_LEXER;
/**
* Enum NumFieldType * is the set of all field indices assuming an array like sequence that a * SCH_COMPONENT or LIB_PART can hold. * The first fields are called fixed fields and the quantity of them is * given by MANDATORY_FIELDS. After that come an unlimited number of * user defined fields, only some of which have indices defined here. */enum NumFieldType { REFERENCE = 0, ///< Field Reference of part, i.e. "IC21"
VALUE, ///< Field Value of part, i.e. "3.3K"
FOOTPRINT, ///< Field Name Module PCB, i.e. "16DIP300"
DATASHEET, ///< name of datasheet
/// The first 4 are mandatory, and must be instantiated in SCH_COMPONENT
/// and LIB_PART constructors
MANDATORY_FIELDS,
FIELD1 = MANDATORY_FIELDS, FIELD2, FIELD3, FIELD4, FIELD5, FIELD6, FIELD7, FIELD8};
/**
* Struct TEMPLATE_FIELDNAME * holds a name of a component's field, field value, and default visibility. * Template fieldnames are wanted fieldnames for use in the symbol/component * property editors. */struct TEMPLATE_FIELDNAME{ wxString m_Name; // The field name
bool m_Visible; // Field defaults to being visible in schematic.
bool m_URL; // If field should have a browse button
TEMPLATE_FIELDNAME() : m_Visible( false ), m_URL( false ) { }
TEMPLATE_FIELDNAME( const wxString& aName ) : m_Name( aName ), m_Visible( false ), m_URL( false ) { }
TEMPLATE_FIELDNAME( const TEMPLATE_FIELDNAME& ref ) { m_Name = ref.m_Name; m_Visible = ref.m_Visible; m_URL = ref.m_URL; }
/**
* Function Format * serializes this object out as text into the given OUTPUTFORMATTER. */ void Format( OUTPUTFORMATTER* out, int nestLevel ) const ;
/**
* Function Parse * fills this object from information in the input stream \a aSpec, which * is a TEMPLATE_FIELDNAMES_LEXER. The entire textual element spec is <br> * (field (name _yourfieldname_)(value _yourvalue_) visible)) <br> * The presence of value is optional, the presence of visible is optional. * When this function is called, the input token stream given by \a aSpec * is assumed to be positioned at the '^' in the following example, i.e. just after the * identifying keyword and before the content specifying stuff.<br> * (field ^ (....) ) * * @param aSpec is the input token stream of keywords and symbols. */ void Parse( TEMPLATE_FIELDNAMES_LEXER* aSpec );
/**
* Function GetDefaultFieldName * returns a default symbol field name for field \a aFieldNdx for all components. * These fieldnames are not modifiable, but template fieldnames are. * @param aFieldNdx The field number index, > 0 */ static const wxString GetDefaultFieldName( int aFieldNdx );};
typedef std::vector< TEMPLATE_FIELDNAME > TEMPLATE_FIELDNAMES;
class TEMPLATES{private: TEMPLATE_FIELDNAMES m_globals; TEMPLATE_FIELDNAMES m_project;
// Combined list. Project templates override global ones.
TEMPLATE_FIELDNAMES m_resolved; bool m_resolvedDirty;
public: TEMPLATES() : m_resolvedDirty( true ) { }
/**
* Function Format * serializes this object out as text into the given OUTPUTFORMATTER. */ void Format( OUTPUTFORMATTER* out, int nestLevel, bool aGlobal ) const ;
/**
* Function Parse * fills this object from information in the input stream handled by TEMPLATE_FIELDNAMES_LEXER */ void Parse( TEMPLATE_FIELDNAMES_LEXER* in, bool aGlobal );
/**
* Function AddTemplateFieldName * inserts or appends a wanted symbol field name into the fieldnames * template. Should be used for any symbol property editor. If the name * already exists, it overwrites the same name. * * @param aFieldName is a full description of the wanted field, and it must not match * any of the default fieldnames. * @param aGlobal indicates whether to add to the global or project table. */ void AddTemplateFieldName( const TEMPLATE_FIELDNAME& aFieldName, bool aGlobal );
/**
* Function DeleteAllFieldNameTemplates * deletes the entire contents. */ void DeleteAllFieldNameTemplates( bool aGlobal );
/**
* Function GetTemplateFieldName * returns a template fieldnames list for read only access. */ const TEMPLATE_FIELDNAMES& GetTemplateFieldNames();
/**
* Function GetTemplateFieldName * returns a specific list (global or project) for read only access. */ const TEMPLATE_FIELDNAMES& GetTemplateFieldNames( bool aGlobal );
/**
* Function GetFieldName * searches for \a aName in the the template field name list. * * @param aName A wxString object containing the field name to search for. * @return the template fieldname if found; NULL otherwise. */ const TEMPLATE_FIELDNAME* GetFieldName( const wxString& aName );
protected: void resolveTemplates();
};
#endif // _TEMPLATE_FIELDNAME_H_
|