@@ -0,0 +1,10 @@ | |||
*.iml | |||
.gradle | |||
/local.properties | |||
/.idea | |||
.DS_Store | |||
/build | |||
/captures | |||
/*/build | |||
.externalNativeBuild | |||
.cxx |
@@ -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 | |||
} |
@@ -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" |
@@ -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? | |||
} |
@@ -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) | |||
} |
@@ -0,0 +1,9 @@ | |||
package gitrest | |||
interface ServiceBuilder<T: RequestProvider> { | |||
val key : String | |||
fun create(context: String?): T | |||
} |
@@ -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") | |||
} | |||
} |
@@ -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 | |||
} |
@@ -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 | |||
} |
@@ -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 | |||
} |
@@ -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") | |||
} | |||
} |
@@ -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 | |||
} |
@@ -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 | |||
} |
@@ -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 | |||
} |
@@ -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 | |||
} |
@@ -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) | |||
} | |||
} |
@@ -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 | |||
} |
@@ -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 | |||
} |
@@ -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") | |||
} | |||
} |
@@ -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' | |||
} |
@@ -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 |
@@ -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) | |||
} | |||
} |
@@ -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> |
@@ -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> |
@@ -0,0 +1,3 @@ | |||
<resources> | |||
<string name="app_name">Git-REST Wrapper Example</string> | |||
</resources> |
@@ -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> |
@@ -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) | |||
} | |||
} |
@@ -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 |
@@ -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 |
@@ -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" "$@" |
@@ -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 |
@@ -0,0 +1,3 @@ | |||
rootProject.name='Git-REST Wrapper' | |||
include ':example-android' | |||
include ':common' |