1 | /*! |
---|
2 | \page codingrules Coding Rules (Mostly inherited from IT++) |
---|
3 | |
---|
4 | In the following sections we describe the naming conventions which are |
---|
5 | used for files, classes, structures, local variables, and global variables. |
---|
6 | |
---|
7 | |
---|
8 | \section cr_variables Default Naming Rules for Variables |
---|
9 | |
---|
10 | Generally, variables are named using lower-case letters and words are separated using |
---|
11 | under-score. But there are many exceptions, for instance abbreviations or classical |
---|
12 | matematical notations. Therefore, coding rules for variables are quite free. Examples: |
---|
13 | |
---|
14 | <ul> |
---|
15 | <li> \c `FFT_size' </li> |
---|
16 | <li> \c `initial_RV' </li> |
---|
17 | <li> \c `my_variable' </li> |
---|
18 | </ul> |
---|
19 | |
---|
20 | \section cr_files Default Naming Rules for Files |
---|
21 | |
---|
22 | Files are named using lower-case letters and words are separated using |
---|
23 | under-score. If an abbreviation is inevitable within file name, it is written with |
---|
24 | lower-case letters. |
---|
25 | |
---|
26 | Source files are named using <tt>`.cpp'</tt> suffix, whereas header |
---|
27 | files end with <tt>`.h'</tt> extension. Examples: |
---|
28 | |
---|
29 | <ul> |
---|
30 | <li> <tt>`my_file.h'</tt> </li> |
---|
31 | <li> <tt>`user_info.cpp'</tt> </li> |
---|
32 | </ul> |
---|
33 | |
---|
34 | \section cr_file_templates Form of the source files |
---|
35 | |
---|
36 | For all the library classes, both header file `[filename].h' and source file |
---|
37 | `[filename].cpp' should be implemented. And the following few rules should be |
---|
38 | respected |
---|
39 | |
---|
40 | <ul> |
---|
41 | |
---|
42 | <li> if possible, each `#inline ... ' dircetive should be located within the `.h' |
---|
43 | file, one obvious exception is the case of `#inline [filename].h' written in |
---|
44 | `[filename].cpp' </li> |
---|
45 | |
---|
46 | <li> firstly, system headers should be included (i.e. those with brackets |
---|
47 | `#include <header_name>'), other headers (like `#include my_header_name.h') |
---|
48 | should follow (this rule leads to the faster search of an error on some |
---|
49 | compilators) </li> |
---|
50 | |
---|
51 | <li> source code itself should be placed in the `.cpp' file, `.h' should |
---|
52 | contains only class declarations and documentation (this rule has a few exceptions like |
---|
53 | inline functions, templates and some extremely short function bodies)</li> |
---|
54 | |
---|
55 | </ul> |
---|
56 | |
---|
57 | Rules considering formatting of the source code itself are stored in the |
---|
58 | file \system\astylerc, which is a configuration file for code formating |
---|
59 | utility named ASTYLE. To apply them, download the proper version from |
---|
60 | its web page http://astyle.sourceforge.net/ |
---|
61 | |
---|
62 | \section cr_functions Default Naming Rules for Functions |
---|
63 | |
---|
64 | Function names are named using lower-case letters and words are |
---|
65 | separated using under-score. Abbreviations, when used in function |
---|
66 | names, are also written with lower-case letters. This rule applies |
---|
67 | both to stand-alone functions as well as to member functions of |
---|
68 | classes. Example: |
---|
69 | |
---|
70 | <ul> |
---|
71 | <li> <tt>int my_function_name(int a, int b)</tt> </li> |
---|
72 | </ul> |
---|
73 | |
---|
74 | |
---|
75 | \section cr_specialfunctions Convention for sensitive functions |
---|
76 | |
---|
77 | For efficiency, some functions may return pointers to internal variables. |
---|
78 | Such functionality is indicated by underscore as the first letter in the |
---|
79 | the name. |
---|
80 | |
---|
81 | <ul> |
---|
82 | <li> <tt>mat* _internal_matrix()</tt> </li> |
---|
83 | </ul> |
---|
84 | |
---|
85 | |
---|
86 | \section cr_classes Default Naming Rules for Classes and Structures |
---|
87 | |
---|
88 | Each new word in a class or structure name should always start with a |
---|
89 | capital letter and the words should not be separated. Abbreviations are |
---|
90 | written with capital letters. Examples: |
---|
91 | |
---|
92 | <ul> |
---|
93 | <li> \c `MyClassName' </li> |
---|
94 | <li> \c `MyStructName' </li> |
---|
95 | <li> \c `OFDM' </li> |
---|
96 | </ul> |
---|
97 | |
---|
98 | |
---|
99 | \section cr_classes_functionality Default Functionality of Classes |
---|
100 | |
---|
101 | All classes that are configured by input parameters should include: |
---|
102 | |
---|
103 | <ul> |
---|
104 | <li> default empty constructor </li> |
---|
105 | <li> one or more additional constructor(s) that takes input parameters |
---|
106 | and initializes the class instance </li> |
---|
107 | <li> setup function, preferably named \c `setup' or \c |
---|
108 | `set_parameters' </li> |
---|
109 | </ul> |
---|
110 | |
---|
111 | Explicit destructor functions are not required, unless they are |
---|
112 | needed. It shall not be possible to use any of the other member |
---|
113 | functions unless the class has been properly initiated with the input |
---|
114 | parameters. |
---|
115 | |
---|
116 | */ |
---|