diff --git a/.circleci/config.yml b/.circleci/config.yml index 8961bc4..ec40792 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -10,13 +10,13 @@ jobs: - checkout - restore_cache: keys: - - v1-dependencies-{{ checksum "build.gradle" }} + - v1-dependencies-{{ checksum "build.gradle.kts" }} - v1-dependencies- - run: ./gradlew dependencies - save_cache: paths: - ~/.gradle - key: v1-dependencies-{{ checksum "build.gradle" }} + key: v1-dependencies-{{ checksum "build.gradle.kts" }} lint: docker: - image: circleci/openjdk:11-jdk @@ -25,9 +25,9 @@ jobs: - checkout - restore_cache: keys: - - v1-dependencies-{{ checksum "build.gradle" }} + - v1-dependencies-{{ checksum "build.gradle.kts" }} - v1-dependencies- - - run: ./gradlew ktlint + - run: ./gradlew ktlintCheck test: docker: - image: circleci/openjdk:11-jdk @@ -36,7 +36,7 @@ jobs: - checkout - restore_cache: keys: - - v1-dependencies-{{ checksum "build.gradle" }} + - v1-dependencies-{{ checksum "build.gradle.kts" }} - v1-dependencies- - run: ./gradlew test diff --git a/.idea/compiler.xml b/.idea/compiler.xml index dcb1ffc..368c8f1 100644 --- a/.idea/compiler.xml +++ b/.idea/compiler.xml @@ -1,7 +1,7 @@ - + diff --git a/.idea/gradle.xml b/.idea/gradle.xml index 1166b6d..3e9cef1 100644 --- a/.idea/gradle.xml +++ b/.idea/gradle.xml @@ -9,13 +9,12 @@ - diff --git a/.idea/misc.xml b/.idea/misc.xml index a134cd6..d9dbfcd 100644 --- a/.idea/misc.xml +++ b/.idea/misc.xml @@ -4,7 +4,12 @@ - + + + + \ No newline at end of file diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 0000000..faa22d1 --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,3 @@ +## [1.0.11] +### Added +- Add support for 213* / 2021.3 version of IDEA #56 \ No newline at end of file diff --git a/README.md b/README.md index e4bf1e3..549d8f3 100644 --- a/README.md +++ b/README.md @@ -2,13 +2,16 @@ [![jetBrains](https://img.shields.io/jetbrains/plugin/d/10942-kotlin-fill-class.svg)](https://plugins.jetbrains.com/plugin/10942-kotlin-fill-class) # kotlin-fill-class plugin + Intellij plugin that provide intention action for empty constructor or function to fill property with default value. Inspired by Go [fillstruct](https://github.com/davidrjenni/reftools/tree/master/cmd/fillstruct) + ## Usage This plugin add intention action for invalid constructor or function expression. ![kotlin fill class demo](https://user-images.githubusercontent.com/8841470/59397528-e61a4380-8dc7-11e9-9684-d82d225316fe.gif) + ### Configure settings You can configure the plugin settings by `Edit inspection profile setting` ![Edit inspection profile setting](https://user-images.githubusercontent.com/1121855/107631811-f4a9b400-6ca8-11eb-9ea8-1b0b56f0fda9.png) diff --git a/build.gradle b/build.gradle deleted file mode 100644 index 5f819e9..0000000 --- a/build.gradle +++ /dev/null @@ -1,84 +0,0 @@ -buildscript { - ext.kotlinVersion = '1.4.10' - repositories { - mavenCentral() - } - dependencies { - classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlinVersion" - } -} - -plugins { - id 'java' - id 'org.jetbrains.intellij' version '0.6.5' - id 'org.jetbrains.kotlin.jvm' version '1.4.21' -} - -apply plugin: 'org.jetbrains.intellij' -apply plugin: 'kotlin' - -sourceCompatibility = JavaVersion.VERSION_11 -targetCompatibility = JavaVersion.VERSION_11 - -intellij { - version '2021.3' - plugins = ['Kotlin', 'java'] - pluginName 'kotlin-fill-class' - publishPlugin { - token System.getenv('TOKEN') - } - patchPluginXml { - sinceBuild '191.8026.42' - } -} - -repositories { - mavenCentral() - jcenter() -} - -group 'com.github.suusan2go.kotlin-fill-class' -version '1.0.11' - -sourceCompatibility = 11 - -repositories { - mavenCentral() -} - -configurations { - ktlint -} - -dependencies { - implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk8" - testImplementation group: 'junit', name: 'junit', version: '4.13.1' - - ktlint "com.github.shyiko:ktlint:0.31.0" -} - -compileKotlin { - kotlinOptions.jvmTarget = "11" -} -compileTestKotlin { - kotlinOptions.jvmTarget = "11" -} - -task ktlint(type: JavaExec, group: "verification") { - description = "Check Kotlin code style." - main = "com.github.shyiko.ktlint.Main" - classpath = configurations.ktlint - args "src/**/*.kt" - // to generate report in checkstyle format prepend following args: - // "--reporter=plain", "--reporter=checkstyle,output=${buildDir}/ktlint.xml" - // see https://github.com/shyiko/ktlint#usage for more -} -check.dependsOn ktlint - -task ktlintFormat(type: JavaExec, group: "formatting") { - description = "Fix Kotlin code style deviations." - main = "com.github.shyiko.ktlint.Main" - classpath = configurations.ktlint - args "-F", "src/**/*.kt" -} - diff --git a/build.gradle.kts b/build.gradle.kts new file mode 100644 index 0000000..a019b2e --- /dev/null +++ b/build.gradle.kts @@ -0,0 +1,108 @@ +import org.jetbrains.changelog.markdownToHTML +import org.jetbrains.kotlin.gradle.tasks.KotlinCompile +import org.jlleitschuh.gradle.ktlint.KtlintExtension + +fun properties(key: String) = project.findProperty(key).toString() + +plugins { + id("java") + id("org.jetbrains.kotlin.jvm") version "1.6.10" + id("org.jetbrains.intellij") version "1.4.0" + id("org.jetbrains.changelog") version "1.3.1" + id("org.jlleitschuh.gradle.ktlint") version "10.2.1" +} + +group = properties("pluginGroup") +version = properties("pluginVersion") + +repositories { + mavenCentral() +} + +intellij { + pluginName.set(properties("pluginName")) + version.set(properties("platformVersion")) + type.set(properties("platformType")) + plugins.set(properties("platformPlugins").split(',').map(String::trim).filter(String::isNotEmpty)) +} + +changelog { + version.set(properties("pluginVersion")) + groups.set(emptyList()) +} + +configure { + filter { + include("src/**/*.kt") + } +} + +dependencies { + testImplementation(group = "junit", name = "junit", version = "4.13.1") +} + +tasks { + // Set the JVM compatibility versions + properties("javaVersion").let { + withType { + sourceCompatibility = it + targetCompatibility = it + } + withType { + kotlinOptions.jvmTarget = it + } + } + + wrapper { + gradleVersion = properties("gradleVersion") + } + + patchPluginXml { + version.set(properties("pluginVersion")) + sinceBuild.set(properties("pluginSinceBuild")) + untilBuild.set(properties("pluginUntilBuild")) + + // Extract the section from README.md and provide for the plugin's manifest + pluginDescription.set( + projectDir.resolve("README.md").readText().lines().run { + val start = "" + val end = "" + + if (!containsAll(listOf(start, end))) { + throw GradleException("Plugin description section not found in README.md:\n$start ... $end") + } + subList(indexOf(start) + 1, indexOf(end)) + }.joinToString("\n") + .run { markdownToHTML(this) } + .plus( + "" + + "\"fill-class\"" + + "

