...
- You consider doing it according to this conventions, assuming you fully understand them.
- If your common sense tells you it's not right, it probably isn't - do it your way.
- But don't leave it like that, talk about it, or even better update this page.
Mes specific conventions
Model fields literals
Every time we add a new model field we should add it to the constants/PluginNameFields.java like this:
Code Block |
---|
public class PluginNameFields {
public final static String ORDER = "order";
} |
So we won't repeat those string literals over and over when accessing entities fields. We're gonna use:
Code Block |
---|
entity.getBelongsToField(PluginNameFields.ORDER); |
You should avoid static importing such constants or you loose their namespace and the probability to make mistake increase dramatically.
It is important especially for field names, which often has the same (or at least very similar) names.
Java enums
For every enum field of a model we create, we should create corresponding Java enum in constants package.
For ex.
Code Block | ||
---|---|---|
| ||
public enum BatchNumberUniqueness {
GLOBALLY("01globally"), MANUFACTURER("02manufacturer");
private final String stringValue;
private BatchNumberUniqueness(final String stringValue) {
this.stringValue = stringValue;
}
public String getStringValue() {
return stringValue;
}
public static BatchNumberUniqueness parseString(final String string) {
BatchNumberUniqueness parsedEnum = null;
for (BatchNumberUniqueness value : BatchNumberUniqueness.values()) {
if (value.getStringValue().equals(string)) {
parsedEnum = value;
break;
}
}
Preconditions.checkArgument(parsedEnum != null, "Couldn't parse enum from string '" + string + "'");
return parsedEnum;
}
@Override
public String toString() {
return stringValue;
}
} |
Naming conventions
Naming literals:
EDIT: look at the mes specific convention about model field literals.
If the same string literal occurs more than once we extract it to a field like this:
...
- constants - we hold here classes like AwesomePluginConstants AwesomePluginConstants.java and maybe some model enums that are plugin specific.
- hooks - model and view hooks like: ViewNameViewHooks ViewNameHooks.java, ModelNameHooks ModelNameHooks.java. If the hook class is meant to extend (on a business level) an other plugin it should have plugin abbreviation for ex. ModelNameHooksAP.java
- validators - model validators like: ModelNameValidators ModelNameValidators.java, SomeOtherModelNameValidators SomeOtherModelNameValidators.java or ModelNameValidatorsAP.java (like with the hooks)
- listeners - view listeners like: ViewNameListeners.javastates - if there is some logic regarding model states (I consider enum state model field as something that common to write it here), for ex. ModelNameStatesService.java ViewNameListeners.java, ViewNameListenersAP.java (like with the hooks)
- workPlansColumnExtension - http://wiki.qcadoo.org/display/QCDMESDOC/WorkPlans+column+extension
...
Code Block |
---|
// state is either 01draft or 02accepted if ("01draft".equals(state)) { doSomething(); } else if ("02accepted".equals(state)) { doSomethingDifferent(); } else { throw new IllegalStateException("state is neither 01draft nor 02accepted"); } |
Mes specific conventions
Java enums
For every enum field of a model we create, we should create corresponding Java enum in constants package.
For ex.
Code Block | ||
---|---|---|
| ||
public enum BatchNumberUniqueness { GLOBALLY("01globally"), MANUFACTURER("02manufacturer"); private String stringValue; private BatchNumberUniqueness(final String stringValue) { this.stringValue = stringValue; } public String getStringValue() { return stringValue; } public static final BatchNumberUniqueness parseString(final String string) { if ("01globally".equals(string)) { return GLOBALLY; } else if ("02manufacturer".equals(string)) { return MANUFACTURER; } else { throw new IllegalStateException("Couldn't parse BatchNumberUniqueness from string"); } } } |