Procházet zdrojové kódy

begin kotlin-multiplatform implementation

main
James Fenn před 1 rokem
rodič
revize
43b26805b6
33 změnil soubory, kde provedl 933 přidání a 0 odebrání
  1. +10
    -0
      .gitignore
  2. +34
    -0
      build.gradle
  3. +60
    -0
      common/build.gradle
  4. +18
    -0
      common/src/commonMain/kotlin/gitrest/RequestProvider.kt
  5. +26
    -0
      common/src/commonMain/kotlin/gitrest/RequestProviderDelegate.kt
  6. +9
    -0
      common/src/commonMain/kotlin/gitrest/ServiceBuilder.kt
  7. +27
    -0
      common/src/commonMain/kotlin/gitrest/impl/github/GithubRequestProvider.kt
  8. +32
    -0
      common/src/commonMain/kotlin/gitrest/impl/github/model/GithubLicense.kt
  9. +25
    -0
      common/src/commonMain/kotlin/gitrest/impl/github/model/GithubRepo.kt
  10. +31
    -0
      common/src/commonMain/kotlin/gitrest/impl/github/model/GithubUser.kt
  11. +26
    -0
      common/src/commonMain/kotlin/gitrest/impl/gitlab/GitlabRequestProvider.kt
  12. +37
    -0
      common/src/commonMain/kotlin/gitrest/impl/gitlab/model/GitlabLicense.kt
  13. +22
    -0
      common/src/commonMain/kotlin/gitrest/impl/gitlab/model/GitlabRepo.kt
  14. +31
    -0
      common/src/commonMain/kotlin/gitrest/impl/gitlab/model/GitlabUser.kt
  15. +16
    -0
      common/src/commonMain/kotlin/gitrest/model/License.kt
  16. +54
    -0
      common/src/commonMain/kotlin/gitrest/model/ProviderString.kt
  17. +13
    -0
      common/src/commonMain/kotlin/gitrest/model/Repo.kt
  18. +15
    -0
      common/src/commonMain/kotlin/gitrest/model/User.kt
  19. +34
    -0
      common/src/commonTest/kotlin/gitrest/ProviderStringTest.kt
  20. +36
    -0
      example-android/build.gradle
  21. +21
    -0
      example-android/proguard-rules.pro
  22. +24
    -0
      example-android/src/androidTest/java/me/jfenn/gitwrappersample/ExampleInstrumentedTest.kt
  23. +9
    -0
      example-android/src/main/AndroidManifest.xml
  24. +6
    -0
      example-android/src/main/res/values/colors.xml
  25. +3
    -0
      example-android/src/main/res/values/strings.xml
  26. +11
    -0
      example-android/src/main/res/values/styles.xml
  27. +17
    -0
      example-android/src/test/java/me/jfenn/gitwrappersample/ExampleUnitTest.kt
  28. +21
    -0
      gradle.properties
  29. binární
      gradle/wrapper/gradle-wrapper.jar
  30. +6
    -0
      gradle/wrapper/gradle-wrapper.properties
  31. +172
    -0
      gradlew
  32. +84
    -0
      gradlew.bat
  33. +3
    -0
      settings.gradle

+ 10
- 0
.gitignore Zobrazit soubor

