Kdevelop4/Manual/Meet KDevelop: Difference between revisions

From KDE Wiki Sandbox
No edit summary
m (moved Kdevelop4/Manual/What is KDevelop? to Kdevelop4/Manual/Meet KDevelop: "?" causes problem for off-line translation)
 
(10 intermediate revisions by 4 users not shown)
Line 1: Line 1:
[http://www.KDevelop.org KDevelop] is a modern integrated development
<languages />
environment (IDE) for C++ (and other languages) that is part of the
<translate>
[http://www.kde.org KDE desktop environment] project. As such it runs on Linux
(even if you run one of the other desktops, such as GNOME) but it is
also available for most other variants of Unix as well as on Windows.


KDevelop offers all amenities of modern IDEs. For large projects and applications, the most important feature is that KDevelop
==What is KDevelop?== <!--T:1-->
'''understands C++''': it parses the entire source base and remembers which classes
 
have which member functions, where variables are defined, what their types are, and many other things about your code. For example, let's say one of your project's header files declares a class
<!--T:2-->
<code><pre>
[http://www.KDevelop.org KDevelop] is a modern integrated development environment (IDE) for C++ (and other languages) that is one of many [http://www.kde.org/applications/ KDE applications]. As such it runs on Linux (even if you run one of the other desktops, such as GNOME) but it is also available for most other variants of Unix and for Windows as well.
 
<!--T:3-->
'''KDevelop''' offers all amenities of modern IDEs. For large projects and applications, the most important feature is that '''KDevelop''' ''understands C++'': it parses the entire source base and remembers which classes have which member functions, where variables are defined, what their types are, and many other things about your code. For example, let's say one of your project's header files declares a class
 
<!--T:4-->
{{Input|<syntaxhighlight lang="cpp">
class Car {
class Car {
   // ...
   // ...
Line 14: Line 17:
     std::string get_color () const;
     std::string get_color () const;
};
};
</pre></code>
</syntaxhighlight>}}
 
<!--T:5-->
and later on in your program you have
and later on in your program you have
<code><pre>
 
<!--T:6-->
{{Input|<syntaxhighlight lang="cpp">
Car my_ride;
Car my_ride;
// ...do something with this variable...
// ...do something with this variable...
std::string color = my_ride.ge
std::string color = my_ride.ge
</pre></code>
</syntaxhighlight>}}
it will have remembered that <code>my_ride</code> in the last line is a variable of type
 
<code>Car</code> and offer you to complete <code>ge</code> as
<!--T:7-->
<code>get_color()</code> since this is the only member function of the
it will have remembered that <code>my_ride</code> in the last line is a variable of type <code>Car</code> and offer you to complete <code>ge</code> as <code>get_color()</code> since this is the only member function of the <code>Car</code> class that starts like this. Instead of continuing to type you just hit <keycap>Enter</keycap> to get the full word; this saves typing, avoids typos, and doesn't require you to remember the exact names of the hundreds or thousands of functions and classes that make up large projects.  
<code>Car</code> class that starts like this. Instead of continuing to type
you just hit enter to get the full word; this saves typing, avoids typos, and
doesn't require you to remember the exact names of the hundreds or thousands of functions and classes that make up large projects.  


<!--T:8-->
As a second example, assume you have code like this:
As a second example, assume you have code like this:
<code><pre>
 
<!--T:9-->
<!--}}-->{{Input|<syntaxhighlight lang="cpp">
double foo ()
double foo ()
{
{
Line 36: Line 43:
}
}


<!--T:10-->
double bar ()
double bar ()
{
{
Line 41: Line 49:
   return var * var * var;
   return var * var * var;
}
}
</pre></code>
</syntaxhighlight>}}<!--{{-->
If you hover the mouse over the symbol <code>var</code> in function <code>bar</code> you get the option to see all uses of this symbol. Clicking on it will only show you the uses of this variable in function <code>bar</code> because KDevelop understands that the variable <code>var</code> in function <code>foo</code> has nothing to do with it. Similarly, right clicking on the variable name allows you to rename the variable; doing so will only touch the variable in <code>bar</code> but not the one with the same name in <code>foo</code>.
 
<!--T:11-->
If you hover the mouse over the symbol <code>var</code> in function <code>bar</code> you get the option to see all uses of this symbol. Clicking on it will only show you the uses of this variable in function <code>bar</code> because '''KDevelop''' understands that the variable <code>var</code> in function <code>foo</code> has nothing to do with it. Similarly, right clicking on the variable name allows you to rename the variable; doing so will only touch the variable in <code>bar</code> but not the one with the same name in <code>foo</code>.
 
<!--T:12-->
But '''KDevelop''' is not just an intelligent code editor; there are other things '''KDevelop''' does well. Obviously, it highlights the source code in different colors; it has a customizable indenter; it has an integrated interface to the GNU debugger '''gdb'''; it can show you the documentation for a function if you hover the mouse over a use of this function; it can deal with different kinds of build environments and compilers (e.g. with '''make''' and '''cmake'''-based project), and many other neat things that are discussed in this manual.
 
<!--T:13-->
{{Prevnext2
| nextpage=Special:MyLanguage/KDevelop4/Manual/Sessions_and_projects
| nexttext=Sessions and projects
| index=Special:myLanguage/KDevelop4/Manual | indextext=Back to Menu
}}


But KDevelop is not just an intelligent code editor;
<!--T:14-->
there are other things KDevelop does well. Obviously, it highlights the source
[[Category:Development]]
code in different colors; it has a customizable indenter; it has an integrated
</translate>
interface to the GNU debugger gdb; it can show you the documentation for a
function if you hover the mouse over a use of this function; it can deal with different kinds of build environments and compilers (e.g. with <code>make</code> and <code>cmake</code> based project), and many other
neat things that are discussed in this manual.

Latest revision as of 18:17, 3 June 2011

What is KDevelop?

KDevelop is a modern integrated development environment (IDE) for C++ (and other languages) that is one of many KDE applications. As such it runs on Linux (even if you run one of the other desktops, such as GNOME) but it is also available for most other variants of Unix and for Windows as well.

KDevelop offers all amenities of modern IDEs. For large projects and applications, the most important feature is that KDevelop understands C++: it parses the entire source base and remembers which classes have which member functions, where variables are defined, what their types are, and many other things about your code. For example, let's say one of your project's header files declares a class

class Car {
  // ...
  public:
    std::string get_color () const;
};

and later on in your program you have

Car my_ride;
// ...do something with this variable...
std::string color = my_ride.ge

it will have remembered that my_ride in the last line is a variable of type Car and offer you to complete ge as get_color() since this is the only member function of the Car class that starts like this. Instead of continuing to type you just hit Enter to get the full word; this saves typing, avoids typos, and doesn't require you to remember the exact names of the hundreds or thousands of functions and classes that make up large projects.

As a second example, assume you have code like this:

double foo ()
{
  double var = my_func();
  return var * var;
}

double bar ()
{
  double var = my_func();
  return var * var * var;
}

If you hover the mouse over the symbol var in function bar you get the option to see all uses of this symbol. Clicking on it will only show you the uses of this variable in function bar because KDevelop understands that the variable var in function foo has nothing to do with it. Similarly, right clicking on the variable name allows you to rename the variable; doing so will only touch the variable in bar but not the one with the same name in foo.

But KDevelop is not just an intelligent code editor; there are other things KDevelop does well. Obviously, it highlights the source code in different colors; it has a customizable indenter; it has an integrated interface to the GNU debugger gdb; it can show you the documentation for a function if you hover the mouse over a use of this function; it can deal with different kinds of build environments and compilers (e.g. with make and cmake-based project), and many other neat things that are discussed in this manual.