mirror of
				https://github.com/InsanusMokrassar/KotlinMultiplatformProjectTemplate.git
				synced 2025-10-26 17:50:27 +00:00 
			
		
		
		
	update readme
This commit is contained in:
		
							
								
								
									
										156
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										156
									
								
								README.md
									
									
									
									
									
								
							| @@ -2,4 +2,158 @@ | |||||||
|  |  | ||||||
| That is a template for Kotlin Multiplatform Projects. How to use it: | That is a template for Kotlin Multiplatform Projects. How to use it: | ||||||
|  |  | ||||||
| * Create repository  | * Create your repository from this template | ||||||
|  | * Replace in a whole project `project_group` by your group | ||||||
|  | * Replace in a whole project `project_name` by your **ROOT** project name | ||||||
|  | * Update your subproject packages. It is not critical, but recommended especially in case you plan to publish your | ||||||
|  |   library | ||||||
|  |  | ||||||
|  | ## Subprojects | ||||||
|  |  | ||||||
|  | In this template there is only one subproject with name `lib`. You are always able to rename it, but remember that in | ||||||
|  | this case you must rename it in `settings.gradle` file. | ||||||
|  |  | ||||||
|  | ## Types of projects | ||||||
|  |  | ||||||
|  | ### `mppProjectWithSerialization` | ||||||
|  |  | ||||||
|  | This type of preset have `JVM`, `JS` and `Android` targets and available using | ||||||
|  | `apply from: "$mppProjectWithSerializationPresetPath"`. Template for project with this preset looks like next snippet: | ||||||
|  |  | ||||||
|  | ```groovy | ||||||
|  | plugins { | ||||||
|  |     id "org.jetbrains.kotlin.multiplatform" | ||||||
|  |     id "org.jetbrains.kotlin.plugin.serialization" | ||||||
|  |     id "com.android.library" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | apply from: "$mppProjectWithSerializationPresetPath" | ||||||
|  |  | ||||||
|  | // The code below is optional | ||||||
|  |  | ||||||
|  | kotlin { | ||||||
|  |     sourceSets { | ||||||
|  |         commonMain { | ||||||
|  |             dependencies { | ||||||
|  |                 // common dependencies | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         commonTest { | ||||||
|  |             dependencies { | ||||||
|  |                 // common test dependencies | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         jvmMain { | ||||||
|  |             dependencies { | ||||||
|  |                 // jvm dependencies | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         jvmTest { | ||||||
|  |             dependencies { | ||||||
|  |                 // jvm test dependencies | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         jsMain { | ||||||
|  |             dependencies { | ||||||
|  |                 // js dependencies | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         jsTest { | ||||||
|  |             dependencies { | ||||||
|  |                 // js test dependencies | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         androidMain { | ||||||
|  |             dependencies { | ||||||
|  |                 // android dependencies | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         androidTest { | ||||||
|  |             dependencies { | ||||||
|  |                 // android test dependencies | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### `mppJavaProject` | ||||||
|  |  | ||||||
|  | This type of preset have only `JVM` target and available using `apply from: "$mppJavaProjectPresetPath"`. Template for | ||||||
|  | project with this preset looks like next snippet: | ||||||
|  |  | ||||||
|  | ```groovy | ||||||
|  | plugins { | ||||||
|  |     id "org.jetbrains.kotlin.multiplatform" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | apply from: "$mppJavaProjectPresetPath" | ||||||
|  |  | ||||||
|  | // The code below is optional | ||||||
|  |  | ||||||
|  | kotlin { | ||||||
|  |     sourceSets { | ||||||
|  |         commonMain { | ||||||
|  |             dependencies { | ||||||
|  |                 // common dependencies | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         commonTest { | ||||||
|  |             dependencies { | ||||||
|  |                 // common test dependencies | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         jvmMain { | ||||||
|  |             dependencies { | ||||||
|  |                 // jvm dependencies | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         jvmTest { | ||||||
|  |             dependencies { | ||||||
|  |                 // jvm test dependencies | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### `mppAndroidProject` | ||||||
|  |  | ||||||
|  | This type of preset have only `Android` target and available using `apply from: "$mppAndroidProjectPresetPath"`. Template for | ||||||
|  | project with this preset looks like next snippet: | ||||||
|  |  | ||||||
|  | ```groovy | ||||||
|  | plugins { | ||||||
|  |     id "org.jetbrains.kotlin.multiplatform" | ||||||
|  |     id "com.android.library" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | apply from: "$mppAndroidProjectPresetPath" | ||||||
|  |  | ||||||
|  | // The code below is optional | ||||||
|  |  | ||||||
|  | kotlin { | ||||||
|  |     sourceSets { | ||||||
|  |         commonMain { | ||||||
|  |             dependencies { | ||||||
|  |                 // common dependencies | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         commonTest { | ||||||
|  |             dependencies { | ||||||
|  |                 // common test dependencies | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         androidMain { | ||||||
|  |             dependencies { | ||||||
|  |                 // android dependencies | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         androidTest { | ||||||
|  |             dependencies { | ||||||
|  |                 // android test dependencies | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | ``` | ||||||
|   | |||||||
| @@ -1,16 +1,7 @@ | |||||||
| /* |  | ||||||
|  * This file was generated by the Gradle 'init' task. |  | ||||||
|  * |  | ||||||
|  * The settings file is used to specify which projects to include in your build. |  | ||||||
|  * |  | ||||||
|  * Detailed information about configuring a multi-project build in Gradle can be found |  | ||||||
|  * in the user manual at https://docs.gradle.org/6.7.1/userguide/multi_project_builds.html |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| rootProject.name = 'project_name' | rootProject.name = 'project_name' | ||||||
|  |  | ||||||
| String[] includes = [ | String[] includes = [ | ||||||
|         ":lib" |     ":lib" | ||||||
| ] | ] | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user