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: | ||||
|  | ||||
| * 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' | ||||
|  | ||||
| String[] includes = [ | ||||
|         ":lib" | ||||
|     ":lib" | ||||
| ] | ||||
|  | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user