diff --git a/.github/workflows/codeql-analysis.yml b/.github/workflows/codeql-analysis.yml index 57eb5a0149..3601aaad0e 100644 --- a/.github/workflows/codeql-analysis.yml +++ b/.github/workflows/codeql-analysis.yml @@ -42,14 +42,14 @@ jobs: with: languages: ${{ matrix.language }} # If you wish to specify custom queries, you can do so here or in a config file. - # By default, queries listed here will override any specified in a config file. + # By default, queries listed here will override any specified in a config file. # Prefix the list here with "+" to use these queries and those in the config file. # queries: ./path/to/local/query, your-org/your-repo/queries@main # Autobuild attempts to build any compiled languages (C/C++, C#, or Java). # If this step fails, then you should remove it and run the build manually (see below) - - name: Autobuild - uses: github/codeql-action/autobuild@v2 + # - name: Autobuild + # uses: github/codeql-action/autobuild@v2 # ℹī¸ Command-line programs to run using the OS shell. # 📚 https://git.io/JvXDl @@ -58,9 +58,8 @@ jobs: # and modify them (or add more) to build your code if your project # uses a compiled language - #- run: | - # make bootstrap - # make release + - run: | + mvn clean install - name: Perform CodeQL Analysis uses: github/codeql-action/analyze@v2 diff --git a/README.md b/README.md index 0f47c1ba17..87b28bba69 100644 --- a/README.md +++ b/README.md @@ -17,14 +17,14 @@ DiKTat is a strict [coding standard ](info/guide/diktat-coding-convention.md) for Kotlin and a collection of [Kotlin](https://kotlinlang.org/) code style rules implemented -as AST visitors on the top of [KTlint](https://ktlint.github.io/). It can be used for detecting and autofixing code smells in CI/CD process. +as AST visitors on the top of [KTlint](https://ktlint.github.io/). It can be used for detecting and autofixing code smells in CI/CD process. The full list of available supported rules and inspections can be found [here](info/available-rules.md). -Now diKTat was already added to the lists of [static analysis tools](https://github.com/analysis-tools-dev/static-analysis), to [kotlin-awesome](https://github.com/KotlinBy/awesome-kotlin) and to [kompar](https://catalog.kompar.tools/Analyzer/diKTat/1.2.1). Thanks to the community for this support! +Now diKTat was already added to the lists of [static analysis tools](https://github.com/analysis-tools-dev/static-analysis), to [kotlin-awesome](https://github.com/KotlinBy/awesome-kotlin) and to [kompar](https://catalog.kompar.tools/Analyzer/diKTat/1.2.1). Thanks to the community for this support! ## See first -| | | | | | | +| | | | | | | | --- | --- | --- | --- | --- | --- | |[Codestyle](info/guide/diktat-coding-convention.md)|[Inspections](info/available-rules.md) | [Examples](examples) | [Demo](https://ktlint-demo.herokuapp.com) | [White Paper](wp/wp.pdf) | [Groups of Inspections](info/rules-mapping.md) | @@ -36,7 +36,7 @@ First of all - actually you can combine diktat with any other static analyzers. Main features of diktat are the following: 1) **More inspections.** It has 100+ inspections that are tightly coupled with it's [Codestyle](info/guide/diktat-coding-convention.md). - + 2) **Unique [Inspections](info/available-rules.md)** that are missing in other linters. 3) **Highly configurable**. Each and every inspection can be [configured](#config) or [suppressed](#suppress). @@ -44,39 +44,34 @@ Main features of diktat are the following: 4) **Strict detailed [Codestyle](info/guide/diktat-coding-convention.md)** that you can adopt and use in your project. ## Run as CLI-application -
-Download and install binaries: + +### Download and install binaries 1. Install KTlint manually: [here](https://github.com/pinterest/ktlint/releases) -**OR** use curl: -```bash -# another option is "brew install ktlint" + **OR** use `curl`: + ```shell + # another option is "brew install ktlint" -curl -sSLO https://github.com/pinterest/ktlint/releases/download/0.43.2/ktlint && chmod a+x ktlint -``` - -2. Load diKTat manually: [here](https://github.com/saveourtool/diKTat/releases/download/v1.2.1/diktat-1.2.1.jar) + curl -sSLO https://github.com/pinterest/ktlint/releases/download/0.46.1/ktlint && chmod a+x ktlint + ``` -**OR** use curl: -```bash -$ curl -sSLO https://github.com/saveourtool/diKTat/releases/download/v1.2.1/diktat-1.2.1.jar -``` -
+1. Load diKTat manually: [here](https://github.com/saveourtool/diKTat/releases/download/v1.2.1/diktat-1.2.1.jar) -
- -Run diktat: - -3. Finally, run KTlint (with diKTat injected) to check your '*.kt' files in 'dir/your/dir': - -```bash + **OR** use `curl`: + ```console + $ curl -sSLO https://github.com/saveourtool/diKTat/releases/download/v1.2.1/diktat-1.2.1.jar + ``` + +### Run diKTat + +Finally, run KTlint (with diKTat injected) to check your '*.kt' files in 'dir/your/dir': + +```console $ ./ktlint -R diktat.jar --disabled_rules=standard "dir/your/dir/**/*.kt" ``` -To **autofix** all code style violations use `-F` option. -
- +To **autofix** all code style violations, use `-F` option. ## Run with Maven using diktat-maven-plugin :heavy_exclamation_mark: If you are using **Java 16+**, you need to add `--add-opens java.base/java.util=ALL-UNNAMED` flag to the JVM. For more information, see: https://github.com/pinterest/ktlint/issues/1195 @@ -91,7 +86,7 @@ If you use it and encounter any problems, feel free to open issues on [github](h
Add this plugin to your pom.xml: - + ```xml org.cqfn.diktat @@ -360,7 +355,7 @@ For example: ```yaml - name: HEADER_MISSING_OR_WRONG_COPYRIGHT # all rules are enabled by the default. To disable add 'enabled: false' to the config. - enabled: true + enabled: true configuration: isCopyrightMandatory: true copyrightText: Copyright (c) Jeff Lebowski, 2012-2020. All rights reserved. @@ -421,12 +416,12 @@ disabling of the inspection on that particular code block: Suppress groups of inspections by chapters It is easy to suppress even groups of inspections in diKTat. -These groups are linked to chapters of [Codestyle](info/guide/diktat-coding-convention.md). +These groups are linked to chapters of [Codestyle](info/guide/diktat-coding-convention.md). To disable chapters, you will need to add the following configuration to common configuration (`- name: DIKTAT_COMMON`): ```yaml disabledChapters: "1, 2, 3" -``` +``` Mapping of inspections to chapters can be found in [Groups of Inspections](info/rules-mapping.md).
@@ -442,5 +437,5 @@ java -jar ktlint -R dikat.jar --baseline=diktat-baseline.xml **/*.kt or with corresponding configuration options in maven or gradle plugins. Baseline report is intended to be added into the VCS, but it can be removed and re-generated later, if needed. -## Contribution +## Contribution See our [Contributing Policy](CONTRIBUTING.md) and [Code of Conduct](CODE_OF_CONDUCT.md) diff --git a/diktat-gradle-plugin/build.gradle.kts b/diktat-gradle-plugin/build.gradle.kts index f45b6b7012..95c506dbe5 100644 --- a/diktat-gradle-plugin/build.gradle.kts +++ b/diktat-gradle-plugin/build.gradle.kts @@ -12,7 +12,7 @@ plugins { repositories { flatDir { // to use snapshot diktat without necessary installing - dirs("../diktat-rules/target") + dirs("../diktat-common/target") content { includeGroup("org.cqfn.diktat") }