====== LU01b - Linting & Formatting ======
==== Formatting ====
Formatter sorgen dafür, dass der gemeinsame Code einheitlich formatiert wird. Oftmals besitzen IDE bereits eine Standard-Formattierung oder die Möglichkeit, Formatierungsregeln mit Entwicklern mit denselber IDE auszutauschen.
Beispiele von IDE-spezifischen Formatierungen:
* **IntelliJ**: Code Style XML unter ''.idea/codeStyles/...''
* **Visual Studio Code**: Settings unter ''.vscode/settings.json''
* **Eclipse: Code Style Formatter**: Eclipse Code Formatter XML
* **Diverse IDE**: ''.editorconfig'' (aber nicht alle Regeln funktionieren aber bei allen IDE's)
^ IntelliJ Project.xml ^ VS Code settings.json ^ Eclipse java-formatter.xml ^ .editorconfig ^
| ...
... | {
// Tab size
"editor.tabSize": 4,
"editor.insertSpaces": true,
// New line at end of file
"files.insertFinalNewline": true,
// Java-specific
"editor.formatOnSave": true,
// Remove unused imports
"editor.codeActionsOnSave": {
"source.organizeImports": true
},
} | ...
... | ...
[*]
indent_style = space
indent_size = 4
tab_width = 4
end_of_line = lf
insert_final_newline = true
trim_trailing_whitespace = true
... |
Das Problem von solchen Konfigurationen ist ihre Abhängigkeit zu der IDE. Sobald ein Teammitglied eine andere IDE nutzt, kommt es früher oder später zu Formatierungsunterschieden, da viele (besonders komplexere) Regeln nicht für alle IDE's verfügbar ist.
Ein weiteres Nachteil ist, dass solche Formatierungen in der Regel nicht in die Build-Pipeline eingebaut werden können.
Daher würde ich IDE-unabhängige Formatter bei komplexeren Formatierungsregeln bevorzugen. Einfache Regeln (Einrückungen, Trailing New Line etc.) sind oft in den gängigsten IDE's vorhanden.
Beispiele von IDE-unabhängigen Formatter-Bibliotheken:
* Javascript, Typescript, HTML, CSS, JSON -> Prettier
* Python -> black, pep8, ...
* Java -> Google Java Format
==== Linting ====
Linting (dt. "fusseln") bezeichnet das automatische finden und teilweise sogar korrigieren von möglichen Fehlern o.Ä. anhand von einem definierten Regelset. Entsprechende Bibliotheken sind für diverse Sprachen erhältlich.
Gängige Linter-Bibliotheken
* Javascript, Typescript -> ESLint(https://eslint.org/) , \\ TSLint wurde eingestellt und ist daher nicht mehr empfohlen
* Python -> Pylint (https://www.pylint.org/)
* Java -> PMD (https://pmd.github.io/)
* Diverse Sprachen -> SonarQube for IDE (SonarLint)