propertyeditormanager.cpp
来自「这是VCF框架的代码」· C++ 代码 · 共 201 行
CPP
201 行
//PropertyEditorManager.cpp/*Copyright 2000-2004 The VCF Project.Please see License.txt in the top level directorywhere you installed the VCF.*/#include "vcf/ApplicationKit/ApplicationKit.h"#include "vcf/ApplicationKit/PropertyEditor.h"#include "vcf/ApplicationKit/PropertyEditorManager.h"using namespace VCF;PropertyEditorManager::PropertyEditorManager(){}PropertyEditorManager::~PropertyEditorManager(){ propertEditorMap_.clear();}PropertyEditor* PropertyEditorManager::createEditor( const String& className ){ PropertyEditor* result = NULL; std::map<String,Class*>::iterator found = PropertyEditorManager::propertyEditorMgr->propertEditorMap_.find( className ); if ( found != PropertyEditorManager::propertyEditorMgr->propertEditorMap_.end() ){ Class* editorClass = found->second; Object* instance = editorClass->createInstance(); if ( NULL != instance ) { result = dynamic_cast<PropertyEditor*>(instance); if ( NULL != result ) { result->internal_setPropertyType( className ); } else { instance->free(); } } } return result;}bool PropertyEditorManager::registerPropertyEditor( Class* editorClass, const String& className ){ bool result = true; if ( PropertyEditorManager::propertyEditorMgr->propertEditorMap_.find(className) != PropertyEditorManager::propertyEditorMgr->propertEditorMap_.end() ) { result = false; } else { PropertyEditorManager::propertyEditorMgr->propertEditorMap_[className] = editorClass; } return result;}bool PropertyEditorManager::registerPropertyEditor( const String& editorClassName, const String& className ){ Class* editorClass = ClassRegistry::getClass( editorClassName ); if ( NULL != editorClass ) { return PropertyEditorManager::registerPropertyEditor( editorClass, className ); } return false;}void PropertyEditorManager::removePropertyEditor( const String& editorClassName, const String& className ){ Class* editorClass = NULL; std::map<String,Class*>::iterator found = PropertyEditorManager::propertyEditorMgr->propertEditorMap_.find( className ); PropertyEditor* result = NULL; if ( found != PropertyEditorManager::propertyEditorMgr->propertEditorMap_.end() ){ editorClass = found->second; } else { return; //nothing to do } if ( (editorClass->getClassName() == editorClassName) || (editorClass->getID() == editorClassName) ) { //prep to remove dupes if neccessary std::map<String,Class*>::iterator it = PropertyEditorManager::propertyEditorMgr->propertEditorMap_.begin(); std::vector<std::map<String,Class*>::iterator> removeList; while ( it != PropertyEditorManager::propertyEditorMgr->propertEditorMap_.end() ) { if ( it->second == editorClass ) { removeList.push_back( it ); } it ++; } std::vector<std::map<String,Class*>::iterator>::iterator it2 = removeList.begin(); while ( it2 != removeList.end() ) { PropertyEditorManager::propertyEditorMgr->propertEditorMap_.erase( *it2 ); it2 ++; } }}void PropertyEditorManager::initPropertyEditorManager(){ PropertyEditorManager::propertyEditorMgr = new PropertyEditorManager(); PropertyEditorManager::propertyEditorMgr->init();}void PropertyEditorManager::closePropertyEditorManager(){ try{ if ( NULL != PropertyEditorManager::propertyEditorMgr ){ delete PropertyEditorManager::propertyEditorMgr; } PropertyEditorManager::propertyEditorMgr = NULL; } catch(...) { }}/***CVS Log info*$Log$*Revision 1.4 2006/04/07 02:35:24 ddiego*initial checkin of merge from 0.6.9 dev branch.**Revision 1.3.2.2 2005/09/03 16:26:41 ddiego*adjusted function in proeprty editor manager class.**Revision 1.3.2.1 2005/08/28 05:14:17 ddiego*small changes to component editor class.**Revision 1.3 2005/07/09 23:14:55 ddiego*merging in changes from devmain-0-6-7 branch.**Revision 1.2.4.3 2005/03/11 04:28:22 ddiego*added some minor modifications to the PropertyEditor interface.**Revision 1.2.4.2 2005/03/09 05:11:19 ddiego*fixed property editor class.**Revision 1.2.4.1 2005/02/16 05:09:31 ddiego*bunch o bug fixes and enhancements to the property editor and treelist control.**Revision 1.2 2004/08/07 02:49:09 ddiego*merged in the devmain-0-6-5 branch to stable**Revision 1.1.2.2 2004/04/29 03:43:14 marcelloptr*reformatting of source files: macros and csvlog and copyright sections**Revision 1.1.2.1 2004/04/28 00:28:19 ddiego*migration towards new directory structure**Revision 1.11 2003/05/17 20:37:49 ddiego*this is the checkin for the 0.6.1 release - represents the merge over from*the devmain-0-6-0 branch plus a few minor bug fixes**Revision 1.10.2.1 2003/03/12 03:13:18 ddiego*switched all member variable that used the "m_"<name> prefix to* <name>"_" suffix nameing standard.*Also changed all vcf builder files to accomadate this.*Changes were made to the Stream classes to NOT multiple inheritance and to*be a little more correct. Changes include breaking the FileStream into two*distinct classes, one for input and one for output.**Revision 1.10 2003/02/26 04:30:56 ddiego*merge of code in the devmain-0-5-9 branch into the current tree.*most additions are in the area of the current linux port, but the major*addition to this release is the addition of a Condition class (currently*still under development) and the change over to using the Delegate class*exclusively from the older event handler macros.**Revision 1.9.14.1 2003/01/08 00:20:00 marcelloptr*mispellings and newlines at the end of all source files**Revision 1.9 2002/05/09 03:10:46 ddiego*merged over code from development branch devmain-0-5-1a into the main CVS trunk**Revision 1.8.4.1 2002/04/08 20:55:31 zzack*changed include style**Revision 1.8 2002/01/24 01:46:50 ddiego*added a cvs "log" comment to the top of all files in vcf/src and vcf/include*to facilitate change tracking**/
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?