Skip to content

Scalastyle proposed rules (Whitespace)

matthewfarwell edited this page Oct 21, 2011 · 7 revisions

This page contains proposed rules for Scalastyle. These rules are from Checkstyle, and do not necessarily apply to Scalastyle.

Whitespace

GenericWhitespace

Checks that the whitespace around the Generic tokens < and > is correct to the typical convention. The convention is not configurable. For example the following is legal: List<Integer> x = new ArrayList<Integer>(); List<List<Integer>> y = new ArrayList<List<Integer>>(); But the following example is not: List < Integer > x = new ArrayList < Integer > (); List < List < Integer > > y = new ArrayList < List < Integer > > ();

EmptyForInitializerPad

Checks the padding of an empty for initializer; that is whether white space is required at an empty for initializer, or such white space is forbidden. No check occurs if there is a line wrap at the initializer, as in for ( ; i < j; i++, j--)

EmptyForIteratorPad

Checks the padding of an empty for iterator; that is whether white space is required at an empty for iterator, or such white space is forbidden. No check occurs if there is a line wrap at the iterator, as in for (Iterator foo = very.long.line.iterator(); foo.hasNext(); )

MethodParamPad

Checks the padding between the identifier of a method definition, constructor definition, method call, or constructor invocation; and the left parenthesis of the parameter list. That is, if the identifier and left parenthesis are on the same line, checks whether a space is required immediately after the identifier or such a space is forbidden. If they are not on the same line, reports an error, unless configured to allow line breaks. To allow linebreaks after the identifier, set property allowLineBreaks to true.

NoWhitespaceAfter

Checks that there is no whitespace after a token. More specifically, it checks that it is not followed by whitespace, or (if linebreaks are allowed) all characters on the line after are whitespace. To forbid linebreaks after a token, set property allowLineBreaks to false.

NoWhitespaceBefore

Checks that there is no whitespace before a token. More specifically, it checks that it is not preceded with whitespace, or (if linebreaks are allowed) all characters on the line before are whitespace. To allow linebreaks before a token, set property allowLineBreaks to true.

OperatorWrap

Checks the policy on how to wrap lines on operators.

ParenPad

Checks the policy on the padding of parentheses; i.e. whether a space is required after a left parenthesis and before a right parenthesis, or such spaces are forbidden.

TypecastParenPad

Checks the policy on the padding of parentheses for typecasts. That is, whether a space is required after a left parenthesis and before a right parenthesis, or such spaces are forbidden.

FileTabCharacter

Checks that there are no tab characters ('\t') in the source code. Rationale:

  • Developers should not need to configure the tab width of their text editors in order to be able to read source code.
  • From the Apache jakarta coding standards: In a distributed development environment, when the commit messages get sent to a mailing list, they are almost impossible to read if you use tabs.

WhitespaceAfter

Checks that a token is followed by whitespace.

WhitespaceAround

Checks that a token is surrounded by whitespace. Empty constructor and method bodies (blocks) of the form public MyClass() {} // empty constructor public void func() {} // empty method may optionally be exempted from the policy using the allowEmptyMethods and allowEmptyConstructors properties.