@@ -0,0 +1,10 @@
*.iml
.gradle
/local.properties
/.idea
.DS_Store
/build
/captures
/*/build
.externalNativeBuild
.cxx

+ 34
- 0
build.gradle Zobrazit soubor

@@ -0,0 +1,34 @@
// Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
ext.kotlin_version = '1.3.72'
ext.ktor_version = '1.3.2'
ext.serialization_version = '0.20.0'

repositories {
google()
jcenter()
maven { url "https://dl.bintray.com/jetbrains/kotlin-native-dependencies" }
maven { url "https://kotlin.bintray.com/kotlinx" }
}

dependencies {
classpath 'com.android.tools.build:gradle:3.6.3'
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
classpath "org.jetbrains.kotlin:kotlin-serialization:$kotlin_version"

// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}

allprojects {
repositories {
google()
jcenter()
}
}

task clean(type: Delete) {
delete rootProject.buildDir
}

+ 60
- 0
common/build.gradle Zobrazit soubor

@@ -0,0 +1,60 @@
apply plugin: "kotlin-multiplatform"
apply plugin: "kotlinx-serialization"

group 'gitrest'
version '0.0.1'

kotlin {
jvm()

sourceSets {
commonMain {
dependencies {
implementation kotlin('stdlib-common')
implementation "io.ktor:ktor-client-core:$ktor_version"
implementation "io.ktor:ktor-client-json:$ktor_version"
implementation "org.jetbrains.kotlinx:kotlinx-serialization-runtime-common:$serialization_version"
}
}
commonTest {
dependencies {
implementation kotlin('test-common')
implementation kotlin('test-annotations-common')
}
}
jvmMain {
dependencies {
implementation kotlin('stdlib-jdk8')
implementation "org.jetbrains.kotlinx:kotlinx-serialization-runtime:$serialization_version"
// TODO: ktor dependency for android / jvm
}
}
jvmTest {
dependencies {
implementation kotlin('test')
implementation kotlin('test-junit')
}
}
jsMain {
dependencies {
implementation kotlin('stdlib-js')
implementation "org.jetbrains.kotlinx:kotlinx-serialization-runtime-js:$serialization_version"
implementation "io.ktor:ktor-client-js:$ktor_version"
}
}
jsTest {
dependencies {
implementation kotlin('test-js')
}
}
nativeMain {
dependencies {
implementation "org.jetbrains.kotlinx:kotlinx-serialization-runtime-native:$serialization_version"
implementation "io.ktor:ktor-client-curl:$ktor_version"
}
}
nativeTest {}
}
}

task run dependsOn "check"

+ 18
- 0
common/src/commonMain/kotlin/gitrest/RequestProvider.kt Zobrazit soubor

@@ -0,0 +1,18 @@
package gitrest

import gitrest.model.License
import gitrest.model.ProviderString
import gitrest.model.Repo
import gitrest.model.User

interface RequestProvider {

suspend fun getUser(str: ProviderString): User?

suspend fun getRepository(str: ProviderString): Repo?

suspend fun getContributors(str: ProviderString): List<User>?

suspend fun getLicense(str: ProviderString): License?

}

+ 26
- 0
common/src/commonMain/kotlin/gitrest/RequestProviderDelegate.kt Zobrazit soubor

@@ -0,0 +1,26 @@
package gitrest

import gitrest.model.License
import gitrest.model.ProviderString
import gitrest.model.Repo
import gitrest.model.User

class RequestProviderDelegate(private val services: List<ServiceBuilder<*>>) : RequestProvider {

private val providers: MutableMap<String, RequestProvider> = HashMap()

private fun get(str: ProviderString) : RequestProvider {
val providerId = str.toProviderString()
return providers[providerId] ?: run {
services.firstOrNull { it.key == str.provider }?.create(str.context)?.also { it ->
providers[providerId] = it
} ?: throw RuntimeException("Provider not found: $providerId")
}
}

override suspend fun getUser(str: ProviderString): User? = get(str).getUser(str)
override suspend fun getRepository(str: ProviderString): Repo? = get(str).getRepository(str)
override suspend fun getContributors(str: ProviderString): List<User>? = get(str).getContributors(str)
override suspend fun getLicense(str: ProviderString): License? = get(str).getLicense(str)

}

+ 9
- 0
common/src/commonMain/kotlin/gitrest/ServiceBuilder.kt Zobrazit soubor

@@ -0,0 +1,9 @@
package gitrest

interface ServiceBuilder<T: RequestProvider> {

val key : String

fun create(context: String?): T

}

+ 27
- 0
common/src/commonMain/kotlin/gitrest/impl/github/GithubRequestProvider.kt Zobrazit soubor

@@ -0,0 +1,27 @@
package gitrest.impl.github

import gitrest.RequestProvider
import gitrest.impl.github.model.GithubLicense
import gitrest.impl.github.model.GithubRepo
import gitrest.impl.github.model.GithubUser
import gitrest.model.ProviderString

class GithubRequestProvider : RequestProvider {

override suspend fun getUser(str: ProviderString): GithubUser? {
TODO("not implemented")
}

override suspend fun getRepository(str: ProviderString): GithubRepo? {
TODO("not implemented")
}

override suspend fun getContributors(str: ProviderString): List<GithubUser>? {
TODO("not implemented")
}

override suspend fun getLicense(str: ProviderString): GithubLicense? {
TODO("not implemented")
}

}

+ 32
- 0
common/src/commonMain/kotlin/gitrest/impl/github/model/GithubLicense.kt Zobrazit soubor

@@ -0,0 +1,32 @@
package gitrest.impl.github.model

import gitrest.model.License
import kotlinx.serialization.SerialName
import kotlinx.serialization.Serializable

@Serializable
class GithubLicense : License() {
@SerialName("key")
override val key: String? = null

@SerialName("name")
override val name: String? = null

@SerialName("description")
override val description: String? = null

@SerialName("body")
override val body: String? = null

@SerialName("html_url")
override val infoUrl: String? = null

@SerialName("permissions")
override val permissions: Array<String>? = null

@SerialName("conditions")
override val conditions: Array<String>? = null

@SerialName("limitations")
override val limitations: Array<String>? = null
}

+ 25
- 0
common/src/commonMain/kotlin/gitrest/impl/github/model/GithubRepo.kt Zobrazit soubor

@@ -0,0 +1,25 @@
package gitrest.impl.github.model

import gitrest.model.Repo
import kotlinx.serialization.SerialName
import kotlinx.serialization.Serializable

@Serializable
class GithubRepo : Repo() {

@SerialName("full_name")
override val slug: String? = null

@SerialName("description")
override val description: String? = null

@SerialName("html_url")
override val url: String? = null

@SerialName("homepage")
override val websiteUrl: String? = null

@SerialName("license")
override val license: GithubLicense? = null

}

+ 31
- 0
common/src/commonMain/kotlin/gitrest/impl/github/model/GithubUser.kt Zobrazit soubor

@@ -0,0 +1,31 @@
package gitrest.impl.github.model

import gitrest.model.User
import kotlinx.serialization.SerialName
import kotlinx.serialization.Serializable

@Serializable
class GithubUser : User() {

@SerialName("login")
override val login: String? = null

@SerialName("name")
override val name: String? = null

@SerialName("html_url")
override val url: String? = null

@SerialName("avatar_url")
override val avatarUrl: String? = null

@SerialName("blog")
override val websiteUrl: String? = null

@SerialName("email")
override val email: String? = null

@SerialName("bio")
override val bio: String? = null

}

+ 26
- 0
common/src/commonMain/kotlin/gitrest/impl/gitlab/GitlabRequestProvider.kt Zobrazit soubor

@@ -0,0 +1,26 @@
package gitrest.impl.gitlab

import gitrest.RequestProvider
import gitrest.impl.gitlab.model.GitlabLicense
import gitrest.impl.gitlab.model.GitlabRepo
import gitrest.impl.gitlab.model.GitlabUser
import gitrest.model.ProviderString

class GitlabRequestProvider : RequestProvider {
override suspend fun getUser(str: ProviderString): GitlabUser? {
TODO("not implemented")
}

override suspend fun getRepository(str: ProviderString): GitlabRepo? {
TODO("not implemented")
}

override suspend fun getContributors(str: ProviderString): List<GitlabUser>? {
TODO("not implemented")
}

override suspend fun getLicense(str: ProviderString): GitlabLicense? {
TODO("not implemented")
}

}

+ 37
- 0
common/src/commonMain/kotlin/gitrest/impl/gitlab/model/GitlabLicense.kt Zobrazit soubor

@@ -0,0 +1,37 @@
package gitrest.impl.gitlab.model

import gitrest.model.License
import kotlinx.serialization.SerialName
import kotlinx.serialization.Serializable

@Serializable
class GitlabLicense : License() {

@SerialName("key")
override val key: String? = null

@SerialName("nickname")
override val name: String? = null

@SerialName("name")
val fullName: String? = null

@SerialName("description")
override val description: String? = null

@SerialName("content")
override val body: String? = null

@SerialName("html_url")
override val infoUrl: String? = null

@SerialName("permissions")
override val permissions: Array<String>? = null

@SerialName("conditions")
override val conditions: Array<String>? = null

@SerialName("limitations")
override val limitations: Array<String>? = null

}

+ 22
- 0
common/src/commonMain/kotlin/gitrest/impl/gitlab/model/GitlabRepo.kt Zobrazit soubor

@@ -0,0 +1,22 @@
package gitrest.impl.gitlab.model

import gitrest.model.Repo
import kotlinx.serialization.SerialName
import kotlinx.serialization.Serializable

@Serializable
class GitlabRepo : Repo() {

@SerialName("path_with_namespace")
override val slug: String? = null

@SerialName("description")
override val description: String? = null

@SerialName("web_url")
override val url: String? = null

@SerialName("license")
override val license: GitlabLicense? = null

}

+ 31
- 0
common/src/commonMain/kotlin/gitrest/impl/gitlab/model/GitlabUser.kt Zobrazit soubor

@@ -0,0 +1,31 @@
package gitrest.impl.gitlab.model

import gitrest.model.User
import kotlinx.serialization.SerialName
import kotlinx.serialization.Serializable

@Serializable
class GitlabUser : User() {

@SerialName("username")
override val login: String? = null

@SerialName("name")
override val name: String? = null

@SerialName("web_url")
override val url: String? = null

@SerialName("avatar_url")
override val avatarUrl: String? = null

@SerialName("website_url")
override val websiteUrl: String? = null

@SerialName("public_email")
override val email: String? = null

@SerialName("bio")
override val bio: String? = null

}

+ 16
- 0
common/src/commonMain/kotlin/gitrest/model/License.kt Zobrazit soubor

@@ -0,0 +1,16 @@
package gitrest.model

import kotlinx.serialization.Transient

open class License {
@Transient
open var id: ProviderString? = null
open val key: String? = null
open val name: String? = null
open val description: String? = null
open val body: String? = null
open val infoUrl: String? = null
open val permissions: Array<String>? = null
open val conditions: Array<String>? = null
open val limitations: Array<String>? = null
}

+ 54
- 0
common/src/commonMain/kotlin/gitrest/model/ProviderString.kt Zobrazit soubor

@@ -0,0 +1,54 @@
package gitrest.model

class ProviderString {

val provider: String
val context : String?
val id: String

constructor(provider: String, context: String? = null, id: String) {
this.provider = provider
this.context = context
this.id = id
}

constructor(str: String) {
if (str.isEmpty())
throw RuntimeException("Attribouter - Empty ProviderString")

val arr = str.split("@", ":")
when (arr.size) {
1 -> {
provider = "github" // TODO: find a less ugly way of specifying this...
context = null
id = arr[0]
}
2 -> {
provider = arr[0]
context = null
id = arr[1]
}
3 -> {
provider = arr[0]
context = arr[1]
id = arr[2]
}
else -> throw RuntimeException("Attribouter - ProviderString with too many parts! '$str' Format: 'provider@context:id'")
}
}

fun toProviderString(): String {
return "$provider@${context ?: "null"}"
}

override fun toString(): String {
return id
}

override fun equals(other: Any?): Boolean {
return (other as? ProviderString)?.let {
provider == it.provider && id == it.id
} ?: super.equals(other)
}

}

+ 13
- 0
common/src/commonMain/kotlin/gitrest/model/Repo.kt Zobrazit soubor

@@ -0,0 +1,13 @@
package gitrest.model

import kotlinx.serialization.Transient

open class Repo {
@Transient
open var id: ProviderString? = null
open val slug: String? = null
open val description: String? = null
open val url: String? = null
open val websiteUrl: String? = null
open val license: License? = null
}

+ 15
- 0
common/src/commonMain/kotlin/gitrest/model/User.kt Zobrazit soubor

@@ -0,0 +1,15 @@
package gitrest.model

import kotlinx.serialization.Transient

open class User {
@Transient
open var id: ProviderString? = null
open val login: String? = null
open val name: String? = null
open val url: String? = null
open val avatarUrl: String? = null
open val websiteUrl: String? = null
open val email: String? = null
open val bio: String? = null
}

+ 34
- 0
common/src/commonTest/kotlin/gitrest/ProviderStringTest.kt Zobrazit soubor

@@ -0,0 +1,34 @@
package gitrest

import gitrest.model.ProviderString
import kotlin.test.Test
import kotlin.test.assertEquals

class ProviderStringTest {

@Test
fun fromSimpleString() {
val str = ProviderString("fennifith/Attribouter")

assertEquals(str.provider, "github")
assertEquals(str.id, "fennifith/Attribouter")
}

@Test
fun fromProviderString() {
val str = ProviderString("gitlab:fennifith")

assertEquals(str.provider, "gitlab")
assertEquals(str.id, "fennifith")
}

@Test
fun fromContextualProviderString() {
val str = ProviderString("gitea@code.horrific.dev:james")

assertEquals(str.provider, "gitea")
assertEquals(str.context, "code.horrific.dev")
assertEquals(str.id, "james")
}

}

+ 36
- 0
example-android/build.gradle Zobrazit soubor

@@ -0,0 +1,36 @@
apply plugin: 'com.android.application'
apply plugin: 'kotlin-android'
apply plugin: 'kotlin-android-extensions'

android {
compileSdkVersion 29


defaultConfig {
applicationId "me.jfenn.gitwrappersample"
minSdkVersion 16
targetSdkVersion 29
versionCode 1
versionName "1.0"

testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}

buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}

}

dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
implementation 'androidx.appcompat:appcompat:1.1.0'
implementation 'androidx.core:core-ktx:1.0.2'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'androidx.test.ext:junit:1.1.1'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0'
}

+ 21
- 0
example-android/proguard-rules.pro Zobrazit soubor

@@ -0,0 +1,21 @@
# Add project specific ProGuard rules here.
# You can control the set of applied configuration files using the
# proguardFiles setting in build.gradle.
#
# For more details, see
# http://developer.android.com/guide/developing/tools/proguard.html

# If your project uses WebView with JS, uncomment the following
# and specify the fully qualified class name to the JavaScript interface
# class:
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
# public *;
#}

# Uncomment this to preserve the line number information for
# debugging stack traces.
#-keepattributes SourceFile,LineNumberTable

# If you keep the line number information, uncomment this to
# hide the original source file name.
#-renamesourcefileattribute SourceFile

+ 24
- 0
example-android/src/androidTest/java/me/jfenn/gitwrappersample/ExampleInstrumentedTest.kt Zobrazit soubor

@@ -0,0 +1,24 @@
package me.jfenn.gitwrappersample

import androidx.test.platform.app.InstrumentationRegistry
import androidx.test.ext.junit.runners.AndroidJUnit4

import org.junit.Test
import org.junit.runner.RunWith

import org.junit.Assert.*

/**
* Instrumented test, which will execute on an Android device.
*
* See [testing documentation](http://d.android.com/tools/testing).
*/
@RunWith(AndroidJUnit4::class)
class ExampleInstrumentedTest {
@Test
fun useAppContext() {
// Context of the app under test.
val appContext = InstrumentationRegistry.getInstrumentation().targetContext
assertEquals("me.jfenn.gitwrappersample", appContext.packageName)
}
}

