summaryrefslogtreecommitdiffstats
path: root/languages/cpp/doxydoc.h
blob: aca424b24f8314fa3a23aac1ed06831acf60291c (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
/***************************************************************************
*   Copyright (C) 2003 by Jonas B. Jacobi                                 *
*   j.jacobi@gmx.de                                                       *
*                                                                         *
*   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 option) any later version.                                   *
***************************************************************************/
#ifndef DOXYDOC_H
#define DOXYDOC_H

#include <qstring.h>
#include <qdom.h>
#include <qdir.h>
#include <qfile.h>
#include <list>

/**
This class is used for getting the description on functions, stored in xml files, which are created by Doxygen
@author Jonas B. Jacobi
@version 0.1
*/
class DoxyDoc
{
public:
	/**
		Constructs a new DoxyDoc object.
		@param dir all directories, which should be searched for files containing the Doxygen-documentation.
	*/
	DoxyDoc( const QStringList& dir );
	~DoxyDoc()
	{}
	;
	/**
		Get the documentation referring to a special function, therefor most parts of the functions signature have to be provided
		@param scope Scope of the function (e.g. name of class, it is member of, namespace etc ...)
		@param name Name of the function(just the name, no '(' etc. )
		@param type Return-type of the function
		@param arguments String containing the arguments of the function, separated by commas and _without_ the argument names
	*/
	QString functionDescription( const QString& scope, const QString& name, const QString& type, const QString& arguments );
	/*not implemented yet, maybe later, if they are useful
	QString classDescription();
	QString enumDescription();
	QString namespaceDescription();
	QString memberVarDescription();
	*/
private:
	static void formatType( QString& type );
	std::list<QDir> m_dirs;
	//used for temporary storing/performance reasons
	QFile m_file;
	QDomNodeList m_list;
};

#endif 
// kate: indent-mode csands; tab-width 4;