KDevelop/CodingStyle: Difference between revisions
Appearance
< KDevelop
Created page with "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 /..." |
m Change location of coding style article |
||
(5 intermediate revisions by 2 users 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 == | |||
<syntaxhighlight lang="cpp-qt"> | |||
// 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; | |||
}; | |||
</syntaxhighlight> | |||
== Class Initialization == | |||
<syntaxhighlight lang="cpp-qt"> | |||
// 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 | |||
} | |||
</syntaxhighlight> | |||
== 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. |
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.