2008-12-02 12:01:29 +01:00
|
|
|
/***************************************************************************
|
|
|
|
|
**
|
|
|
|
|
** This file is part of Qt Creator
|
|
|
|
|
**
|
2009-01-13 19:21:51 +01:00
|
|
|
** Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
|
|
|
|
** Contact: Qt Software Information (qt-info@nokia.com)
|
|
|
|
|
**
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
|
|
|
|
** Non-Open Source Usage
|
|
|
|
|
**
|
2008-12-02 12:01:29 +01:00
|
|
|
** Licensees may use this file in accordance with the Qt Beta Version
|
|
|
|
|
** License Agreement, Agreement version 2.2 provided with the Software or,
|
|
|
|
|
** alternatively, in accordance with the terms contained in a written
|
2008-12-02 14:17:16 +01:00
|
|
|
** agreement between you and Nokia.
|
|
|
|
|
**
|
|
|
|
|
** GNU General Public License Usage
|
|
|
|
|
**
|
2008-12-02 12:01:29 +01:00
|
|
|
** Alternatively, this file may be used under the terms of the GNU General
|
|
|
|
|
** Public License versions 2.0 or 3.0 as published by the Free Software
|
|
|
|
|
** Foundation and appearing in the file LICENSE.GPL included in the packaging
|
|
|
|
|
** of this file. Please review the following information to ensure GNU
|
|
|
|
|
** General Public Licensing requirements will be met:
|
|
|
|
|
**
|
|
|
|
|
** http://www.fsf.org/licensing/licenses/info/GPLv2.html and
|
|
|
|
|
** http://www.gnu.org/copyleft/gpl.html.
|
|
|
|
|
**
|
|
|
|
|
** In addition, as a special exception, Nokia gives you certain additional
|
2008-12-02 14:17:16 +01:00
|
|
|
** rights. These rights are described in the Nokia Qt GPL Exception
|
2008-12-16 17:20:00 +01:00
|
|
|
** version 1.3, included in the file GPL_EXCEPTION.txt in this package.
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
|
|
|
|
***************************************************************************/
|
2008-12-02 15:08:31 +01:00
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
#include "uniqueidmanager.h"
|
|
|
|
|
#include "coreconstants.h"
|
|
|
|
|
|
|
|
|
|
using namespace Core;
|
|
|
|
|
|
|
|
|
|
UniqueIDManager* UniqueIDManager::m_instance = 0;
|
|
|
|
|
|
|
|
|
|
UniqueIDManager::UniqueIDManager()
|
|
|
|
|
{
|
|
|
|
|
m_instance = this;
|
|
|
|
|
m_uniqueIdentifiers.insert(Constants::C_GLOBAL, Constants::C_GLOBAL_ID);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
UniqueIDManager::~UniqueIDManager()
|
|
|
|
|
{
|
|
|
|
|
m_instance = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool UniqueIDManager::hasUniqueIdentifier(const QString &id) const
|
|
|
|
|
{
|
|
|
|
|
return m_uniqueIdentifiers.contains(id);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int UniqueIDManager::uniqueIdentifier(const QString &id)
|
|
|
|
|
{
|
|
|
|
|
if (hasUniqueIdentifier(id))
|
|
|
|
|
return m_uniqueIdentifiers.value(id);
|
|
|
|
|
|
|
|
|
|
int uid = m_uniqueIdentifiers.count() + 1;
|
|
|
|
|
m_uniqueIdentifiers.insert(id, uid);
|
|
|
|
|
return uid;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QString UniqueIDManager::stringForUniqueIdentifier(int uid)
|
|
|
|
|
{
|
|
|
|
|
return m_uniqueIdentifiers.key(uid);
|
|
|
|
|
}
|