1
#ifndef _KVI_KVS_ALIASMANAGER_H_
2
#define _KVI_KVS_ALIASMANAGER_H_
3
//=============================================================================
5
// File : kvi_kvs_aliasmanager.h
6
// Creation date : Mon 15 Dec 2003 02:11:41 by Szymon Stefanek
8
// This file is part of the KVIrc IRC client distribution
9
// Copyright (C) 2003-2008 Szymon Stefanek <pragma at kvirc dot net>
11
// This program is FREE software. You can redistribute it and/or
12
// modify it under the terms of the GNU General Public License
13
// as published by the Free Software Foundation; either version 2
14
// of the License, or (at your opinion) any later version.
16
// This program is distributed in the HOPE that it will be USEFUL,
17
// but WITHOUT ANY WARRANTY; without even the implied warranty of
18
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
19
// See the GNU General Public License for more details.
21
// You should have received a copy of the GNU General Public License
22
// along with this program. If not, write to the Free Software Foundation,
23
// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
25
//=============================================================================
27
#include "kvi_settings.h"
28
#include "kvi_pointerhashtable.h"
30
#include "kvi_pointerlist.h"
31
#include "kvi_qstring.h"
33
#include "kvi_kvs_script.h"
35
class KVIRC_API KviKvsAliasManager : public QObject
38
protected: // it only can be created and destroyed by KviKvsAliasManager::init()/done()
40
~KviKvsAliasManager();
42
KviPointerHashTable<QString,KviKvsScript> * m_pAliasDict;
43
static KviKvsAliasManager * m_pAliasManager;
45
static KviKvsAliasManager * instance()
46
{ return m_pAliasManager; };
47
static void init(); // called by KviKvs::init()
48
static void done(); // called by KviKvs::done()
50
KviPointerHashTable<QString,KviKvsScript> * aliasDict(){ return m_pAliasDict; };
51
const KviKvsScript * lookup(const QString & szName)
52
{ return m_pAliasDict->find(szName); };
53
void add(const QString &szName,KviKvsScript * pAlias);
54
bool remove(const QString & szName)
55
{ return m_pAliasDict->remove(szName); };
57
{ m_pAliasDict->clear(); };
59
void save(const QString & filename);
60
void load(const QString & filename);
62
void completeCommand(const QString &word,KviPointerList<QString> * matches);
65
void aliasRefresh(const QString &);
67
// namespaces are handled completly in the editing!
68
#endif //!_KVI_KVS_ALIASMANAGER_H_