" + ) + ) + + // Get the latest available change notes from the changelog file + changeNotes.set( + provider { + changelog.run { + getOrNull(properties("pluginVersion")) ?: getLatest() + }.toHTML() + } + ) + } + + // Configure UI tests plugin + // Read more: https://github.com/JetBrains/intellij-ui-test-robot + runIdeForUiTests { + systemProperty("robot-server.port", "8082") + systemProperty("ide.mac.message.dialogs.as.sheets", "false") + systemProperty("jb.privacy.policy.text", "") + systemProperty("jb.consents.confirmation.enabled", "false") + } + + publishPlugin { + dependsOn("patchChangelog") + token.set(System.getenv("TOKEN")) + channels.set(listOf(properties("pluginVersion").split('-').getOrElse(1) { "default" }.split('.').first())) + } +} diff --git a/gradle.properties b/gradle.properties new file mode 100644 index 0000000..35401f5 --- /dev/null +++ b/gradle.properties @@ -0,0 +1,15 @@ +pluginGroup = com.github.suusan2go.kotlin-fill-class +pluginName = kotlin-fill-class +pluginVersion = 1.0.12 +pluginSinceBuild = 191.8026.42 +pluginUntilBuild = 221.* +platformType = IC +platformVersion = 2021.1.3 +platformPlugins = com.intellij.java, org.jetbrains.kotlin +javaVersion = 11 +gradleVersion = 7.4 + +# Opt-out flag for bundling Kotlin standard library. +# See https://plugins.jetbrains.com/docs/intellij/kotlin.html#kotlin-standard-library for details. +# suppress inspection "UnusedProperty" +kotlin.stdlib.default.dependency = false \ No newline at end of file diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties index 6623300..d7e66b5 100644 --- a/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/wrapper/gradle-wrapper.properties @@ -1,5 +1,5 @@ distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-6.3-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-7.4.1-all.zip zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists diff --git a/settings.gradle b/settings.gradle.kts similarity index 74% rename from settings.gradle rename to settings.gradle.kts index 8afdb2f..409d6e4 100644 --- a/settings.gradle +++ b/settings.gradle.kts @@ -1,5 +1,5 @@ /* - * This file was generated by the Gradle 'init' task. + * This file was generated by the Gradle "init" task. * * The settings file is used to specify which projects to include in your build. * @@ -7,5 +7,4 @@ * in the user guide at https://docs.gradle.org/4.8.1/userguide/multi_project_builds.html */ -rootProject.name = 'kotlin-fill-class' - +rootProject.name = "kotlin-fill-class" diff --git a/src/test/kotlin/com/github/suusan2go/kotlinfillclass/inspections/FillClassInspectionTest.kt b/src/test/kotlin/com/github/suusan2go/kotlinfillclass/inspections/FillClassInspectionTest.kt index 32cca27..b9cdbc8 100644 --- a/src/test/kotlin/com/github/suusan2go/kotlinfillclass/inspections/FillClassInspectionTest.kt +++ b/src/test/kotlin/com/github/suusan2go/kotlinfillclass/inspections/FillClassInspectionTest.kt @@ -8,55 +8,67 @@ import org.jetbrains.kotlin.idea.KotlinFileType class FillClassInspectionTest : BasePlatformTestCase() { fun `test fill class constructor`() { - doAvailableTest(""" + doAvailableTest( + """ class User(val name: String, val age: Int) fun test() { User() } - """, """ + """, + """ class User(val name: String, val age: Int) fun test() { User(name = "", age = 0) } - """) + """ + ) } fun `test can't fill class constructor`() { - doUnavailableTest(""" + doUnavailableTest( + """ class User(val name: String, val age: Int) fun test() { User("", 0) } - """) + """ + ) } fun `test fill function`() { - doAvailableTest(""" + doAvailableTest( + """ class User(val name: String, val age: Int) fun foo(s: String, t: Int, u: User) {} fun test() { foo() } - """, """ + """, + """ class User(val name: String, val age: Int) fun foo(s: String, t: Int, u: User) {} fun test() { foo(s = "", t = 0, u = User(name = "", age = 0)) } - """, "Fill function") + """, + "Fill function" + ) } fun `test can't fill function`() { - doUnavailableTest(""" + doUnavailableTest( + """ fun foo(s: String, t: Int) {} fun test() { foo("", 0) } - """) + """ + ) } fun `test fill for non primitive types`() { - doAvailableTest(""" + doAvailableTest( + """ class A(a1: String, a2: Int) class B(b1: Int, b2: String, a: A) class C @@ -64,7 +76,8 @@ class FillClassInspectionTest : BasePlatformTestCase() { fun test() { D() } - """, """ + """, + """ class A(a1: String, a2: Int) class B(b1: Int, b2: String, a: A) class C @@ -72,11 +85,13 @@ class FillClassInspectionTest : BasePlatformTestCase() { fun test() { D(a = A(a1 = "", a2 = 0), b = B(b1 = 0, b2 = "", a = A(a1 = "", a2 = 0)), c = C(), r =) } - """) + """ + ) } fun `test don't add default value for enum,abstract,sealed`() { - doAvailableTest(""" + doAvailableTest( + """ enum class A(val a: String) { Foo("foo"), Bar("bar"), Baz("baz"); } @@ -86,7 +101,8 @@ class FillClassInspectionTest : BasePlatformTestCase() { fun test() { Test() } - """, """ + """, + """ enum class A(val a: String) { Foo("foo"), Bar("bar"), Baz("baz"); } @@ -96,7 +112,8 @@ class FillClassInspectionTest : BasePlatformTestCase() { fun test() { Test(a =, b =, c =) } - """) + """ + ) } fun `test add import directives`() { @@ -106,16 +123,20 @@ class FillClassInspectionTest : BasePlatformTestCase() { class A class B(a: A) """ - doAvailableTest(""" + doAvailableTest( + """ import com.example.B val b = B() - """, """ + """, + """ import com.example.A import com.example.B val b = B(a = A()) - """, dependencies = listOf(dependency)) + """, + dependencies = listOf(dependency) + ) } fun `test call java constructor`() { @@ -125,11 +146,14 @@ class FillClassInspectionTest : BasePlatformTestCase() { } } """ - doUnavailableTest(""" + doUnavailableTest( + """ fun test() { Java() } - """, javaDependencies = listOf(javaDependency)) + """, + javaDependencies = listOf(javaDependency) + ) } fun `test call java method`() { @@ -142,49 +166,63 @@ class FillClassInspectionTest : BasePlatformTestCase() { } } """ - doUnavailableTest(""" + doUnavailableTest( + """ fun test() { Java("").foo() } - """, javaDependencies = listOf(javaDependency)) + """, + javaDependencies = listOf(javaDependency) + ) } fun `test fill super type call entry`() { - doAvailableTest(""" + doAvailableTest( + """ open class C(p1: Int, p2: Int) class D : C() - """, """ + """, + """ open class C(p1: Int, p2: Int) class D : C(p1 = 0, p2 = 0) - """) + """ + ) } fun `test fill class constructor without default values`() { - doAvailableTest(""" + doAvailableTest( + """ class User(val name: String, val age: Int) fun test() { User() } - """, """ + """, + """ class User(val name: String, val age: Int) fun test() { User(name =, age =) } - """, withoutDefaultValues = true) + """, + withoutDefaultValues = true + ) } fun `test do not fill default arguments`() { - doAvailableTest(""" + doAvailableTest( + """ class User(val name: String, val age: Int = 0) fun test() { User() } - """, """ + """, + """ class User(val name: String, val age: Int = 0) fun test() { User(name = "") } - """, withoutDefaultArguments = true) + """, + withoutDefaultArguments = true + ) } fun `test fill lambda arguments`() { @@ -196,20 +234,24 @@ class FillClassInspectionTest : BasePlatformTestCase() { class B(f1: () -> Unit, f2: (Int) -> String, f3: (Int, String?, A) -> String) """.trimIndent() - doAvailableTest(""" + doAvailableTest( + """ import foo.B fun test() { B() } - """, """ + """, + """ import foo.A import foo.B fun test() { B(f1 = {}, f2 = {}, f3 = { i: Int, s: String?, a: A -> }) } - """, withoutDefaultArguments = true, dependencies = listOf(dependency)) + """, + withoutDefaultArguments = true, dependencies = listOf(dependency) + ) } private fun doAvailableTest(