summaryrefslogtreecommitdiffstats
path: root/doc/platform/Mainpage.dox
blob: 29f6deb07ab0ba17a6dca94d7e6c7dc5e91d32bf (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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
/** \file Mainpage.dox
    \brief The main page of the doxygen generated %API Documentation
*/

/**
\mainpage The KDevelop Platform %API %Documentation


KDevelop Platform is set of libraries and tools that are used to build IDEs (Integrated Development Environments),
applications similar to IDEs (web development enviroment, text editors for programmers and designers, etc.)
and/or IDE plugins for all possible purposes.

Platform provides:
- the plugin architecture (interfaces);
- the common support libraries;
- the generic shell with plugin profiles support.
.

\section intro Introduction

This document is targeted at all those that want to build their own IDE or improve KDevelop's source code.
If you are instead looking for a user manual, just go to the help menu of your KDevelop and select KDevelop handbook.
This documentation contains the KDevelop Platform online class reference for the current
development version of KDevelop.  Additionally, you
can subscribe or read the <a href="http://www.kdevelop.org/index.html?filename=mailinglist.html">mailing list</a> for any additions and/or
modifications to the Platform %API.

An on-line, updated every 24H, html version of this documentation can be found at: http://www.kdevelop.org/HEAD/doc/platform/html/index.html

You can also download a local browseable copy form http://www.kdevelop.org/HEAD/doc/platform/kdevplatformdoc.tar.bz2 . It gets updated every single day too.

More information about the KDevelop Platform architecture in form of tutorials, Wikis, HOWTOs,
and FAQs can be found at
the <a href="http://www.kdevelop.org">KDevelop website</a>.

Quick overviews of the architecture can also be found in the issues of <a href="http://www.kdevelop.org/doc/tehcnotes">
KDevelop Technotes</a>.

\section platformapi Platform Libraries API

- <a href="kdevinterfaces/html/index.html"><b>Interfaces Library</b></a>
   (<a href="kdevinterfaces/html/classes.html">classes</a>)\n
   <i>Interfaces and classes that form TDevelop plugin architecture.</i>
- <a href="kdevextensions/html/index.html"><b>Extension Interfaces Library</b></a>
   (<a href="kdevextensions/html/classes.html">classes</a>)\n
   <i>Extension interfaces used by TDevelop plugin architecture.</i>
- <a href="kdevutil/html/index.html"><b>Utility Library</b></a>
   (<a href="kdevutil/html/classes.html">classes</a>)\n
   <i>Utility classes for the KDevelop architecture.</i>
- <a href="kdevextras/html/index.html"><b>Extra Interfaces Library</b></a>
   (<a href="kdevextras/html/classes.html">classes</a>)\n
   <i>Extra interfaces that are not the part of TDevelop plugin architecture
   but that can be implemented by extra plugins or "plugins for plugins".</i>
- <a href="kdevwidgets/html/index.html"><b>Widgets Library</b></a>
   (<a href="kdevwidgets/html/classes.html">classes</a>)\n
   <i>A collection of widgets.</i>
- <a href="propeditor/html/index.html"><b>Property Editing Library</b></a>
   (<a href="propeditor/html/classes.html">classes</a>)\n
   <i>A collection of facilities to store and edit the properties of various objects.</i>
- <a href="kdevcatalog/html/index.html"><b>Catalog Library</b></a>
   (<a href="kdevcatalog/html/classes.html">classes</a>)\n
   <i>The persistant symbol store library working with BerkeleyDb backend.</i>
.

\section designerapi GUI Designer Integration API

- <a href="external/html/index.html"><b>KInterfaceDesigner Library</b></a>
   (<a href="external/html/classes.html">classes</a>)\n
   <i>KInterfaceDesigner classes and interfaces which form the core of GUI Designer integration framework.</i>
- <a href="designer_integration/html/index.html"><b>Designer Integration Support Library</b></a>
   (<a href="designer_integration/html/classes.html">classes</a>)\n
   <i>The base classes to implement GUI designer integration in language support plugins.</i>
.

\section pluginsapi Platform Plugins API

- <a href="kdevdocinterfaces/html/index.html"><b>Documentation Part Interfaces Library</b></a>
   (<a href="kdevdocinterfaces/html/classes.html">classes</a>)\n
   <i>Interfaces to implement KDevelop documentation plugins.</i>
.

\section langapi Programming Language Support API

- <a href="kdevlanginterfaces/html/index.html"><b>Language Support Interfaces Library</b></a>
   (<a href="kdevlanginterfaces/html/classes.html">classes</a>)\n
   <i>Interfaces for KDevelop language support facilities.</i>
- <a href="kdevlangdebugger/html/index.html"><b>Debugger Support Library</b></a>
   (<a href="kdevlangdebugger/html/classes.html">classes</a>)\n
   <i>Classes to implement debugger support for a programming language.</i>
.

\section buildtoolapi Buildtool Support API

- <a href="kdevbtbase/html/index.html"><b>Buildtool Base Library</b></a>
   (<a href="kdevbtbase/html/classes.html">classes</a>)\n
   <i>Base classes for KDevelop builtool support plugins.</i>
- <a href="kdevpminterfaces/html/index.html"><b>Project Manager Interfaces Library</b></a>
   (<a href="kdevpminterfaces/html/classes.html">classes</a>)\n
   <i>Interfaces to implement plugins for the KDevelop generic project manager.</i>
- <a href="kdevbtwidgets/html/index.html"><b>Buildtool Widgets Library</b></a>
   (<a href="kdevbtwidgets/html/classes.html">classes</a>)\n
   <i>Widgets commonly used in buildtool support plugins.</i>
- <a href="kdevparserautotools/html/index.html"><b>Autotools parser Library</b></a>
   (<a href="kdevparserautotools/html/classes.html">classes</a>)\n
   <i>Parser for Autotools based support plugins.</i>
- <a href="kdevparserqmake/html/index.html"><b>QMake parser Library</b></a>
   (<a href="kdevparserqmake/html/classes.html">classes</a>)\n
   <i>Parser for QMake based support plugins.</i>
.

\section shellapi Shell API

- <a href="kdevshellsrc/html/index.html"><b>Generic Shell</b></a>
   (<a href="kdevshellsrc/html/classes.html">classes</a>)\n
   <i>The Shell - a profile-based implementation of TDevelop plugin architecture.</i>
- <a href="kdevprofileslib/html/index.html"><b>Shell Profiles Library</b></a>
   (<a href="kdevprofileslib/html/classes.html">classes</a>)\n
   <i>Plugin profiles implementation for TDevelop shell.</i>
.

\section PlannedTasks Planned tasks

Here is a priority ordered list:
  -# fix the dispersed fixme
  -# <a href="http://bugs.kde.org/buglist.cgi?product=tdevelop&bug_status=UNCONFIRMED&bug_status=NEW&bug_status=ASSIGNED&bug_status=REOPENED&order=bugs.bug_id">reported bugs in bugzilla database</a>
  -# fix the dispersed todo all over the code.
  .

\section howTobuildAPIlocalcopy How to build a local copy of this documentation

This documentation is large and changes with every cvs commit, therefore is not available for download.
To build your local copy of this documentation you need to fetch KDevelop sources and 
if you have doxygen >= 1.3.4 and (optionally) PHP >= 4.10 plus a local running webserver then
- make apidox
- make install-apidox (as root)
.

The advantage of the webserver is that you'll get a search engine in your documentation if you read your
documentation using your local webserver.

\section License

Permission is granted to copy, distribute and/or modify this document under
the terms of the GNU Free %Documentation License, Version 1.2 or any later
version published by the Free Software Foundation; For details see
http://www.gnu.org/copyleft/fdl.html .

*/