From 93a89b347b2de99a05d2f6c1013c6b93026c5ff3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Antonio=20L=C3=B3pez=20Mar=C3=ADn?= Date: Mon, 14 Oct 2019 11:31:20 +0200 Subject: [PATCH] Fix multiplatform support (#8) * Fix kotlin multiplatform and added an example * Removed android target source at this moment * Remove unnecessary iOS project in multiplatform example * Fix travis file and added next release * Add android to travis * Fix kotlin-example * Remove unnecessary repositories * Fix Travis CI integration (#9) * Update travis file * Add licenses configuration * Add missing build tool * Apply review suggestions --- .editorconfig | 4 +- .travis.yml | 27 ++- README.md | 4 +- build.gradle | 4 +- .../kotlin-example}/.gitignore | 0 .../kotlin-example}/build.gradle | 6 +- .../kotlin-example}/gradle.properties | 0 .../gradle/wrapper/gradle-wrapper.jar | Bin .../gradle/wrapper/gradle-wrapper.properties | 0 {example => examples/kotlin-example}/gradlew | 0 .../kotlin-example}/gradlew.bat | 0 .../kotlin-example}/settings.gradle | 0 .../main/kotlin/com/karumi/example/Main.kt | 0 .../kotlin/com/karumi/example/MainTest.kt | 1 - examples/multiplatform-example/.gitignore | 40 ++++ .../android/build.gradle | 41 +++++ .../android/src/main/AndroidManifest.xml | 20 ++ .../com/example/karumi/hagu/MainActivity.kt | 15 ++ .../src/main/res/layout/main_activity.xml | 11 ++ .../src/main/res/mipmap-hdpi/ic_launcher.png | Bin 0 -> 2863 bytes .../src/main/res/mipmap-mdpi/ic_launcher.png | Bin 0 -> 1803 bytes .../src/main/res/mipmap-xhdpi/ic_launcher.png | Bin 0 -> 4400 bytes .../main/res/mipmap-xxhdpi/ic_launcher.png | Bin 0 -> 7884 bytes .../main/res/mipmap-xxxhdpi/ic_launcher.png | Bin 0 -> 11267 bytes .../android/src/main/res/values/dimens.xml | 4 + .../android/src/main/res/values/strings.xml | 3 + .../java/com/karumi/hagu/AndroidSharedTest.kt | 19 ++ examples/multiplatform-example/build.gradle | 25 +++ .../multiplatform-example/gradle.properties | 1 + .../gradle/wrapper/gradle-wrapper.jar | Bin 0 -> 56177 bytes .../gradle/wrapper/gradle-wrapper.properties | 6 + examples/multiplatform-example/gradlew | 172 ++++++++++++++++++ examples/multiplatform-example/gradlew.bat | 84 +++++++++ .../multiplatform-example/settings.gradle | 3 + .../multiplatform-example/shared/build.gradle | 77 ++++++++ .../shared/gradle.properties | 2 + .../shared/settings.properties | 1 + .../hagu/multiplatform/AndroidLogger.kt | 7 + .../com/karumi/hagu/multiplatform/Logger.kt | 10 + .../karumi/hagu/multiplatform/SharedTest.kt | 18 ++ .../karumi/hagu/multiplatform/IOSLogger.kt | 13 ++ .../shared/src/main/AndroidManifest.xml | 5 + plugin/build.gradle | 19 +- plugin/gradle.properties | 8 +- .../com/karumi/hagu/plugin/HaguPlugin.kt | 33 +++- .../hagu/plugin/{HaguTasks.kt => HaguTask.kt} | 27 ++- .../hagu/plugin/KotlinConfigGenerator.kt | 9 +- .../karumi/hagu/plugin/source/SourceRoots.kt | 67 +++++++ .../karumi/hagu/plugin/source/SourceSets.kt | 25 +++ ....properties => com.karumi.hagu.properties} | 0 .../hagu/plugin/KotlinConfigGeneratorTest.kt | 2 +- 51 files changed, 766 insertions(+), 47 deletions(-) rename {example => examples/kotlin-example}/.gitignore (100%) mode change 100644 => 100755 rename {example => examples/kotlin-example}/build.gradle (82%) mode change 100644 => 100755 rename {example => examples/kotlin-example}/gradle.properties (100%) mode change 100644 => 100755 rename {example => examples/kotlin-example}/gradle/wrapper/gradle-wrapper.jar (100%) mode change 100644 => 100755 rename {example => examples/kotlin-example}/gradle/wrapper/gradle-wrapper.properties (100%) mode change 100644 => 100755 rename {example => examples/kotlin-example}/gradlew (100%) rename {example => examples/kotlin-example}/gradlew.bat (100%) mode change 100644 => 100755 rename {example => examples/kotlin-example}/settings.gradle (100%) mode change 100644 => 100755 rename {example => examples/kotlin-example}/src/main/kotlin/com/karumi/example/Main.kt (100%) mode change 100644 => 100755 rename {example => examples/kotlin-example}/src/test/kotlin/com/karumi/example/MainTest.kt (99%) mode change 100644 => 100755 create mode 100644 examples/multiplatform-example/.gitignore create mode 100644 examples/multiplatform-example/android/build.gradle create mode 100644 examples/multiplatform-example/android/src/main/AndroidManifest.xml create mode 100644 examples/multiplatform-example/android/src/main/java/com/example/karumi/hagu/MainActivity.kt create mode 100644 examples/multiplatform-example/android/src/main/res/layout/main_activity.xml create mode 100644 examples/multiplatform-example/android/src/main/res/mipmap-hdpi/ic_launcher.png create mode 100644 examples/multiplatform-example/android/src/main/res/mipmap-mdpi/ic_launcher.png create mode 100644 examples/multiplatform-example/android/src/main/res/mipmap-xhdpi/ic_launcher.png create mode 100644 examples/multiplatform-example/android/src/main/res/mipmap-xxhdpi/ic_launcher.png create mode 100644 examples/multiplatform-example/android/src/main/res/mipmap-xxxhdpi/ic_launcher.png create mode 100644 examples/multiplatform-example/android/src/main/res/values/dimens.xml create mode 100644 examples/multiplatform-example/android/src/main/res/values/strings.xml create mode 100644 examples/multiplatform-example/android/src/test/java/com/karumi/hagu/AndroidSharedTest.kt create mode 100644 examples/multiplatform-example/build.gradle create mode 100644 examples/multiplatform-example/gradle.properties create mode 100644 examples/multiplatform-example/gradle/wrapper/gradle-wrapper.jar create mode 100644 examples/multiplatform-example/gradle/wrapper/gradle-wrapper.properties create mode 100755 examples/multiplatform-example/gradlew create mode 100644 examples/multiplatform-example/gradlew.bat create mode 100644 examples/multiplatform-example/settings.gradle create mode 100644 examples/multiplatform-example/shared/build.gradle create mode 100644 examples/multiplatform-example/shared/gradle.properties create mode 100644 examples/multiplatform-example/shared/settings.properties create mode 100644 examples/multiplatform-example/shared/src/androidMain/kotlin/com/karumi/hagu/multiplatform/AndroidLogger.kt create mode 100644 examples/multiplatform-example/shared/src/commonMain/kotlin/com/karumi/hagu/multiplatform/Logger.kt create mode 100644 examples/multiplatform-example/shared/src/commonTest/kotlin/com/karumi/hagu/multiplatform/SharedTest.kt create mode 100644 examples/multiplatform-example/shared/src/iosMain/kotlin/com/karumi/hagu/multiplatform/IOSLogger.kt create mode 100644 examples/multiplatform-example/shared/src/main/AndroidManifest.xml rename plugin/src/main/kotlin/com/karumi/hagu/plugin/{HaguTasks.kt => HaguTask.kt} (55%) create mode 100644 plugin/src/main/kotlin/com/karumi/hagu/plugin/source/SourceRoots.kt create mode 100644 plugin/src/main/kotlin/com/karumi/hagu/plugin/source/SourceSets.kt rename plugin/src/main/resources/META-INF/gradle-plugins/{hagu.properties => com.karumi.hagu.properties} (100%) diff --git a/.editorconfig b/.editorconfig index 8e5e26e..8e72deb 100644 --- a/.editorconfig +++ b/.editorconfig @@ -4,7 +4,7 @@ root = true end_of_line = lf insert_final_newline = true -[*.{kt,kts}] +[*.{kt, kts}] indent_size = 2 insert_final_newline = false -max_line_length=100 +max_line_length = 100 diff --git a/.travis.yml b/.travis.yml index 030bcf1..2c96a00 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,10 +1,25 @@ -language: java - -jdk: - - oraclejdk11 +language: android +dist: trusty +android: + components: + - tools + - platform-tools + - build-tools-28.0.0-rc02 + - build-tools-28.0.3 + - build-tools-27.0.3 + - android-27 + - android-28 + - extra-android-support + - extra-google-m2repository + - extra-android-m2repository + licenses: + - 'android-sdk-preview-license-52d11cd2' + - 'android-sdk-license-.+' + - 'google-gdk-license-.+' script: - ./gradlew ktlint test install --info - - ./gradlew install - - cd example + - cd examples/kotlin-example + - ./gradlew test --info + - cd ../multiplatform-example - ./gradlew test --info diff --git a/README.md b/README.md index aaf2e17..8f18482 100644 --- a/README.md +++ b/README.md @@ -15,11 +15,11 @@ buildscript { } dependencies { - classpath 'com.karumi.hagu:hagu:0.1.1' + classpath 'com.karumi.hagu:hagu:0.1.3-SNAPSHOT' } } -apply plugin: 'hagu' +apply plugin: 'com.karumi.hagu' kotlin.sourceSets["main"].kotlin.srcDirs("$buildDir/generated/kotlin/config") ``` diff --git a/build.gradle b/build.gradle index 28e8960..8d9a5f0 100644 --- a/build.gradle +++ b/build.gradle @@ -12,5 +12,5 @@ buildscript { allprojects { group 'com.karumi.hagu' - version '0.1.1' -} \ No newline at end of file + version '0.1.3-SNAPSHOT' +} diff --git a/example/.gitignore b/examples/kotlin-example/.gitignore old mode 100644 new mode 100755 similarity index 100% rename from example/.gitignore rename to examples/kotlin-example/.gitignore diff --git a/example/build.gradle b/examples/kotlin-example/build.gradle old mode 100644 new mode 100755 similarity index 82% rename from example/build.gradle rename to examples/kotlin-example/build.gradle index 47e1c66..4ea933c --- a/example/build.gradle +++ b/examples/kotlin-example/build.gradle @@ -3,16 +3,16 @@ buildscript { repositories { mavenCentral() - maven { url uri("../repo") } + maven { url uri("../../repo") } } dependencies { classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" - classpath 'com.karumi.hagu:hagu:0.1.1' + classpath 'com.karumi.hagu:gradle-plugin:0.1.3-SNAPSHOT' } } apply plugin: 'kotlin' -apply plugin: 'hagu' +apply plugin: 'com.karumi.hagu' sourceCompatibility = 1.8 diff --git a/example/gradle.properties b/examples/kotlin-example/gradle.properties old mode 100644 new mode 100755 similarity index 100% rename from example/gradle.properties rename to examples/kotlin-example/gradle.properties diff --git a/example/gradle/wrapper/gradle-wrapper.jar b/examples/kotlin-example/gradle/wrapper/gradle-wrapper.jar old mode 100644 new mode 100755 similarity index 100% rename from example/gradle/wrapper/gradle-wrapper.jar rename to examples/kotlin-example/gradle/wrapper/gradle-wrapper.jar diff --git a/example/gradle/wrapper/gradle-wrapper.properties b/examples/kotlin-example/gradle/wrapper/gradle-wrapper.properties old mode 100644 new mode 100755 similarity index 100% rename from example/gradle/wrapper/gradle-wrapper.properties rename to examples/kotlin-example/gradle/wrapper/gradle-wrapper.properties diff --git a/example/gradlew b/examples/kotlin-example/gradlew similarity index 100% rename from example/gradlew rename to examples/kotlin-example/gradlew diff --git a/example/gradlew.bat b/examples/kotlin-example/gradlew.bat old mode 100644 new mode 100755 similarity index 100% rename from example/gradlew.bat rename to examples/kotlin-example/gradlew.bat diff --git a/example/settings.gradle b/examples/kotlin-example/settings.gradle old mode 100644 new mode 100755 similarity index 100% rename from example/settings.gradle rename to examples/kotlin-example/settings.gradle diff --git a/example/src/main/kotlin/com/karumi/example/Main.kt b/examples/kotlin-example/src/main/kotlin/com/karumi/example/Main.kt old mode 100644 new mode 100755 similarity index 100% rename from example/src/main/kotlin/com/karumi/example/Main.kt rename to examples/kotlin-example/src/main/kotlin/com/karumi/example/Main.kt diff --git a/example/src/test/kotlin/com/karumi/example/MainTest.kt b/examples/kotlin-example/src/test/kotlin/com/karumi/example/MainTest.kt old mode 100644 new mode 100755 similarity index 99% rename from example/src/test/kotlin/com/karumi/example/MainTest.kt rename to examples/kotlin-example/src/test/kotlin/com/karumi/example/MainTest.kt index 5cf04a0..e075ae3 --- a/example/src/test/kotlin/com/karumi/example/MainTest.kt +++ b/examples/kotlin-example/src/test/kotlin/com/karumi/example/MainTest.kt @@ -15,5 +15,4 @@ class MainTest { fun `hagu configuration file should contains number key`() { assertEquals(11, HaguConfig.NUMBER_KEY) } - } \ No newline at end of file diff --git a/examples/multiplatform-example/.gitignore b/examples/multiplatform-example/.gitignore new file mode 100644 index 0000000..62a024c --- /dev/null +++ b/examples/multiplatform-example/.gitignore @@ -0,0 +1,40 @@ +# Compiled class file +*.class + +# Log file +*.log + +# BlueJ files +*.ctxt + +# Mobile Tools for Java (J2ME) +.mtj.tmp/ + +# Package Files # +*.war +*.nar +*.ear +*.zip +*.tar.gz +*.rar + +logs +target +/.idea +/.idea_modules +/.classpath +/.project +/.settings +.vscode +/RUNNING_PID +**/.DS_Store +.gradle/ +build +out/ +.kotlintest +local.properties +*.iml +*/Pods + +# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml +hs_err_pid* diff --git a/examples/multiplatform-example/android/build.gradle b/examples/multiplatform-example/android/build.gradle new file mode 100644 index 0000000..8bcefe4 --- /dev/null +++ b/examples/multiplatform-example/android/build.gradle @@ -0,0 +1,41 @@ +apply plugin: 'com.android.application' +apply plugin: 'kotlin-android' + +android { + compileSdkVersion 28 + + compileOptions { + sourceCompatibility JavaVersion.VERSION_1_7 + targetCompatibility JavaVersion.VERSION_1_7 + } + + lintOptions { + textOutput 'stdout' + } + + defaultConfig { + minSdkVersion 14 + targetSdkVersion 28 + + applicationId 'com.example.karumi.hagu' + + versionCode 1 + versionName '1.0' + } + + buildTypes { + debug { + applicationIdSuffix '.development' + signingConfig signingConfigs.debug + } + } +} + +dependencies { + implementation project(':shared') + + implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk8:$kotlin_version" + implementation "com.android.support:appcompat-v7:28.0.0" + + testImplementation group: 'junit', name: 'junit', version: '4.12' +} diff --git a/examples/multiplatform-example/android/src/main/AndroidManifest.xml b/examples/multiplatform-example/android/src/main/AndroidManifest.xml new file mode 100644 index 0000000..49b3228 --- /dev/null +++ b/examples/multiplatform-example/android/src/main/AndroidManifest.xml @@ -0,0 +1,20 @@ + + + + + + + + + + + + + + diff --git a/examples/multiplatform-example/android/src/main/java/com/example/karumi/hagu/MainActivity.kt b/examples/multiplatform-example/android/src/main/java/com/example/karumi/hagu/MainActivity.kt new file mode 100644 index 0000000..7d2583c --- /dev/null +++ b/examples/multiplatform-example/android/src/main/java/com/example/karumi/hagu/MainActivity.kt @@ -0,0 +1,15 @@ +package com.example.karumi.hagu + +import android.os.Bundle +import android.support.v7.app.AppCompatActivity +import android.widget.TextView +import com.karumi.hagu.generated.HaguConfig + +class MainActivity : AppCompatActivity() { + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + setContentView(R.layout.main_activity) + + findViewById(R.id.messageTextView).text = "$HaguConfig.API_KEY" + } +} \ No newline at end of file diff --git a/examples/multiplatform-example/android/src/main/res/layout/main_activity.xml b/examples/multiplatform-example/android/src/main/res/layout/main_activity.xml new file mode 100644 index 0000000..0fbc2bd --- /dev/null +++ b/examples/multiplatform-example/android/src/main/res/layout/main_activity.xml @@ -0,0 +1,11 @@ + + + + + + diff --git a/examples/multiplatform-example/android/src/main/res/mipmap-hdpi/ic_launcher.png b/examples/multiplatform-example/android/src/main/res/mipmap-hdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..edb98c82650abde6de43d8e520f8ee9e2b9b39f3 GIT binary patch literal 2863 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 N002ovPDHLkV1m6`OGy9# literal 0 HcmV?d00001 diff --git a/examples/multiplatform-example/android/src/main/res/mipmap-mdpi/ic_launcher.png b/examples/multiplatform-example/android/src/main/res/mipmap-mdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..64478427f6611110d8b20c3f4c8ccf69cd853f20 GIT binary patch literal 1803 zcmV+m2lV)fP)-9 za*04hg+;ctyFuG+U9S|FYup=xwHV`0^2<5v<(%LD zInR0DbJhnQm|bR<+2#MU2n2!$5&y~kvskP-YExO6VsIM|ZO3B&vi>5TWT3D#7W;<> zNO@RdDEL}^w$v&3qVR=i?|=zYQ!YMkPdol$cE9wDKQ&Z;_?OK4XMBA8V;>*QRjD2PadCGE-&+iAr>Cbs^hO1d zDA&BcRynY(w8gZg9D%l_U0c@_3pPE9KI8vAQ72Zau#w~ChhI^`V=Ro>b$|}OcvYCHeRM+fs#Ih@6DqEq~pD&v+)wYAjI;^5y^If{VF!J}w)6naoQivDi06xo#n z{Jk};yysK5rq2CPmAkCbLjEc`&Aq(nsrk>KW5jeMN=!^lDBHWCOl2<_R}7Y%Xf~G} zQ=cpS1Ii&mpz;tH0MT@|0Fn=y?1f{EM&1!wKiMj`5`Xe`ui+;pCC$4pLuuNoB}=7e z3cqVPR|3=&#UPXbw7fe2MCqokhjVG^ij*a>9HKqTo@Vm#W=mNY6u;ZT$j>l<;w*W$ zaj-!9fh=cHY^#4fe~H@0HzV0Fy#;K{FM82Oyu9G<0h*td|iNi*a3X2 z?;QXkH<7*D>(?!e`skw^C~0mvSA5S$e8$xe44|-M_r!XlF>0d`y0B_Bylk~!)zMk# z{jm{TxiJF1z1k0se)D$70gep41uk9f1HarD23?oMbRbF|r?KHca0=TTm5Z9FU?nzN ziiem=Gkkt=2e{?D0mjD0D29L2g}7cJFmk)+kFE-Rpw585ynldZxJI94zBlS}g5ww84+zj`!^ef%T;7b%!fI^w zJcX&qpz`T)ngi!wg{{*EoUYs8rt=!m{2-cEp6UIL@Are7cdh~F=q)fpow*_(c`AS% z17ahl%gD%xk2pXDyhCiV@tnZ|pjJWG!j~gE!DmBnP9q<9@gBPH8f?S&0{h=9fXss3 zEI}X7psu3M<8zShyTmns=s~RFiXt}Oxh|ml4cTFc;cXGVQb;G97 zvPTg@Z4O0sXU^!}Q<-|?5>WtA4{odJB;c$_0AU-X9nwKltsww<53wIo+l7PLZb%Q@ z?j?W-Qg<411_yOIntDCNfO(PUL!E)^hU10{gk3q-hy%cj*ru@Ng9aT5L|ss-8`9$~ zM^mpSK!X8?z;z!1#Qg-2AO;{t97qQVAT!}WW`e;Nhl4)&F~J>LV!j$aw|2O*n2JcGBq%&UFmu=;Y_R6Xx2PY1}FNdT^unKgr2gfHQ03T50XXlfz@}9^{DdJJUT$A^7k_U0$s3-ywr?Q z@>BpQFLMW&Y^a<}9#I=jPg*xA{AbOeGpHAow3)swkXt6?<)O&C#Tj{tg?+E$tC!^w-cGaTq_2Bo zMfu^E4hb~bLqcu#a7bvfhb!B&hN~dVx=I7lW(^CpSr@&j(q>N3u^FC^X0q4A;lBL0dUlyzW|x0=`3LS>eus@ZVvYa+002ovPDHLkV1h?NSc(7u literal 0 HcmV?d00001 diff --git a/examples/multiplatform-example/android/src/main/res/mipmap-xhdpi/ic_launcher.png b/examples/multiplatform-example/android/src/main/res/mipmap-xhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..7bbbe376dd770d9f807a0363faa303f6987eb290 GIT binary patch literal 4400 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 literal 0 HcmV?d00001 diff --git a/examples/multiplatform-example/android/src/main/res/values/dimens.xml b/examples/multiplatform-example/android/src/main/res/values/dimens.xml new file mode 100644 index 0000000..d781ec5 --- /dev/null +++ b/examples/multiplatform-example/android/src/main/res/values/dimens.xml @@ -0,0 +1,4 @@ + + + + diff --git a/examples/multiplatform-example/android/src/main/res/values/strings.xml b/examples/multiplatform-example/android/src/main/res/values/strings.xml new file mode 100644 index 0000000..aa9b982 --- /dev/null +++ b/examples/multiplatform-example/android/src/main/res/values/strings.xml @@ -0,0 +1,3 @@ + + Hagu example + diff --git a/examples/multiplatform-example/android/src/test/java/com/karumi/hagu/AndroidSharedTest.kt b/examples/multiplatform-example/android/src/test/java/com/karumi/hagu/AndroidSharedTest.kt new file mode 100644 index 0000000..fd82d46 --- /dev/null +++ b/examples/multiplatform-example/android/src/test/java/com/karumi/hagu/AndroidSharedTest.kt @@ -0,0 +1,19 @@ +package com.karumi.hagu + +import com.karumi.hagu.generated.HaguConfig + +import org.junit.Test +import junit.framework.TestCase.assertEquals + +class AndroidSharedTest { + + @Test + fun `hagu configuration file should be accessible from android`() { + assertEquals("some_api_key", HaguConfig.API_KEY) + } + + @Test + fun `hagu configuration file should contains number key`() { + assertEquals(11, HaguConfig.NUMBER_KEY) + } +} \ No newline at end of file diff --git a/examples/multiplatform-example/build.gradle b/examples/multiplatform-example/build.gradle new file mode 100644 index 0000000..e4ffc73 --- /dev/null +++ b/examples/multiplatform-example/build.gradle @@ -0,0 +1,25 @@ +buildscript { + ext.kotlin_version = '1.3.50' + + repositories { + mavenCentral() + maven { url uri("../../repo") } + google() + jcenter() + maven { url 'https://plugins.gradle.org/m2/' } + } + + dependencies { + classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" + classpath 'com.android.tools.build:gradle:3.5.0' + classpath 'com.karumi.hagu:gradle-plugin:0.1.3-SNAPSHOT' + } +} + +allprojects { + repositories { + mavenCentral() + google() + jcenter() + } +} diff --git a/examples/multiplatform-example/gradle.properties b/examples/multiplatform-example/gradle.properties new file mode 100644 index 0000000..7fc6f1f --- /dev/null +++ b/examples/multiplatform-example/gradle.properties @@ -0,0 +1 @@ +kotlin.code.style=official diff --git a/examples/multiplatform-example/gradle/wrapper/gradle-wrapper.jar b/examples/multiplatform-example/gradle/wrapper/gradle-wrapper.jar new file mode 100644 index 0000000000000000000000000000000000000000..94336fcae912db8a11d55634156fa011f4686124 GIT binary patch literal 56177 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 i;x|p)^~-yfPOPa3(|vBayXKz \(.*\)$'` + if expr "$link" : '/.*' > /dev/null; then + PRG="$link" + else + PRG=`dirname "$PRG"`"/$link" + fi +done +SAVED="`pwd`" +cd "`dirname \"$PRG\"`/" >/dev/null +APP_HOME="`pwd -P`" +cd "$SAVED" >/dev/null + +APP_NAME="Gradle" +APP_BASE_NAME=`basename "$0"` + +# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. +DEFAULT_JVM_OPTS="" + +# Use the maximum available, or set MAX_FD != -1 to use that value. +MAX_FD="maximum" + +warn () { + echo "$*" +} + +die () { + echo + echo "$*" + echo + exit 1 +} + +# OS specific support (must be 'true' or 'false'). +cygwin=false +msys=false +darwin=false +nonstop=false +case "`uname`" in + CYGWIN* ) + cygwin=true + ;; + Darwin* ) + darwin=true + ;; + MINGW* ) + msys=true + ;; + NONSTOP* ) + nonstop=true + ;; +esac + +CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar + +# Determine the Java command to use to start the JVM. +if [ -n "$JAVA_HOME" ] ; then + if [ -x "$JAVA_HOME/jre/sh/java" ] ; then + # IBM's JDK on AIX uses strange locations for the executables + JAVACMD="$JAVA_HOME/jre/sh/java" + else + JAVACMD="$JAVA_HOME/bin/java" + fi + if [ ! -x "$JAVACMD" ] ; then + die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME + +Please set the JAVA_HOME variable in your environment to match the +location of your Java installation." + fi +else + JAVACMD="java" + which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. + +Please set the JAVA_HOME variable in your environment to match the +location of your Java installation." +fi + +# Increase the maximum file descriptors if we can. +if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then + MAX_FD_LIMIT=`ulimit -H -n` + if [ $? -eq 0 ] ; then + if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then + MAX_FD="$MAX_FD_LIMIT" + fi + ulimit -n $MAX_FD + if [ $? -ne 0 ] ; then + warn "Could not set maximum file descriptor limit: $MAX_FD" + fi + else + warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" + fi +fi + +# For Darwin, add options to specify how the application appears in the dock +if $darwin; then + GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" +fi + +# For Cygwin, switch paths to Windows format before running java +if $cygwin ; then + APP_HOME=`cygpath --path --mixed "$APP_HOME"` + CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` + JAVACMD=`cygpath --unix "$JAVACMD"` + + # We build the pattern for arguments to be converted via cygpath + ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` + SEP="" + for dir in $ROOTDIRSRAW ; do + ROOTDIRS="$ROOTDIRS$SEP$dir" + SEP="|" + done + OURCYGPATTERN="(^($ROOTDIRS))" + # Add a user-defined pattern to the cygpath arguments + if [ "$GRADLE_CYGPATTERN" != "" ] ; then + OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" + fi + # Now convert the arguments - kludge to limit ourselves to /bin/sh + i=0 + for arg in "$@" ; do + CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` + CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option + + if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition + eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` + else + eval `echo args$i`="\"$arg\"" + fi + i=$((i+1)) + done + case $i in + (0) set -- ;; + (1) set -- "$args0" ;; + (2) set -- "$args0" "$args1" ;; + (3) set -- "$args0" "$args1" "$args2" ;; + (4) set -- "$args0" "$args1" "$args2" "$args3" ;; + (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; + (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; + (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; + (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; + (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; + esac +fi + +# Escape application args +save () { + for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done + echo " " +} +APP_ARGS=$(save "$@") + +# Collect all arguments for the java command, following the shell quoting and substitution rules +eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS" + +# by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong +if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then + cd "$(dirname "$0")" +fi + +exec "$JAVACMD" "$@" diff --git a/examples/multiplatform-example/gradlew.bat b/examples/multiplatform-example/gradlew.bat new file mode 100644 index 0000000..e95643d --- /dev/null +++ b/examples/multiplatform-example/gradlew.bat @@ -0,0 +1,84 @@ +@if "%DEBUG%" == "" @echo off +@rem ########################################################################## +@rem +@rem Gradle startup script for Windows +@rem +@rem ########################################################################## + +@rem Set local scope for the variables with windows NT shell +if "%OS%"=="Windows_NT" setlocal + +set DIRNAME=%~dp0 +if "%DIRNAME%" == "" set DIRNAME=. +set APP_BASE_NAME=%~n0 +set APP_HOME=%DIRNAME% + +@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. +set DEFAULT_JVM_OPTS= + +@rem Find java.exe +if defined JAVA_HOME goto findJavaFromJavaHome + +set JAVA_EXE=java.exe +%JAVA_EXE% -version >NUL 2>&1 +if "%ERRORLEVEL%" == "0" goto init + +echo. +echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. +echo. +echo Please set the JAVA_HOME variable in your environment to match the +echo location of your Java installation. + +goto fail + +:findJavaFromJavaHome +set JAVA_HOME=%JAVA_HOME:"=% +set JAVA_EXE=%JAVA_HOME%/bin/java.exe + +if exist "%JAVA_EXE%" goto init + +echo. +echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% +echo. +echo Please set the JAVA_HOME variable in your environment to match the +echo location of your Java installation. + +goto fail + +:init +@rem Get command-line arguments, handling Windows variants + +if not "%OS%" == "Windows_NT" goto win9xME_args + +:win9xME_args +@rem Slurp the command line arguments. +set CMD_LINE_ARGS= +set _SKIP=2 + +:win9xME_args_slurp +if "x%~1" == "x" goto execute + +set CMD_LINE_ARGS=%* + +:execute +@rem Setup the command line + +set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar + +@rem Execute Gradle +"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% + +:end +@rem End local scope for the variables with windows NT shell +if "%ERRORLEVEL%"=="0" goto mainEnd + +:fail +rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of +rem the _cmd.exe /c_ return code! +if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 +exit /b 1 + +:mainEnd +if "%OS%"=="Windows_NT" endlocal + +:omega diff --git a/examples/multiplatform-example/settings.gradle b/examples/multiplatform-example/settings.gradle new file mode 100644 index 0000000..7b3fa02 --- /dev/null +++ b/examples/multiplatform-example/settings.gradle @@ -0,0 +1,3 @@ +rootProject.name = 'multiplatform-example' + +include ':shared', ':android' diff --git a/examples/multiplatform-example/shared/build.gradle b/examples/multiplatform-example/shared/build.gradle new file mode 100644 index 0000000..cd7dc41 --- /dev/null +++ b/examples/multiplatform-example/shared/build.gradle @@ -0,0 +1,77 @@ +apply plugin: 'com.android.library' +apply plugin: "kotlin-multiplatform" +apply plugin: "com.karumi.hagu" + +group 'com.karumi.hagu.multiplatform' + +android { + defaultConfig { + compileSdkVersion 28 + } + packagingOptions { + exclude "META-INF/*" + } +} + +kotlin { + // This is for iPhone emulator + // Switch here to iosArm64 (or iosArm32) to build library for iPhone device + iosX64("ios") { + binaries { + framework("shared") + } + } + android() + + sourceSets { + commonMain { + dependencies { + implementation "org.jetbrains.kotlin:kotlin-stdlib-common:$kotlin_version" + } + } + commonTest { + dependencies { + implementation 'org.jetbrains.kotlin:kotlin-test-common' + implementation 'org.jetbrains.kotlin:kotlin-test-annotations-common' + } + } + androidMain { + dependencies { + implementation "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" + } + } + androidTest { + dependencies { + implementation "org.jetbrains.kotlin:kotlin-test-junit:$kotlin_version" + } + } + iosMain { + dependencies {} + } + } +} + +//This is to let Intellij import generated code +kotlin.sourceSets["commonMain"].kotlin.srcDirs("$buildDir/generated/kotlin/config") + +// This task attaches native framework built from ios module to Xcode project +// (see iosApp directory). Don't run this task directly, +// Xcode runs this task itself during its build process. +// Before opening the project from iosApp directory in Xcode, +// make sure all Gradle infrastructure exists (gradle.wrapper, gradlew). +task copyFramework { + final File frameworkDir = new File(buildDir, "xcode-frameworks") + def buildType = project.findProperty('kotlin.build.type') ?: 'DEBUG' + def framework = kotlin.targets.ios.compilations.main.target.binaries.findFramework("shared", buildType) + dependsOn framework.linkTask + + doLast { + def srcFile = framework.outputFile + copy { + from srcFile.parent + into frameworkDir + include 'Shared.framework/**' + include 'Shared.framework.dSYM' + } + } +} diff --git a/examples/multiplatform-example/shared/gradle.properties b/examples/multiplatform-example/shared/gradle.properties new file mode 100644 index 0000000..a5ab6a0 --- /dev/null +++ b/examples/multiplatform-example/shared/gradle.properties @@ -0,0 +1,2 @@ +api_key="some_api_key" +number_key=11 diff --git a/examples/multiplatform-example/shared/settings.properties b/examples/multiplatform-example/shared/settings.properties new file mode 100644 index 0000000..e6a275d --- /dev/null +++ b/examples/multiplatform-example/shared/settings.properties @@ -0,0 +1 @@ +enableFeaturePreview('GRADLE_METADATA') diff --git a/examples/multiplatform-example/shared/src/androidMain/kotlin/com/karumi/hagu/multiplatform/AndroidLogger.kt b/examples/multiplatform-example/shared/src/androidMain/kotlin/com/karumi/hagu/multiplatform/AndroidLogger.kt new file mode 100644 index 0000000..b4ec91f --- /dev/null +++ b/examples/multiplatform-example/shared/src/androidMain/kotlin/com/karumi/hagu/multiplatform/AndroidLogger.kt @@ -0,0 +1,7 @@ +package com.karumi.hagu.multiplatform + +import android.util.Log + +actual fun logInfo(tag: String, message: String) { + Log.i(tag, message) +} \ No newline at end of file diff --git a/examples/multiplatform-example/shared/src/commonMain/kotlin/com/karumi/hagu/multiplatform/Logger.kt b/examples/multiplatform-example/shared/src/commonMain/kotlin/com/karumi/hagu/multiplatform/Logger.kt new file mode 100644 index 0000000..30728fb --- /dev/null +++ b/examples/multiplatform-example/shared/src/commonMain/kotlin/com/karumi/hagu/multiplatform/Logger.kt @@ -0,0 +1,10 @@ +package com.karumi.hagu.multiplatform + +import com.karumi.hagu.generated.HaguConfig + +expect fun logInfo(tag: String, message: String) + +fun doThingsWithGeneratedCode() { + logInfo("Multiplatform", "API_KEY = ${HaguConfig.API_KEY}") + logInfo("Multiplatform", "API_KEY = ${HaguConfig.NUMBER_KEY}") +} \ No newline at end of file diff --git a/examples/multiplatform-example/shared/src/commonTest/kotlin/com/karumi/hagu/multiplatform/SharedTest.kt b/examples/multiplatform-example/shared/src/commonTest/kotlin/com/karumi/hagu/multiplatform/SharedTest.kt new file mode 100644 index 0000000..415f136 --- /dev/null +++ b/examples/multiplatform-example/shared/src/commonTest/kotlin/com/karumi/hagu/multiplatform/SharedTest.kt @@ -0,0 +1,18 @@ +package com.karumi.hagu.multiplatform + +import com.karumi.hagu.generated.HaguConfig +import kotlin.test.Test +import kotlin.test.assertEquals + +class SharedTest { + + @Test + fun `hagu configuration file should be accessible by common module`() { + assertEquals("some_api_key", HaguConfig.API_KEY) + } + + @Test + fun `hagu configuration file should contains number key`() { + assertEquals(11, HaguConfig.NUMBER_KEY) + } +} \ No newline at end of file diff --git a/examples/multiplatform-example/shared/src/iosMain/kotlin/com/karumi/hagu/multiplatform/IOSLogger.kt b/examples/multiplatform-example/shared/src/iosMain/kotlin/com/karumi/hagu/multiplatform/IOSLogger.kt new file mode 100644 index 0000000..16b0455 --- /dev/null +++ b/examples/multiplatform-example/shared/src/iosMain/kotlin/com/karumi/hagu/multiplatform/IOSLogger.kt @@ -0,0 +1,13 @@ +package com.karumi.hagu.multiplatform + +import com.karumi.hagu.generated.HaguConfig +import platform.Foundation.NSLog + +actual fun logInfo(tag: String, message: String) { + NSLog("$tag: $message") +} + +fun doThingsWithGeneratedIOSCode() { + logInfo("Multiplatform", "API_KEY = ${HaguConfig.API_KEY}") + logInfo("Multiplatform", "API_KEY = ${HaguConfig.NUMBER_KEY}") +} \ No newline at end of file diff --git a/examples/multiplatform-example/shared/src/main/AndroidManifest.xml b/examples/multiplatform-example/shared/src/main/AndroidManifest.xml new file mode 100644 index 0000000..1eac9e3 --- /dev/null +++ b/examples/multiplatform-example/shared/src/main/AndroidManifest.xml @@ -0,0 +1,5 @@ + + + + diff --git a/plugin/build.gradle b/plugin/build.gradle index 9b9ee77..95efa87 100644 --- a/plugin/build.gradle +++ b/plugin/build.gradle @@ -3,6 +3,7 @@ buildscript { repositories { mavenCentral() + google() } dependencies { classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" @@ -12,22 +13,38 @@ buildscript { apply plugin: 'kotlin' apply plugin: 'groovy' +apply plugin: 'java-gradle-plugin' apply plugin: 'com.karumi.kotlin-snapshot' repositories { mavenCentral() + google() } configurations { ktlint + fixtureClasspath } +// Append any extra dependencies to the test fixtures via a custom configuration classpath. This +// allows us to apply additional plugins in a fixture while still leveraging dependency resolution +// and de-duplication semantics. +tasks.getByName('pluginUnderTestMetadata'). + getPluginClasspath(). + from(configurations.fixtureClasspath) + dependencies { implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk8" + implementation "org.jetbrains.kotlin:kotlin-gradle-plugin:${kotlin_version}" + implementation gradleApi() implementation localGroovy() + ktlint "com.pinterest:ktlint:0.34.2" - implementation group: 'junit', name: 'junit', version: '4.12' + + testImplementation group: 'junit', name: 'junit', version: '4.12' + + fixtureClasspath "org.jetbrains.kotlin:kotlin-gradle-plugin:${kotlin_version}" } compileKotlin { diff --git a/plugin/gradle.properties b/plugin/gradle.properties index bbc3b50..4e348b7 100644 --- a/plugin/gradle.properties +++ b/plugin/gradle.properties @@ -1,10 +1,8 @@ -POM_NAME=hagu -POM_ARTIFACT_ID=hagu +POM_NAME=gradle-plugin +POM_ARTIFACT_ID=gradle-plugin POM_PACKAGING=jar - -VERSION_NAME=0.1.1 +VERSION_NAME=0.1.3-SNAPSHOT GROUP=com.karumi.hagu - POM_DESCRIPTION=Kotlin configuration file for multiplatform. POM_URL=https://github.com/Karumi/Hagu POM_SCM_URL=https://github.com/Karumi/hagu diff --git a/plugin/src/main/kotlin/com/karumi/hagu/plugin/HaguPlugin.kt b/plugin/src/main/kotlin/com/karumi/hagu/plugin/HaguPlugin.kt index 3685963..fd4d96b 100644 --- a/plugin/src/main/kotlin/com/karumi/hagu/plugin/HaguPlugin.kt +++ b/plugin/src/main/kotlin/com/karumi/hagu/plugin/HaguPlugin.kt @@ -1,20 +1,41 @@ package com.karumi.hagu.plugin +import com.karumi.hagu.plugin.source.sources +import java.io.File import org.gradle.api.Plugin import org.gradle.api.Project +import org.jetbrains.kotlin.gradle.plugin.KotlinPlatformType class HaguPlugin : Plugin { + companion object { + private const val HAGU_GENERATED_SOURCE_FOLDER = "generated/kotlin/config" + } + override fun apply(project: Project) { project.afterEvaluate(::addTasks) } private fun addTasks(project: Project) { - val hagoBuildTask = project.tasks.create( - BuildHagu.NAME, - BuildHagu::class.java - ) - val buildTask = project.tasks.findByName("compileKotlin") - buildTask?.dependsOn(hagoBuildTask) + val outputDirectory = File(project.buildDir, HAGU_GENERATED_SOURCE_FOLDER) + val task = project.tasks.register( + HaguTask.NAME, + HaguTask::class.java + ) { + it.generatedSourceOutput = outputDirectory + } + + val sources = sources(project) + + val common = sources.singleOrNull { it.type == KotlinPlatformType.common } + common?.sourceDirectorySet?.srcDir(outputDirectory.toRelativeString(project.projectDir)) + + sources.forEach { source -> + if (common == null) { + source.sourceDirectorySet.srcDir(outputDirectory.toRelativeString(project.projectDir)) + } + + source.registerTaskDependency(task) + } } } \ No newline at end of file diff --git a/plugin/src/main/kotlin/com/karumi/hagu/plugin/HaguTasks.kt b/plugin/src/main/kotlin/com/karumi/hagu/plugin/HaguTask.kt similarity index 55% rename from plugin/src/main/kotlin/com/karumi/hagu/plugin/HaguTasks.kt rename to plugin/src/main/kotlin/com/karumi/hagu/plugin/HaguTask.kt index b740f9a..018f467 100644 --- a/plugin/src/main/kotlin/com/karumi/hagu/plugin/HaguTasks.kt +++ b/plugin/src/main/kotlin/com/karumi/hagu/plugin/HaguTask.kt @@ -1,18 +1,17 @@ package com.karumi.hagu.plugin +import java.io.File import java.io.FileInputStream import java.util.Properties import org.gradle.api.DefaultTask +import org.gradle.api.tasks.CacheableTask +import org.gradle.api.tasks.OutputDirectory +import org.gradle.api.tasks.PathSensitive +import org.gradle.api.tasks.PathSensitivity import org.gradle.api.tasks.TaskAction -sealed class HaguTasks : DefaultTask() { - - init { - group = "Hagu" - } -} - -open class BuildHagu : HaguTasks() { +@CacheableTask +open class HaguTask : DefaultTask() { companion object { const val NAME = "buildHagu" @@ -20,13 +19,21 @@ open class BuildHagu : HaguTasks() { } init { + group = "Hagu" description = "Build Kotlin configuration from configuration file." } + @get:OutputDirectory + @get:PathSensitive(PathSensitivity.RELATIVE) + var generatedSourceOutput: File? = null + @TaskAction fun build() { - val kotlinConfigGenerator = KotlinConfigGenerator(project.buildDir) - kotlinConfigGenerator.generateConfig(getProperties()) + generatedSourceOutput?.run { + deleteRecursively() + val kotlinConfigGenerator = KotlinConfigGenerator(this) + kotlinConfigGenerator.generateConfig(getProperties()) + } } private fun getProperties(): Properties { diff --git a/plugin/src/main/kotlin/com/karumi/hagu/plugin/KotlinConfigGenerator.kt b/plugin/src/main/kotlin/com/karumi/hagu/plugin/KotlinConfigGenerator.kt index 56f63dd..aa02543 100644 --- a/plugin/src/main/kotlin/com/karumi/hagu/plugin/KotlinConfigGenerator.kt +++ b/plugin/src/main/kotlin/com/karumi/hagu/plugin/KotlinConfigGenerator.kt @@ -2,8 +2,6 @@ package com.karumi.hagu.plugin import java.io.File import java.util.Properties -import kotlin.Comparator -import kotlin.String val configurationFile = """ package com.karumi.hagu.generated @@ -16,19 +14,14 @@ val configurationFile = """ """.trimIndent() class KotlinConfigGenerator( - buildConfigDir: File + val generatedSourceOutput: File ) { companion object { private const val HAGU_CONFIG_FILE_NAME = "HaguConfig.kt" - private const val HAGU_GENERATED_SOURCE_FOLDER = "generated/kotlin/config" private const val PROPERTIES = "&properties" } - val generatedSourceOutput = File( - buildConfigDir, - HAGU_GENERATED_SOURCE_FOLDER - ) val haguConfigFile = File( generatedSourceOutput, HAGU_CONFIG_FILE_NAME diff --git a/plugin/src/main/kotlin/com/karumi/hagu/plugin/source/SourceRoots.kt b/plugin/src/main/kotlin/com/karumi/hagu/plugin/source/SourceRoots.kt new file mode 100644 index 0000000..ac36774 --- /dev/null +++ b/plugin/src/main/kotlin/com/karumi/hagu/plugin/source/SourceRoots.kt @@ -0,0 +1,67 @@ +package com.karumi.hagu.plugin.source + +import com.karumi.hagu.plugin.HaguTask +import org.gradle.api.Project +import org.gradle.api.file.SourceDirectorySet +import org.gradle.api.tasks.SourceSetContainer +import org.gradle.api.tasks.TaskProvider +import org.jetbrains.kotlin.gradle.dsl.KotlinCommonOptions +import org.jetbrains.kotlin.gradle.dsl.KotlinMultiplatformExtension +import org.jetbrains.kotlin.gradle.plugin.KotlinCompilation +import org.jetbrains.kotlin.gradle.plugin.KotlinPlatformType +import org.jetbrains.kotlin.gradle.plugin.mpp.KotlinJvmAndroidCompilation +import org.jetbrains.kotlin.gradle.plugin.mpp.KotlinNativeTarget +import org.jetbrains.kotlin.konan.target.KonanTarget + +internal fun sources(project: Project): List { + project.extensions.findByType(KotlinMultiplatformExtension::class.java)?.let { + return it.sources() + } + + val sourceSets = project.property("sourceSets") as SourceSetContainer + return listOf(Source( + type = KotlinPlatformType.jvm, + name = "main", + sourceSets = listOf("main"), + sourceDirectorySet = sourceSets.getByName("main").kotlin!!, + registerTaskDependency = { task -> + project.tasks.named("compileKotlin").configure { it.dependsOn(task) } + } + )) +} + +private fun KotlinMultiplatformExtension.sources(): List = + targets.flatMap { target -> + target.compilations.mapNotNull { it.source() } + } + +private fun KotlinCompilation.source(): Source? { + if (name.endsWith(suffix = "Test", ignoreCase = true)) { + return null + } + + return Source( + type = target.platformType, + konanTarget = (target as? KotlinNativeTarget)?.konanTarget, + name = "${target.name}${name.capitalize()}", + variantName = (this as? KotlinJvmAndroidCompilation)?.name, + sourceDirectorySet = defaultSourceSet.kotlin, + sourceSets = allKotlinSourceSets.map { it.name }, + registerTaskDependency = { task -> + (target as? KotlinNativeTarget)?.binaries?.forEach { + it.linkTask.dependsOn(task) + } + compileKotlinTask.dependsOn(task) + } + ) +} + +internal data class Source( + val type: KotlinPlatformType, + val konanTarget: KonanTarget? = null, + val sourceDirectorySet: SourceDirectorySet, + val name: String, + val variantName: String? = null, + val sourceSets: List, + val registerTaskDependency: (TaskProvider) -> Unit +) \ No newline at end of file diff --git a/plugin/src/main/kotlin/com/karumi/hagu/plugin/source/SourceSets.kt b/plugin/src/main/kotlin/com/karumi/hagu/plugin/source/SourceSets.kt new file mode 100644 index 0000000..351e418 --- /dev/null +++ b/plugin/src/main/kotlin/com/karumi/hagu/plugin/source/SourceSets.kt @@ -0,0 +1,25 @@ +package com.karumi.hagu.plugin.source + +import org.gradle.api.file.SourceDirectorySet +import org.gradle.api.internal.HasConvention +import org.gradle.api.tasks.SourceSet +import org.jetbrains.kotlin.gradle.plugin.KOTLIN_DSL_NAME +import org.jetbrains.kotlin.gradle.plugin.KOTLIN_JS_DSL_NAME +import org.jetbrains.kotlin.gradle.plugin.KotlinSourceSet + +internal val SourceSet.kotlin: SourceDirectorySet? + get() = kotlinSourceSet + +// Copied from kotlin plugin +private val Any.kotlinSourceSet: SourceDirectorySet? + get() { + val convention = + (getConvention(KOTLIN_DSL_NAME) ?: getConvention(KOTLIN_JS_DSL_NAME)) ?: return null + val kotlinSourceSetIface = + convention.javaClass.interfaces.find { it.name == KotlinSourceSet::class.qualifiedName } + val getKotlin = kotlinSourceSetIface?.methods?.find { it.name == "getKotlin" } ?: return null + return getKotlin(convention) as? SourceDirectorySet + } + +private fun Any.getConvention(name: String): Any? = + (this as HasConvention).convention.plugins[name] \ No newline at end of file diff --git a/plugin/src/main/resources/META-INF/gradle-plugins/hagu.properties b/plugin/src/main/resources/META-INF/gradle-plugins/com.karumi.hagu.properties similarity index 100% rename from plugin/src/main/resources/META-INF/gradle-plugins/hagu.properties rename to plugin/src/main/resources/META-INF/gradle-plugins/com.karumi.hagu.properties diff --git a/plugin/src/test/kotlin/com/karumi/hagu/plugin/KotlinConfigGeneratorTest.kt b/plugin/src/test/kotlin/com/karumi/hagu/plugin/KotlinConfigGeneratorTest.kt index c481005..e0158c1 100644 --- a/plugin/src/test/kotlin/com/karumi/hagu/plugin/KotlinConfigGeneratorTest.kt +++ b/plugin/src/test/kotlin/com/karumi/hagu/plugin/KotlinConfigGeneratorTest.kt @@ -9,7 +9,7 @@ import org.junit.Test class KotlinConfigGeneratorTest { - private val buildDir = File("build/test") + private val buildDir = File("build/test/generated") private val kotlinConfigGenerator = KotlinConfigGenerator(buildDir) @BeforeTest