summaryrefslogtreecommitdiffstats
path: root/src/kvilib/ext/kvi_parameterlist.h
blob: 51c573e0c7fdeac04cd2fd9c47855c9639f71547 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
#ifndef _KVI_PARAMETERLIST_H_
#define _KVI_PARAMETERLIST_H_

//
//   File : kvi_parameterlist.h
//   Creation date : Tue Sep 12 2000 18:00:01 by Szymon Stefanek
//
//   This file is part of the KVirc irc client distribution
//   Copyright (C) 1999-2000 Szymon Stefanek (pragma at kvirc dot net)
//
//   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 opinion) 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, write to the Free Software Foundation,
//   Inc. ,51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
//

#include "kvi_settings.h"
#include "kvi_heapobject.h"
#include "kvi_string.h"

#include "kvi_pointerlist.h"
#include <qrect.h>
#include <qpoint.h>
#include <qsize.h>

class KVILIB_API KviParameterList : public KviPointerList<KviStr>, public KviHeapObject
{
public:
	KviParameterList();
	KviParameterList(KviStr *p1);
	KviParameterList(KviStr *p1,KviStr *p2);
	KviParameterList(KviStr *p1,KviStr *p2,KviStr *p3);
	KviParameterList(KviStr *p1,KviStr *p2,KviStr *p3,KviStr *p4);
	KviParameterList(KviStr *p1,KviStr *p2,KviStr *p3,KviStr *p4,KviStr *p5);
	KviParameterList(KviStr *p1,KviStr *p2,KviStr *p3,KviStr *p4,KviStr *p5,KviStr *p6);
	KviParameterList(KviStr *p1,KviStr *p2,KviStr *p3,KviStr *p4,KviStr *p5,KviStr *p6,KviStr *p7);
	KviParameterList(const char * paramBuffer);
	virtual ~KviParameterList();
private:
	KviStr m_szEmpty;
public:
	void         init(){ (void)first(); };
	// These functions have to be called when the
	// current() points to the FIRST item that has
	// to be interpreted as Bool,Int,UInt,Rect etc...
	// At the call exit the current() points
	// to the first item that was NOT used by the call
	bool         getBool();
	int          getInt(bool * bOk = 0);
	unsigned int getUInt(bool * bOk = 0);
	QRect        getRect(bool * bOk = 0);
	QPoint       getPoint(bool * bOk = 0);
	QSize        getSize(bool * bOk = 0);
	KviStr *     safeFirst();
	KviStr *     safeNext();
	const char * safeFirstParam(){ return safeFirst()->ptr(); };
	const char * safeNextParam(){ return safeNext()->ptr(); };

};



#endif //_KVI_PARAMETERLIST_H_