This file describes the coding conventions used in Gwenview. Naming ------ Classes should be named like this: MyClass. The class MyClass should be defined in the myclass.h file and implemented in myclass.cpp. Variables and functions should be named like this: myVariable. Static and member variables are identified by a prefix (s or m), without underscore. int sStaticVariable. class MyClass { int mMemberVariable; void doSomething() { int localVariable; } }; Enum items and consts are spelled like this: const int MY_CONST_VALUE=120; enum AnEnum { ITEM1, ITEM2, ITEM3 }; Namespace --------- All code should be enclosed in the "Gwenview" namespace. Make sure the closing curly bracket of the namespace looks like this : } // namespace This avoids wondering why the curly bracket is here. Code layout ----------- Use tabs, not spaces. The opening brace follows the function/class/for/while. Insert a space after commas and after for/while keywords. void myFunction() { int v1; int v2=12; for (v1=0; v1<10; ++v1) { doSomething(v1, v2); } } class MyClass { }; If the if content is only one line long, you can place it on the same line and omit the curly braces, but DO NOT omit them if you place the content after the if. // Ok if (!data) { return; } // Ok too if (!data) return; // Bad if (!data) return; Include files ------------- Group include files in the Qt, KDE or local groups and sort them alphabetically. When writing the implementation file of a class which is a Q_OBJECT, make sure you include the .moc file, not the .h. // Qt #include <qobject.h> #include <qwidget.h> // KDE #include <kiconview.h> #include <tdelistview.h> // Local #include "aclass.h" #include "myclass.moc"