+ 9
- 0
example-android/src/main/AndroidManifest.xml Zobrazit soubor

@@ -0,0 +1,9 @@
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="me.jfenn.gitwrappersample">

<application
android:allowBackup="true"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme" />
</manifest>

+ 6
- 0
example-android/src/main/res/values/colors.xml Zobrazit soubor

@@ -0,0 +1,6 @@
<?xml version="1.0" encoding="utf-8"?>
<resources>
<color name="colorPrimary">#6200EE</color>
<color name="colorPrimaryDark">#3700B3</color>
<color name="colorAccent">#03DAC5</color>
</resources>

+ 3
- 0
example-android/src/main/res/values/strings.xml Zobrazit soubor

@@ -0,0 +1,3 @@
<resources>
<string name="app_name">Git-REST Wrapper Example</string>
</resources>

+ 11
- 0
example-android/src/main/res/values/styles.xml Zobrazit soubor

@@ -0,0 +1,11 @@
<resources>

<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<!-- Customize your theme here. -->
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
</style>

</resources>

+ 17
- 0
example-android/src/test/java/me/jfenn/gitwrappersample/ExampleUnitTest.kt Zobrazit soubor

@@ -0,0 +1,17 @@
package me.jfenn.gitwrappersample

import org.junit.Test

import org.junit.Assert.*

