| 
									
										
										
										
											2014-02-27 07:57:22 -08:00
										 |  |  | Coding Style | 
					
						
							|  |  |  | ============ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 09:08:46 +02:00
										 |  |  | Here are some of the basics that we are trying to enforce for our coding style | 
					
						
							|  |  |  | and conventions. The existing code (as of the commit that adds these lines) is | 
					
						
							|  |  |  | not yet fully consistent to these rules, but following these rules will make | 
					
						
							| 
									
										
										
										
											2014-02-27 07:57:22 -08:00
										 |  |  | sure that no one yells at you about your patches. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | We have a script that can be used to reformat code to be reasonably close | 
					
						
							|  |  |  | to these rules; it's in scripts/whitespace.pl - this script requires | 
					
						
							|  |  |  | clang-format to be installed (which sadly isn't installed by default on | 
					
						
							|  |  |  | any of our platforms; even on Mac where clang is the default compiler). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | At the end of this file are some ideas for your .emacs file (if that's | 
					
						
							|  |  |  | your editor of choice) as well as for QtCreator. If you have settings for | 
					
						
							|  |  |  | other editors that implement this coding style, please add them here. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Basic rules | 
					
						
							|  |  |  | =========== | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-16 11:50:56 +07:00
										 |  |  | - all indentation is tabs (set to 8 char) with the exception of | 
					
						
							| 
									
										
										
										
											2018-04-09 07:59:33 +02:00
										 |  |  |   continuation lines that are aligned with tabs and then spaces | 
					
						
							| 
									
										
										
										
											2014-01-16 11:50:56 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | - all keywords followed by a '(' have a space in between | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (condition) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (i = 0; i < 5; i++) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - function calls do NOT have a space between their name and argument | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	i = some_function(argument); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - usually there is no space on the inside of parenthesis (see examples | 
					
						
							|  |  |  |   above) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - function / method implementations have their opening curly braces in | 
					
						
							|  |  |  |   column 1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - all other opening curly braces follow at the end of the line, with a | 
					
						
							|  |  |  |   space separating them: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (condition) { | 
					
						
							|  |  |  | 		dosomething(); | 
					
						
							| 
									
										
										
										
											2015-03-18 02:22:32 +02:00
										 |  |  | 		dosomethingelse(); | 
					
						
							| 
									
										
										
										
											2014-01-16 11:50:56 +07:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - both sides of an if / else clause either use or do not use curly braces: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (condition) | 
					
						
							|  |  |  | 		i = 4; | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		j = 6; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (condition) { | 
					
						
							|  |  |  | 		i = 6; | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		i = 4; | 
					
						
							|  |  |  | 		j = 6; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - use space to make visual separation easier | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	a = b + 3 + e / 4; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - continuation lines have the operator / comma at the end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-09 07:59:33 +02:00
										 |  |  | 	if (very_long_condition_1 || | 
					
						
							| 
									
										
										
										
											2014-01-16 11:50:56 +07:00
										 |  |  | 	    condition_2) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	b = a + (c + d + | 
					
						
							|  |  |  | 		 f + z); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-22 08:25:14 -08:00
										 |  |  | - in a C++ constructor initialization list, the colon is on the same line and | 
					
						
							|  |  |  |   continuation lines are aligned as the rule above: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-23 05:54:16 -07:00
										 |  |  | 	ClassName::ClassName() : x(1), | 
					
						
							|  |  |  | 		y(2), | 
					
						
							|  |  |  | 		z(3) | 
					
						
							| 
									
										
										
										
											2014-01-22 08:25:14 -08:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-16 11:50:56 +07:00
										 |  |  | - unfortunate inconsistency: | 
					
						
							|  |  |  |   -- C code usually uses underscores to structure names | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	variable_in_C | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   -- C++ code usually uses camelCase | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	variableInCPlusPlus | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   where the two meet, use your best judgment and go for best consistency | 
					
						
							|  |  |  |   (i.e., where does the variable "originate") | 
					
						
							| 
									
										
										
										
											2014-01-16 12:58:06 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | - switch statements with blocks are a little bit special (to avoid indenting | 
					
						
							|  |  |  |   too far) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	switch (foo) { | 
					
						
							|  |  |  | 	case FIRST: | 
					
						
							|  |  |  | 		whatever(); | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 	case SECOND: { | 
					
						
							|  |  |  | 		int i; | 
					
						
							|  |  |  | 		for (i = 0; i < 5; i++) | 
					
						
							|  |  |  | 			do_something(i); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-01-22 08:25:14 -08:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-02-27 07:57:22 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 09:08:46 +02:00
										 |  |  | Coding conventions | 
					
						
							|  |  |  | ================== | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-16 09:16:47 -07:00
										 |  |  | - variable declarations | 
					
						
							|  |  |  |   in C code we really like them to be at the beginning of a code block, | 
					
						
							|  |  |  |   not interspersed in the middle. | 
					
						
							|  |  |  |   in C++ we are a bit less strict about this - but still, try not to go | 
					
						
							|  |  |  |   crazy. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-17 09:23:53 +00:00
										 |  |  | - text strings | 
					
						
							|  |  |  |   The default language of subsurface is US English so please use US English | 
					
						
							|  |  |  |   spelling and terminology. | 
					
						
							|  |  |  |   Where at all possible strings should be passed to the tr() function to enable | 
					
						
							|  |  |  |   translation into other languages. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   -- like this | 
					
						
							|  |  |  | 	QString msgTitle = tr("Submit user survey."); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   -- rather than | 
					
						
							|  |  |  | 	QString msgTitle = "Submit user survey."; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - UI text style | 
					
						
							| 
									
										
										
										
											2018-04-09 07:59:33 +02:00
										 |  |  |   These guidelines are designed to ensure consistency in presentation within | 
					
						
							| 
									
										
										
										
											2014-12-17 09:23:53 +00:00
										 |  |  |   Subsurface. | 
					
						
							| 
									
										
										
										
											2018-04-09 07:59:33 +02:00
										 |  |  |   Only the first word of multi-word text strings should be capitalized unless | 
					
						
							|  |  |  |   a word would normally be capitalized mid-sentence, like Africa. This applies | 
					
						
							| 
									
										
										
										
											2014-12-17 09:23:53 +00:00
										 |  |  |   to all UI text including menus, menu items, tool-tips, button text and label | 
					
						
							|  |  |  |   text etc. e.g. "Check for updates" rather than "Check for Updates". | 
					
						
							| 
									
										
										
										
											2018-04-09 07:59:33 +02:00
										 |  |  |   We also capitalize Subsurface (NOTE: not SubSurface) when referring to the | 
					
						
							| 
									
										
										
										
											2014-12-17 09:23:53 +00:00
										 |  |  |   application itself. | 
					
						
							|  |  |  |   Abbreviations should end with a period, e.g. "temp." not "temp" for | 
					
						
							|  |  |  |   temperature | 
					
						
							|  |  |  |   Numerals in chemical formulae should use subscript characters e.g. O₂ not O2 | 
					
						
							|  |  |  |   Partial pressures in Subsurface are, by convention, abbreviated with a single | 
					
						
							|  |  |  |   "p" rather than 2, as in pO₂ not ppO₂ | 
					
						
							|  |  |  |   Where more than one term exists for something, please choose the one already | 
					
						
							|  |  |  |   in use within Subsurface e.g. Cylinder vs. Tank. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 09:08:46 +02:00
										 |  |  | - string manipulation | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  -- user interface | 
					
						
							|  |  |  |     In UI part of the code use of QString methods is preferred, see this pretty | 
					
						
							|  |  |  |     good guide in QString documentation: | 
					
						
							|  |  |  |     http://doc.qt.io/qt-5/qstring.html#manipulating-string-data | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  -- core components | 
					
						
							|  |  |  |     In the core part of the code, C-string should be used. | 
					
						
							|  |  |  |     C-string manipulation is not always straightforward specifically when | 
					
						
							|  |  |  |     it comes to memory allocation, a set of helper functions has been developed | 
					
						
							|  |  |  |     to help with this. Documentation and usage examples can be found in | 
					
						
							|  |  |  |     core/membuffer.h file: | 
					
						
							|  |  |  |     https://github.com/Subsurface-divelog/subsurface/blob/master/core/membuffer.h | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-27 07:57:22 -08:00
										 |  |  | Sample Settings | 
					
						
							|  |  |  | =============== | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Emacs | 
					
						
							|  |  |  | ----- | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | These lines in your .emacs file should get you fairly close when it comes | 
					
						
							|  |  |  | to indentation - many of the other rules you have to follow manually | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ;; indentation | 
					
						
							|  |  |  | (defun c-lineup-arglist-tabs-only (ignored) | 
					
						
							|  |  |  |   "Line up argument lists by tabs, not spaces" | 
					
						
							|  |  |  |   (let* ((anchor (c-langelem-pos c-syntactic-element)) | 
					
						
							|  |  |  |          (column (c-langelem-2nd-pos c-syntactic-element)) | 
					
						
							|  |  |  |          (offset (- (1+ column) anchor)) | 
					
						
							|  |  |  |          (steps (floor offset c-basic-offset))) | 
					
						
							|  |  |  |     (* (max steps 1) | 
					
						
							|  |  |  |        c-basic-offset))) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (add-hook 'c-mode-common-hook | 
					
						
							|  |  |  |           (lambda () | 
					
						
							|  |  |  |             ;; Add kernel style | 
					
						
							|  |  |  |             (c-add-style | 
					
						
							|  |  |  |              "linux-tabs-only" | 
					
						
							|  |  |  |              '("linux" (c-offsets-alist | 
					
						
							|  |  |  |                         (arglist-cont-nonempty | 
					
						
							|  |  |  |                          c-lineup-gcc-asm-reg | 
					
						
							|  |  |  |                          c-lineup-arglist-tabs-only)))))) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (add-hook 'c-mode-hook | 
					
						
							|  |  |  |           (lambda () | 
					
						
							|  |  |  |             (let ((filename (buffer-file-name))) | 
					
						
							|  |  |  |               ;; Enable kernel mode for the appropriate files | 
					
						
							|  |  |  |                 (setq indent-tabs-mode t) | 
					
						
							|  |  |  |                 (c-set-style "linux-tabs-only")))) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (add-hook 'c++-mode-hook | 
					
						
							|  |  |  |           (lambda () | 
					
						
							|  |  |  |             (let ((filename (buffer-file-name))) | 
					
						
							|  |  |  |               ;; Enable kernel mode for the appropriate files | 
					
						
							|  |  |  |                 (setq indent-tabs-mode t) | 
					
						
							|  |  |  |                 (c-set-style "linux-tabs-only")))) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | QtCreator | 
					
						
							|  |  |  | --------- | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | These settings seem to get indentation right in QtCreator. Making TAB | 
					
						
							|  |  |  | always adjust indent makes it hard to add hard tabs before '\' when | 
					
						
							|  |  |  | creating continuing lines. Copying a tab with your mouse / ctrl-C and | 
					
						
							|  |  |  | inserting it with ctrl-V seems to work around that problem (use Command | 
					
						
							|  |  |  | instead of ctrl on your Mac) | 
					
						
							| 
									
										
										
										
											2015-09-07 07:58:35 -07:00
										 |  |  | Save this XML code below to a file, open Preferences (or Tools->Options) | 
					
						
							|  |  |  | in QtCreator, pick C++ in the left column and then click on Import... | 
					
						
							|  |  |  | to open the file you just created. Now you should have a "Subsurface" | 
					
						
							|  |  |  | style that you can select which should work well for our coding style. | 
					
						
							| 
									
										
										
										
											2014-02-27 07:57:22 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <?xml version="1.0" encoding="UTF-8"?> | 
					
						
							|  |  |  | <!DOCTYPE QtCreatorCodeStyle> | 
					
						
							|  |  |  | <!-- Written by QtCreator 3.0.0, 2014-02-27T07:52:57. --> | 
					
						
							|  |  |  | <qtcreator> | 
					
						
							|  |  |  |  <data> | 
					
						
							|  |  |  |   <variable>CodeStyleData</variable> | 
					
						
							|  |  |  |   <valuemap type="QVariantMap"> | 
					
						
							|  |  |  |    <value type="bool" key="AlignAssignments">false</value> | 
					
						
							|  |  |  |    <value type="bool" key="AutoSpacesForTabs">false</value> | 
					
						
							|  |  |  |    <value type="bool" key="BindStarToIdentifier">true</value> | 
					
						
							|  |  |  |    <value type="bool" key="BindStarToLeftSpecifier">false</value> | 
					
						
							|  |  |  |    <value type="bool" key="BindStarToRightSpecifier">false</value> | 
					
						
							|  |  |  |    <value type="bool" key="BindStarToTypeName">false</value> | 
					
						
							|  |  |  |    <value type="bool" key="ExtraPaddingForConditionsIfConfusingAlign">false</value> | 
					
						
							|  |  |  |    <value type="bool" key="IndentAccessSpecifiers">false</value> | 
					
						
							|  |  |  |    <value type="bool" key="IndentBlockBody">true</value> | 
					
						
							|  |  |  |    <value type="bool" key="IndentBlockBraces">false</value> | 
					
						
							|  |  |  |    <value type="bool" key="IndentBlocksRelativeToSwitchLabels">false</value> | 
					
						
							|  |  |  |    <value type="bool" key="IndentClassBraces">false</value> | 
					
						
							|  |  |  |    <value type="bool" key="IndentControlFlowRelativeToSwitchLabels">true</value> | 
					
						
							|  |  |  |    <value type="bool" key="IndentDeclarationsRelativeToAccessSpecifiers">true</value> | 
					
						
							|  |  |  |    <value type="bool" key="IndentEnumBraces">false</value> | 
					
						
							|  |  |  |    <value type="bool" key="IndentFunctionBody">true</value> | 
					
						
							|  |  |  |    <value type="bool" key="IndentFunctionBraces">false</value> | 
					
						
							|  |  |  |    <value type="bool" key="IndentNamespaceBody">false</value> | 
					
						
							|  |  |  |    <value type="bool" key="IndentNamespaceBraces">false</value> | 
					
						
							|  |  |  |    <value type="int" key="IndentSize">8</value> | 
					
						
							|  |  |  |    <value type="bool" key="IndentStatementsRelativeToSwitchLabels">true</value> | 
					
						
							|  |  |  |    <value type="bool" key="IndentSwitchLabels">false</value> | 
					
						
							|  |  |  |    <value type="int" key="PaddingMode">2</value> | 
					
						
							|  |  |  |    <value type="bool" key="SpacesForTabs">false</value> | 
					
						
							|  |  |  |    <value type="int" key="TabSize">8</value> | 
					
						
							|  |  |  |   </valuemap> | 
					
						
							|  |  |  |  </data> | 
					
						
							|  |  |  |  <data> | 
					
						
							|  |  |  |   <variable>DisplayName</variable> | 
					
						
							|  |  |  |   <value type="QString">Subsurface</value> | 
					
						
							|  |  |  |  </data> | 
					
						
							|  |  |  | </qtcreator> | 
					
						
							| 
									
										
										
										
											2014-02-27 22:42:10 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Vim | 
					
						
							|  |  |  | --------- | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-28 12:09:18 +03:00
										 |  |  | As everybody knows vim is a way better editor than emacs and thus needs to be | 
					
						
							| 
									
										
										
										
											2014-05-10 09:34:34 -07:00
										 |  |  | in this file too. Put this into your .vimrc and this should produce something | 
					
						
							| 
									
										
										
										
											2014-02-27 22:42:10 +01:00
										 |  |  | close to our coding standards. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | " Subsurface coding style | 
					
						
							|  |  |  | filetype plugin indent on | 
					
						
							|  |  |  | filetype detect | 
					
						
							| 
									
										
										
										
											2014-03-10 12:19:40 -05:00
										 |  |  | set cindent tabstop=8 shiftwidth=8 cinoptions=l1,:0,(0,g0 | 
					
						
							| 
									
										
										
										
											2014-02-27 22:42:10 +01:00
										 |  |  | " TODO: extern "C" gets indented | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | " And some sane defaults, optional, but quite nice | 
					
						
							|  |  |  | set nocompatible | 
					
						
							|  |  |  | syntax on | 
					
						
							|  |  |  | colorscheme default | 
					
						
							| 
									
										
										
										
											2014-03-10 12:19:40 -05:00
										 |  |  | set hls | 
					
						
							|  |  |  | set is | 
					
						
							| 
									
										
										
										
											2014-02-27 22:42:10 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | " The default blue is just impossible to see on a black terminal | 
					
						
							|  |  |  | highlight Comment ctermfg=Brown | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | " clearly point out when someone have trailing spaces | 
					
						
							|  |  |  | highlight ExtraWhitespace ctermbg=red guibg=red | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | " Show trailing whitespace and spaces before a tab: | 
					
						
							|  |  |  | match ExtraWhitespace /\s\+$\| \+\ze\t/ |