Ignore:
Timestamp:
Feb 11, 2010, 11:19:06 PM (16 years ago)
Author:
Dmitry A. Kuminov
Message:

trunk: Merged in qt 4.6.1 sources.

Location:
trunk
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk

  • trunk/src/gui/itemviews/qitemeditorfactory.cpp

    r2 r561  
    22**
    33** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
    4 ** Contact: Qt Software Information ([email protected])
     4** All rights reserved.
     5** Contact: Nokia Corporation ([email protected])
    56**
    67** This file is part of the QtGui module of the Qt Toolkit.
     
    2122** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
    2223**
    23 ** In addition, as a special exception, Nokia gives you certain
    24 ** additional rights. These rights are described in the Nokia Qt LGPL
    25 ** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
    26 ** package.
     24** In addition, as a special exception, Nokia gives you certain additional
     25** rights.  These rights are described in the Nokia Qt LGPL Exception
     26** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
    2727**
    2828** GNU General Public License Usage
     
    3434** met: http://www.gnu.org/copyleft/gpl.html.
    3535**
    36 ** If you are unsure which license is appropriate for your use, please
    37 ** contact the sales department at qt-sales@nokia.com.
     36** If you
     37** @nokia.com.
    3838** $QT_END_LICENSE$
    3939**
     
    159159QItemEditorFactory::~QItemEditorFactory()
    160160{
     161
     162
     163
     164
    161165}
    162166
     
    171175void QItemEditorFactory::registerEditor(QVariant::Type type, QItemEditorCreatorBase *creator)
    172176{
    173    delete creatorMap.value(type, 0);
    174    creatorMap[type] = creator;
     177    QHash<QVariant::Type, QItemEditorCreatorBase *>::iterator it = creatorMap.find(type);
     178    if (it != creatorMap.end()) {
     179        QItemEditorCreatorBase *oldCreator = it.value();
     180        Q_ASSERT(oldCreator);
     181        creatorMap.erase(it);
     182        if (!creatorMap.values().contains(oldCreator))
     183            delete oldCreator; // if it is no more in use we can delete it
     184    }
     185
     186    creatorMap[type] = creator;
    175187}
    176188
Note: See TracChangeset for help on using the changeset viewer.