/**
* Example local unit test, which will execute on the development machine (host).
*
* See [testing documentation](http://d.android.com/tools/testing).
*/
class ExampleUnitTest {
@Test
fun addition_isCorrect() {
assertEquals(4, 2 + 2)
}
}

+ 21
- 0
gradle.properties Zobrazit soubor

@@ -0,0 +1,21 @@
# Project-wide Gradle settings.
# IDE (e.g. Android Studio) users:
# Gradle settings configured through the IDE *will override*
# any settings specified in this file.
# For more details on how to configure your build environment visit
# http://www.gradle.org/docs/current/userguide/build_environment.html
# Specifies the JVM arguments used for the daemon process.
# The setting is particularly useful for tweaking memory settings.
org.gradle.jvmargs=-Xmx1536m
# When configured, Gradle will run in incubating parallel mode.
# This option should only be used with decoupled projects. More details, visit
# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
# org.gradle.parallel=true
# AndroidX package structure to make it clearer which packages are bundled with the
# Android operating system, and which are packaged with your app's APK
# https://developer.android.com/topic/libraries/support-library/androidx-rn
android.useAndroidX=true
# Automatically convert third-party libraries to use AndroidX
android.enableJetifier=true
# Kotlin code style for this project: "official" or "obsolete":
kotlin.code.style=official

binární
gradle/wrapper/gradle-wrapper.jar Zobrazit soubor


+ 6
- 0
gradle/wrapper/gradle-wrapper.properties Zobrazit soubor

@@ -0,0 +1,6 @@
#Sat May 09 17:04:07 EDT 2020
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-5.6.4-all.zip

+ 172
- 0
gradlew Zobrazit soubor

@@ -0,0 +1,172 @@
#!/usr/bin/env sh

##############################################################################
##
## Gradle start up script for UN*X
##
##############################################################################

# Attempt to set APP_HOME
# Resolve links: $0 may be a link
PRG="$0"
# Need this for relative symlinks.
while [ -h "$PRG" ] ; do
ls=`ls -ld "$PRG"`
link=`expr "$ls" : '.*-> \(.*\)$'`
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" "$@"

+ 84
- 0
gradlew.bat Zobrazit soubor

@@ -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

+ 3
- 0
settings.gradle Zobrazit soubor

@@ -0,0 +1,3 @@
rootProject.name='Git-REST Wrapper'
include ':example-android'
include ':common'

Načítá se…
Zrušit
Uložit