KDevelop/CodingStyle: Difference between revisions
< KDevelop
No edit summary |
m (Change location of coding style article) |
||
(2 intermediate revisions by one other user not shown) | |||
Line 1: | Line 1: | ||
The current KDevelop code base is very inconsistent when it comes to the coding style. So please adhere to the file's coding style you are working on / patching. | The current KDevelop code base is very inconsistent when it comes to the coding style. So please adhere to the file's coding style you are working on / patching. | ||
For new files / projects / plugins, please use the [[Policies/ | For new files / projects / plugins, please use the [[Policies/Frameworks_Coding_Style]] guidelines. Here are a few special additions: | ||
== QObject and Access Modifiers == | == QObject and Access Modifiers == |
Latest revision as of 09:50, 31 October 2019
The current KDevelop code base is very inconsistent when it comes to the coding style. So please adhere to the file's coding style you are working on / patching.
For new files / projects / plugins, please use the Policies/Frameworks_Coding_Style guidelines. Here are a few special additions:
QObject and Access Modifiers
// wrong
class Foo : public QObject {
Q_OBJECT
public:
Foo();
private:
int bla;
};
// correct foo.h
class Foo: public QObject
{
Q_OBJECT
public:
Foo();
private:
int m_bla;
};
Class Initialization
// wrong foo.h
class Foo : public Bar {
public:
Foo(int i, int j) : Bar(i), bla(j) { /* do stuff */ }
private:
int bla;
};
// correct foo.h
class Foo: public Bar
{
public:
Foo(int i, int j);
private:
int m_bla;
};
// foo.cpp
Foo::Foo(int i, int j)
: Bar(i)
, m_bla(j)
{
// do stuff
}
Using Namespaces
Never add a "using namespace ..." to a header. Do use that though in every .cpp file , esp. for the KDevelop namespace. Public API should always be in the KDevelop namespace.