Public:Coding conventions
From YaddaWiki
Contents |
Coding Conventions
All ICM development must stick to the following rules about code formatting, conventions etc.
Please, adjust your IDE to match the code formatting patterns described below.
Java coding conventions
We follow the Java code conventions and JSP code conventions with some customization and specific rules which are described below.
Class code sections
To improve the readability of classes we have decided to divide their code into logical sections. Each section should have a relevant comment block on top of it.
The comment pattern for each section is as follows: a space, 20 dashes, a space, section_name, a space, 20 dashes i.e.:
// -------------------- SECTION_NAME --------------------
Names of all distinguished code sections along with their descriptions:
- CONSTRUCTORS - class constructors
- GETTERS - Java Beans getters
- TESTS - test methods in test classes
- LOGIC - public methods of a class that implement its intended functionalities, e.g. Parser.parse(String) or Math.divide(), Court.addDivision(Division).
- PRIVATE - class and package private methods
- SETTERS - Java Beans setters
- HashCode & Equals - hashCode and equals methods
- toString - toString method
- INNER CLASSES - inner classes
The order of the sections in a class should be the same as on the list above.
Spacing/indentation
- never use tabs to indent, use 4 spaces instead of one tab
- if possible break lines longer than 120 chars, try not to excees 160 chars.
- use 80 chars for javadocs
One line if-s
Excerpt from code conventions:
Braces are used around all statements, even singletons, when they are part of a control structure, such as a if-else or for statement. This makes it easier to add statements without accidentally introducing bugs due to forgetting to add braces.
Access modifiers
Do not use "public" and "abstract" modifiers for interface methods. They are superfluous.
Naming things
Naming parts of code properly is one of the most important things to guarante the code to be readable and clear. The name should clearly indicate what a given part of the code is or does.
Module naming conventions
The name of the module should clearly express the functionality the given module provides, and should be preceded by the name of the application. Let's say the name of the app is football
and the module we want to write will be responsible for the persistence layer access(saving, reading, repositories). In such a case the name of the module could be football-persistence
.
Package name conventions
We divide the applications by functionalities they provide, not the types of services they are. It doesn't matter if you create a module, a package, a class or a method, the most important thing is that the name should correspond to the functionality the given fragment of the code provides (at least it's first part, e.g. JournalSearchController
). It means that instead of package structure like this:
- controller - service - dto ...
We would have, for example:
- journal - details - search - article - details - search - search-common - security
It's worth noting that it very often doesn't make sense to create a package unless there are at least a few classes (let's say 3-6) that could make up its content. For example, if we had a journal
package and only three classes in it, let's say JournalDetailsController
, JournalEditController<code> and <code>JournalEditService
we probably wouldn't divide the package into journal.details
and journal.edit
packages.
</code>
Interface and implementation naming
Avoid using IName
for the interface name. An interface should be named without leading I
.
Good:
SomeService
Bad:
ISomeService
The following rules apply to implementation naming:
- use a reasonable prefix to explain the specifics of the implementation, eg.:
JdbcCatalog
CachedCatalog
- if there is a really, really only one reasonable implementation of the interface (and you do not expect to ever have another one) you may also use:
<Interface name> + Impl
, eg.:
SomeServiceImpl
Loggers and logging
SLF4j is since now official logging tool (classes shall use slf4j logging classes and never use other loggers). Details: logging in Yaddda
Avoid commiting files with warnings
You should not commit files that have warnings shown by Eclipse or any editor you use.
In eclipse, to avoid warnings informing about unused imports you can use a feature called "Automated formatting and import clean up". This will allow eclipse to organize imports and to format the code before saving each java file.
To enable it, you have to select Window->Preferences item from the main menu. Then select Java->Editor->Save Actions option.
Expected settings are:
- enable "Perform the selected actions on save"
- enable "Organize imports"
- you can also enable "Format source code" but only "Format edited lines", to avoid unnecessary noise in repo commits.
Coding guidelines
Exception handling
It is forbidden to catch an exception silently
Every exception must be handled properly (shown to a user, logged etc.). Never, ever do anything like this:
try { ... } catch(Exception e) {}
Exceptions and threads
Be aware that exceptions raised in manually created threads are silently skipped. Check against any exceptions in the thread code:
MyThread extends Thread { public void run() { try { //thread execution code } catch (Exception e) { //exception handling code } } }
And whenever starting specific thread it is preferable to use Future, DeskLightTask (in DL) or other class that does proper exception handling.
Iteration
Instead of this:
Iterator<Foo> it = foos.iterator(); while (it.hasNext()) { bar(it.next()); }
use this:
for (Foo foo : foos) { bar(foo); }
Comments
Comments are usually helpful for other developers who need to read and maintain the existing code. Please, keep in mind, that a comment should be clear, concise and only written if really needed because we prefer to write readable code rather than extensive comments.
General rules
We write all comments in English. You are adviced to use spellchecker feature of IDE to maintain reasonable standards.
Preamble
[suspended, TBD]
Each file must have preamble with:
- copyright note (ICM, Warsaw University)
- license note (Usually apache 2.0)
Class comments
Each class must have a javadoc on itself, describing:
- what it is
- what it is for
- authors (note: if you do some extensive work on a class, put yourself on author list together with previous one).
Interface comments
It is obligatory to write extensive javadoc for every interface, no exceptions. This includes:
- interface itself javadoc (what it is, what functionality represents etc.)
- full javadoc for every method
Remember that comments describe the contract of an interface, both for users and those who will implement it. If it is clear then less problems will occur at the integration time.
Method comments
Each public method must have a javadoc comment describing its usage, functionality, exceptions, params and return value. The comment should also explain the expected behaviour in border cases (what will happen if passed Collection is null? NullPointerException, or will it be treated as empty list?)
Field/ accessor method comments
If get/set methods are present for a field, the `get` method is preferred to add javadoc. Idem per idem is not acceptable (i.e. 'setCatalog: this sets the catalog property).