From 98c19b62a7ae3d2f70968effd06614a23c7bb7ec Mon Sep 17 00:00:00 2001 From: Asier Fernandez Date: Thu, 4 Jun 2015 16:50:49 +0200 Subject: [PATCH 1/9] Added new examples HttpUrlConnection and AsyncTask ListView with BaseAdapter and Data Object OkHttp and AsyncTask Gson deserializers with OkHttp and AsyncTask Anko simple ui Anko async api sample --- gradle/anko-asynchronous-tasks/.gitignore | 27 +++ .../anko-asynchronous-tasks/MyApplication.iml | 19 ++ gradle/anko-asynchronous-tasks/app/.gitignore | 1 + gradle/anko-asynchronous-tasks/app/app.iml | 100 +++++++++++ .../anko-asynchronous-tasks/app/build.gradle | 46 +++++ .../app/proguard-rules.pro | 17 ++ .../app/src/main/AndroidManifest.xml | 23 +++ .../com/irontec/kotlintest/MainActivity.kt | 75 ++++++++ .../deserializers/WeatherDeserializer.kt | 39 +++++ .../kotlintest/models/WeatherObject.kt | 24 +++ .../irontec/kotlintest/models/WindObject.kt | 17 ++ .../kotlintest/networking/NetworkClient.kt | 21 +++ .../app/src/main/res/menu/menu_main.xml | 6 + .../src/main/res/mipmap-hdpi/ic_launcher.png | Bin 0 -> 3418 bytes .../src/main/res/mipmap-mdpi/ic_launcher.png | Bin 0 -> 2206 bytes .../src/main/res/mipmap-xhdpi/ic_launcher.png | Bin 0 -> 4842 bytes .../main/res/mipmap-xxhdpi/ic_launcher.png | Bin 0 -> 7718 bytes .../app/src/main/res/values-w820dp/dimens.xml | 6 + .../app/src/main/res/values/dimens.xml | 5 + .../app/src/main/res/values/strings.xml | 6 + .../app/src/main/res/values/styles.xml | 8 + gradle/anko-asynchronous-tasks/build.gradle | 19 ++ .../anko-asynchronous-tasks/gradle.properties | 18 ++ .../gradle/wrapper/gradle-wrapper.jar | Bin 0 -> 49896 bytes .../gradle/wrapper/gradle-wrapper.properties | 6 + gradle/anko-asynchronous-tasks/gradlew | 164 ++++++++++++++++++ gradle/anko-asynchronous-tasks/gradlew.bat | 90 ++++++++++ .../anko-asynchronous-tasks/settings.gradle | 1 + gradle/anko-simple-ui/.gitignore | 27 +++ gradle/anko-simple-ui/MyApplication.iml | 19 ++ gradle/anko-simple-ui/app/.gitignore | 1 + gradle/anko-simple-ui/app/app.iml | 100 +++++++++++ gradle/anko-simple-ui/app/build.gradle | 46 +++++ gradle/anko-simple-ui/app/proguard-rules.pro | 17 ++ .../app/src/main/AndroidManifest.xml | 23 +++ .../com/irontec/kotlintest/MainActivity.kt | 87 ++++++++++ .../deserializers/WeatherDeserializer.kt | 39 +++++ .../kotlintest/models/WeatherObject.kt | 24 +++ .../irontec/kotlintest/models/WindObject.kt | 17 ++ .../kotlintest/networking/NetworkClient.kt | 21 +++ .../app/src/main/res/menu/menu_main.xml | 6 + .../src/main/res/mipmap-hdpi/ic_launcher.png | Bin 0 -> 3418 bytes .../src/main/res/mipmap-mdpi/ic_launcher.png | Bin 0 -> 2206 bytes .../src/main/res/mipmap-xhdpi/ic_launcher.png | Bin 0 -> 4842 bytes .../main/res/mipmap-xxhdpi/ic_launcher.png | Bin 0 -> 7718 bytes .../app/src/main/res/values-w820dp/dimens.xml | 6 + .../app/src/main/res/values/dimens.xml | 5 + .../app/src/main/res/values/strings.xml | 6 + .../app/src/main/res/values/styles.xml | 8 + gradle/anko-simple-ui/build.gradle | 19 ++ gradle/anko-simple-ui/gradle.properties | 18 ++ .../gradle/wrapper/gradle-wrapper.jar | Bin 0 -> 49896 bytes .../gradle/wrapper/gradle-wrapper.properties | 6 + gradle/anko-simple-ui/gradlew | 164 ++++++++++++++++++ gradle/anko-simple-ui/gradlew.bat | 90 ++++++++++ gradle/anko-simple-ui/settings.gradle | 1 + gradle/common-data/bilbao.json | 41 +++++ .../.gitignore | 27 +++ .../MyApplication.iml | 19 ++ .../app/.gitignore | 1 + .../app/app.iml | 99 +++++++++++ .../app/build.gradle | 44 +++++ .../app/proguard-rules.pro | 17 ++ .../app/src/main/AndroidManifest.xml | 23 +++ .../com/irontec/kotlintest/MainActivity.kt | 83 +++++++++ .../deserializers/WeatherDeserializer.kt | 39 +++++ .../kotlintest/models/WeatherObject.kt | 24 +++ .../irontec/kotlintest/models/WindObject.kt | 17 ++ .../kotlintest/networking/NetworkClient.kt | 21 +++ .../app/src/main/res/layout/activity_main.xml | 10 ++ .../app/src/main/res/menu/menu_main.xml | 6 + .../src/main/res/mipmap-hdpi/ic_launcher.png | Bin 0 -> 3418 bytes .../src/main/res/mipmap-mdpi/ic_launcher.png | Bin 0 -> 2206 bytes .../src/main/res/mipmap-xhdpi/ic_launcher.png | Bin 0 -> 4842 bytes .../main/res/mipmap-xxhdpi/ic_launcher.png | Bin 0 -> 7718 bytes .../app/src/main/res/values-w820dp/dimens.xml | 6 + .../app/src/main/res/values/dimens.xml | 5 + .../app/src/main/res/values/strings.xml | 6 + .../app/src/main/res/values/styles.xml | 8 + .../build.gradle | 19 ++ .../gradle.properties | 18 ++ .../gradle/wrapper/gradle-wrapper.jar | Bin 0 -> 49896 bytes .../gradle/wrapper/gradle-wrapper.properties | 6 + .../gradlew | 164 ++++++++++++++++++ .../gradlew.bat | 90 ++++++++++ .../settings.gradle | 1 + gradle/httpurlconnection-asynctask/.gitignore | 27 +++ .../MyApplication.iml | 19 ++ .../app/.gitignore | 1 + .../httpurlconnection-asynctask/app/app.iml | 96 ++++++++++ .../app/build.gradle | 42 +++++ .../app/proguard-rules.pro | 17 ++ .../app/src/main/AndroidManifest.xml | 23 +++ .../com/irontec/kotlintest/MainActivity.kt | 91 ++++++++++ .../app/src/main/res/layout/activity_main.xml | 10 ++ .../app/src/main/res/menu/menu_main.xml | 6 + .../src/main/res/mipmap-hdpi/ic_launcher.png | Bin 0 -> 3418 bytes .../src/main/res/mipmap-mdpi/ic_launcher.png | Bin 0 -> 2206 bytes .../src/main/res/mipmap-xhdpi/ic_launcher.png | Bin 0 -> 4842 bytes .../main/res/mipmap-xxhdpi/ic_launcher.png | Bin 0 -> 7718 bytes .../app/src/main/res/values-w820dp/dimens.xml | 6 + .../app/src/main/res/values/dimens.xml | 5 + .../app/src/main/res/values/strings.xml | 6 + .../app/src/main/res/values/styles.xml | 8 + .../httpurlconnection-asynctask/build.gradle | 19 ++ .../gradle.properties | 18 ++ .../gradle/wrapper/gradle-wrapper.jar | Bin 0 -> 49896 bytes .../gradle/wrapper/gradle-wrapper.properties | 6 + gradle/httpurlconnection-asynctask/gradlew | 164 ++++++++++++++++++ .../httpurlconnection-asynctask/gradlew.bat | 90 ++++++++++ .../settings.gradle | 1 + .../.gitignore | 27 +++ .../MyApplication.iml | 19 ++ .../app/.gitignore | 1 + .../app/app.iml | 96 ++++++++++ .../app/build.gradle | 42 +++++ .../app/proguard-rules.pro | 17 ++ .../app/src/main/AndroidManifest.xml | 23 +++ .../com/irontec/kotlintest/MainActivity.kt | 50 ++++++ .../kotlintest/adapters/CustomListAdapter.kt | 59 +++++++ .../irontec/kotlintest/models/CustomPojo.kt | 14 ++ .../app/src/main/res/layout/activity_main.xml | 10 ++ .../app/src/main/res/layout/row_item.xml | 11 ++ .../app/src/main/res/menu/menu_main.xml | 6 + .../src/main/res/mipmap-hdpi/ic_launcher.png | Bin 0 -> 3418 bytes .../src/main/res/mipmap-mdpi/ic_launcher.png | Bin 0 -> 2206 bytes .../src/main/res/mipmap-xhdpi/ic_launcher.png | Bin 0 -> 4842 bytes .../main/res/mipmap-xxhdpi/ic_launcher.png | Bin 0 -> 7718 bytes .../app/src/main/res/values-w820dp/dimens.xml | 6 + .../app/src/main/res/values/dimens.xml | 5 + .../app/src/main/res/values/strings.xml | 6 + .../app/src/main/res/values/styles.xml | 8 + .../build.gradle | 19 ++ .../gradle.properties | 18 ++ .../gradle/wrapper/gradle-wrapper.jar | Bin 0 -> 49896 bytes .../gradle/wrapper/gradle-wrapper.properties | 6 + .../listview-baseadapter-data-object/gradlew | 164 ++++++++++++++++++ .../gradlew.bat | 90 ++++++++++ .../settings.gradle | 1 + gradle/okhttp-asynctask/.gitignore | 27 +++ gradle/okhttp-asynctask/MyApplication.iml | 19 ++ gradle/okhttp-asynctask/app/.gitignore | 1 + gradle/okhttp-asynctask/app/app.iml | 98 +++++++++++ gradle/okhttp-asynctask/app/build.gradle | 43 +++++ .../okhttp-asynctask/app/proguard-rules.pro | 17 ++ .../app/src/main/AndroidManifest.xml | 23 +++ .../com/irontec/kotlintest/MainActivity.kt | 73 ++++++++ .../kotlintest/networking/NetworkClient.kt | 21 +++ .../app/src/main/res/layout/activity_main.xml | 10 ++ .../app/src/main/res/menu/menu_main.xml | 6 + .../src/main/res/mipmap-hdpi/ic_launcher.png | Bin 0 -> 3418 bytes .../src/main/res/mipmap-mdpi/ic_launcher.png | Bin 0 -> 2206 bytes .../src/main/res/mipmap-xhdpi/ic_launcher.png | Bin 0 -> 4842 bytes .../main/res/mipmap-xxhdpi/ic_launcher.png | Bin 0 -> 7718 bytes .../app/src/main/res/values-w820dp/dimens.xml | 6 + .../app/src/main/res/values/dimens.xml | 5 + .../app/src/main/res/values/strings.xml | 6 + .../app/src/main/res/values/styles.xml | 8 + gradle/okhttp-asynctask/build.gradle | 19 ++ gradle/okhttp-asynctask/gradle.properties | 18 ++ .../gradle/wrapper/gradle-wrapper.jar | Bin 0 -> 49896 bytes .../gradle/wrapper/gradle-wrapper.properties | 6 + gradle/okhttp-asynctask/gradlew | 164 ++++++++++++++++++ gradle/okhttp-asynctask/gradlew.bat | 90 ++++++++++ gradle/okhttp-asynctask/settings.gradle | 1 + 165 files changed, 4296 insertions(+) create mode 100644 gradle/anko-asynchronous-tasks/.gitignore create mode 100644 gradle/anko-asynchronous-tasks/MyApplication.iml create mode 100644 gradle/anko-asynchronous-tasks/app/.gitignore create mode 100644 gradle/anko-asynchronous-tasks/app/app.iml create mode 100644 gradle/anko-asynchronous-tasks/app/build.gradle create mode 100644 gradle/anko-asynchronous-tasks/app/proguard-rules.pro create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/AndroidManifest.xml create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/MainActivity.kt create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/res/menu/menu_main.xml create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/res/mipmap-hdpi/ic_launcher.png create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/res/mipmap-mdpi/ic_launcher.png create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/res/mipmap-xhdpi/ic_launcher.png create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/res/mipmap-xxhdpi/ic_launcher.png create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/res/values-w820dp/dimens.xml create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/res/values/dimens.xml create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/res/values/strings.xml create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/res/values/styles.xml create mode 100644 gradle/anko-asynchronous-tasks/build.gradle create mode 100644 gradle/anko-asynchronous-tasks/gradle.properties create mode 100644 gradle/anko-asynchronous-tasks/gradle/wrapper/gradle-wrapper.jar create mode 100644 gradle/anko-asynchronous-tasks/gradle/wrapper/gradle-wrapper.properties create mode 100755 gradle/anko-asynchronous-tasks/gradlew create mode 100644 gradle/anko-asynchronous-tasks/gradlew.bat create mode 100644 gradle/anko-asynchronous-tasks/settings.gradle create mode 100644 gradle/anko-simple-ui/.gitignore create mode 100644 gradle/anko-simple-ui/MyApplication.iml create mode 100644 gradle/anko-simple-ui/app/.gitignore create mode 100644 gradle/anko-simple-ui/app/app.iml create mode 100644 gradle/anko-simple-ui/app/build.gradle create mode 100644 gradle/anko-simple-ui/app/proguard-rules.pro create mode 100644 gradle/anko-simple-ui/app/src/main/AndroidManifest.xml create mode 100644 gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/MainActivity.kt create mode 100644 gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt create mode 100644 gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt create mode 100644 gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt create mode 100644 gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt create mode 100644 gradle/anko-simple-ui/app/src/main/res/menu/menu_main.xml create mode 100644 gradle/anko-simple-ui/app/src/main/res/mipmap-hdpi/ic_launcher.png create mode 100644 gradle/anko-simple-ui/app/src/main/res/mipmap-mdpi/ic_launcher.png create mode 100644 gradle/anko-simple-ui/app/src/main/res/mipmap-xhdpi/ic_launcher.png create mode 100644 gradle/anko-simple-ui/app/src/main/res/mipmap-xxhdpi/ic_launcher.png create mode 100644 gradle/anko-simple-ui/app/src/main/res/values-w820dp/dimens.xml create mode 100644 gradle/anko-simple-ui/app/src/main/res/values/dimens.xml create mode 100644 gradle/anko-simple-ui/app/src/main/res/values/strings.xml create mode 100644 gradle/anko-simple-ui/app/src/main/res/values/styles.xml create mode 100644 gradle/anko-simple-ui/build.gradle create mode 100644 gradle/anko-simple-ui/gradle.properties create mode 100644 gradle/anko-simple-ui/gradle/wrapper/gradle-wrapper.jar create mode 100644 gradle/anko-simple-ui/gradle/wrapper/gradle-wrapper.properties create mode 100755 gradle/anko-simple-ui/gradlew create mode 100644 gradle/anko-simple-ui/gradlew.bat create mode 100644 gradle/anko-simple-ui/settings.gradle create mode 100644 gradle/common-data/bilbao.json create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/.gitignore create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/MyApplication.iml create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/.gitignore create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/app.iml create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/build.gradle create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/proguard-rules.pro create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/src/main/AndroidManifest.xml create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/layout/activity_main.xml create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/menu/menu_main.xml create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-hdpi/ic_launcher.png create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-mdpi/ic_launcher.png create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-xhdpi/ic_launcher.png create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-xxhdpi/ic_launcher.png create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values-w820dp/dimens.xml create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/dimens.xml create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/strings.xml create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/styles.xml create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/build.gradle create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/gradle.properties create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/gradle/wrapper/gradle-wrapper.jar create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/gradle/wrapper/gradle-wrapper.properties create mode 100755 gradle/gson-deserializers-okhttp-asyncTask/gradlew create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/gradlew.bat create mode 100644 gradle/gson-deserializers-okhttp-asyncTask/settings.gradle create mode 100644 gradle/httpurlconnection-asynctask/.gitignore create mode 100644 gradle/httpurlconnection-asynctask/MyApplication.iml create mode 100644 gradle/httpurlconnection-asynctask/app/.gitignore create mode 100644 gradle/httpurlconnection-asynctask/app/app.iml create mode 100644 gradle/httpurlconnection-asynctask/app/build.gradle create mode 100644 gradle/httpurlconnection-asynctask/app/proguard-rules.pro create mode 100644 gradle/httpurlconnection-asynctask/app/src/main/AndroidManifest.xml create mode 100644 gradle/httpurlconnection-asynctask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt create mode 100644 gradle/httpurlconnection-asynctask/app/src/main/res/layout/activity_main.xml create mode 100644 gradle/httpurlconnection-asynctask/app/src/main/res/menu/menu_main.xml create mode 100644 gradle/httpurlconnection-asynctask/app/src/main/res/mipmap-hdpi/ic_launcher.png create mode 100644 gradle/httpurlconnection-asynctask/app/src/main/res/mipmap-mdpi/ic_launcher.png create mode 100644 gradle/httpurlconnection-asynctask/app/src/main/res/mipmap-xhdpi/ic_launcher.png create mode 100644 gradle/httpurlconnection-asynctask/app/src/main/res/mipmap-xxhdpi/ic_launcher.png create mode 100644 gradle/httpurlconnection-asynctask/app/src/main/res/values-w820dp/dimens.xml create mode 100644 gradle/httpurlconnection-asynctask/app/src/main/res/values/dimens.xml create mode 100644 gradle/httpurlconnection-asynctask/app/src/main/res/values/strings.xml create mode 100644 gradle/httpurlconnection-asynctask/app/src/main/res/values/styles.xml create mode 100644 gradle/httpurlconnection-asynctask/build.gradle create mode 100644 gradle/httpurlconnection-asynctask/gradle.properties create mode 100644 gradle/httpurlconnection-asynctask/gradle/wrapper/gradle-wrapper.jar create mode 100644 gradle/httpurlconnection-asynctask/gradle/wrapper/gradle-wrapper.properties create mode 100755 gradle/httpurlconnection-asynctask/gradlew create mode 100644 gradle/httpurlconnection-asynctask/gradlew.bat create mode 100644 gradle/httpurlconnection-asynctask/settings.gradle create mode 100644 gradle/listview-baseadapter-data-object/.gitignore create mode 100644 gradle/listview-baseadapter-data-object/MyApplication.iml create mode 100644 gradle/listview-baseadapter-data-object/app/.gitignore create mode 100644 gradle/listview-baseadapter-data-object/app/app.iml create mode 100644 gradle/listview-baseadapter-data-object/app/build.gradle create mode 100644 gradle/listview-baseadapter-data-object/app/proguard-rules.pro create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/AndroidManifest.xml create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/MainActivity.kt create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/adapters/CustomListAdapter.kt create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/models/CustomPojo.kt create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/res/layout/activity_main.xml create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/res/layout/row_item.xml create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/res/menu/menu_main.xml create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/res/mipmap-hdpi/ic_launcher.png create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/res/mipmap-mdpi/ic_launcher.png create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/res/mipmap-xhdpi/ic_launcher.png create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/res/mipmap-xxhdpi/ic_launcher.png create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/res/values-w820dp/dimens.xml create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/res/values/dimens.xml create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/res/values/strings.xml create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/res/values/styles.xml create mode 100644 gradle/listview-baseadapter-data-object/build.gradle create mode 100644 gradle/listview-baseadapter-data-object/gradle.properties create mode 100644 gradle/listview-baseadapter-data-object/gradle/wrapper/gradle-wrapper.jar create mode 100644 gradle/listview-baseadapter-data-object/gradle/wrapper/gradle-wrapper.properties create mode 100755 gradle/listview-baseadapter-data-object/gradlew create mode 100644 gradle/listview-baseadapter-data-object/gradlew.bat create mode 100644 gradle/listview-baseadapter-data-object/settings.gradle create mode 100644 gradle/okhttp-asynctask/.gitignore create mode 100644 gradle/okhttp-asynctask/MyApplication.iml create mode 100644 gradle/okhttp-asynctask/app/.gitignore create mode 100644 gradle/okhttp-asynctask/app/app.iml create mode 100644 gradle/okhttp-asynctask/app/build.gradle create mode 100644 gradle/okhttp-asynctask/app/proguard-rules.pro create mode 100644 gradle/okhttp-asynctask/app/src/main/AndroidManifest.xml create mode 100644 gradle/okhttp-asynctask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt create mode 100644 gradle/okhttp-asynctask/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt create mode 100644 gradle/okhttp-asynctask/app/src/main/res/layout/activity_main.xml create mode 100644 gradle/okhttp-asynctask/app/src/main/res/menu/menu_main.xml create mode 100644 gradle/okhttp-asynctask/app/src/main/res/mipmap-hdpi/ic_launcher.png create mode 100644 gradle/okhttp-asynctask/app/src/main/res/mipmap-mdpi/ic_launcher.png create mode 100644 gradle/okhttp-asynctask/app/src/main/res/mipmap-xhdpi/ic_launcher.png create mode 100644 gradle/okhttp-asynctask/app/src/main/res/mipmap-xxhdpi/ic_launcher.png create mode 100644 gradle/okhttp-asynctask/app/src/main/res/values-w820dp/dimens.xml create mode 100644 gradle/okhttp-asynctask/app/src/main/res/values/dimens.xml create mode 100644 gradle/okhttp-asynctask/app/src/main/res/values/strings.xml create mode 100644 gradle/okhttp-asynctask/app/src/main/res/values/styles.xml create mode 100644 gradle/okhttp-asynctask/build.gradle create mode 100644 gradle/okhttp-asynctask/gradle.properties create mode 100644 gradle/okhttp-asynctask/gradle/wrapper/gradle-wrapper.jar create mode 100644 gradle/okhttp-asynctask/gradle/wrapper/gradle-wrapper.properties create mode 100755 gradle/okhttp-asynctask/gradlew create mode 100644 gradle/okhttp-asynctask/gradlew.bat create mode 100644 gradle/okhttp-asynctask/settings.gradle diff --git a/gradle/anko-asynchronous-tasks/.gitignore b/gradle/anko-asynchronous-tasks/.gitignore new file mode 100644 index 0000000000..ccf2efe026 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.gitignore @@ -0,0 +1,27 @@ +# Built application files +*.apk +*.ap_ + +# Files for the Dalvik VM +*.dex + +# Java class files +*.class + +# Generated files +bin/ +gen/ + +# Gradle files +.gradle/ +build/ +/*/build/ + +# Local configuration file (sdk path, etc) +local.properties + +# Proguard folder generated by Eclipse +proguard/ + +# Log Files +*.log diff --git a/gradle/anko-asynchronous-tasks/MyApplication.iml b/gradle/anko-asynchronous-tasks/MyApplication.iml new file mode 100644 index 0000000000..960784f551 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/MyApplication.iml @@ -0,0 +1,19 @@ + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/app/.gitignore b/gradle/anko-asynchronous-tasks/app/.gitignore new file mode 100644 index 0000000000..796b96d1c4 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/app/.gitignore @@ -0,0 +1 @@ +/build diff --git a/gradle/anko-asynchronous-tasks/app/app.iml b/gradle/anko-asynchronous-tasks/app/app.iml new file mode 100644 index 0000000000..36f5f43c43 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/app/app.iml @@ -0,0 +1,100 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/app/build.gradle b/gradle/anko-asynchronous-tasks/app/build.gradle new file mode 100644 index 0000000000..222efc6577 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/app/build.gradle @@ -0,0 +1,46 @@ +apply plugin: 'com.android.application' +apply plugin: 'kotlin-android' + +android { + compileSdkVersion 22 + buildToolsVersion "22.0.1" + + defaultConfig { + applicationId "com.irontec.kotlintest" + minSdkVersion 16 + targetSdkVersion 22 + versionCode 1 + versionName "1.0" + } + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' + } + } + sourceSets { + main.java.srcDirs += 'src/main/kotlin' + } +} + +dependencies { + compile fileTree(dir: 'libs', include: ['*.jar']) + compile 'com.android.support:appcompat-v7:22.1.0' + compile 'com.google.code.gson:gson:2.3.1' + compile 'com.squareup.okhttp:okhttp:2.3.0' + compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" + compile "org.jetbrains.anko:anko:$anko_version" +} +buildscript { + ext.kotlin_version = '0.11.91.2' + ext.anko_version = '0.6-15' + repositories { + mavenCentral() + } + dependencies { + classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" + } +} +repositories { + mavenCentral() +} diff --git a/gradle/anko-asynchronous-tasks/app/proguard-rules.pro b/gradle/anko-asynchronous-tasks/app/proguard-rules.pro new file mode 100644 index 0000000000..d6d8d1fbb0 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/app/proguard-rules.pro @@ -0,0 +1,17 @@ +# Add project specific ProGuard rules here. +# By default, the flags in this file are appended to flags specified +# in /Users/axier/Library/Android/sdk/tools/proguard/proguard-android.txt +# You can edit the include path and order by changing the proguardFiles +# directive in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# Add any project specific keep options here: + +# 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 *; +#} diff --git a/gradle/anko-asynchronous-tasks/app/src/main/AndroidManifest.xml b/gradle/anko-asynchronous-tasks/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000000..e609988df0 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/app/src/main/AndroidManifest.xml @@ -0,0 +1,23 @@ + + + + + + + + + + + + + + + + diff --git a/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/MainActivity.kt b/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/MainActivity.kt new file mode 100644 index 0000000000..aca9392592 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/MainActivity.kt @@ -0,0 +1,75 @@ +package com.irontec.kotlintest + +import android.app.Activity +import android.os.AsyncTask +import android.os.Bundle +import android.support.v7.app.AppCompatActivity +import android.util.Log +import android.view.Menu +import android.view.MenuItem +import android.widget.TextView +import com.google.gson.Gson +import com.google.gson.GsonBuilder +import com.irontec.kotlintest.deserializers.WeatherDeserializer +import com.irontec.kotlintest.models.WeatherObject +import com.irontec.kotlintest.networking.NetworkClient +import org.json.JSONObject +import java.io.BufferedInputStream +import java.io.BufferedReader +import java.io.InputStreamReader +import java.net.HttpURLConnection +import java.net.URL +import org.jetbrains.anko.* + + +public class MainActivity : AppCompatActivity() { + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + + verticalLayout { + padding = dip(5) + val mTextView = textView { + textSize = 12f + }.layoutParams(width = matchParent, height = dip(300)) + button("Retrieve Weather") { + textSize = 14f + onClick { + // Declare a background asynchronous task, no need for an AsyncTask anymore + async { + // Heavy duty work made on the background + val networkClient = NetworkClient() + val stream = BufferedInputStream( + networkClient.get("https://raw.githubusercontent.com/irontec/android-kotlin-samples/master/common-data/bilbao.json")) + val bufferedReader = BufferedReader(InputStreamReader(stream)); + val stringBuilder = StringBuilder(); + bufferedReader.forEachLine { stringBuilder.append(it) } + val gsonBuilder = GsonBuilder().serializeNulls(); + gsonBuilder.registerTypeAdapter(javaClass(), WeatherDeserializer()); + val gson = gsonBuilder.create(); + val weather = gson.fromJson(stringBuilder.toString(), javaClass()) as WeatherObject + + uiThread { + // Just set the TextView text on the UI-Thread + mTextView.setText(weather.toString()) + } + } + } + }.layoutParams(width = matchParent, height = wrapContent) + } + + } + + override fun onCreateOptionsMenu(menu: Menu): Boolean { + getMenuInflater().inflate(R.menu.menu_main, menu) + return true + } + + override fun onOptionsItemSelected(item: MenuItem): Boolean { + val id = item.getItemId() + if (id == R.id.action_settings) { + return true + } + return super.onOptionsItemSelected(item) + } +} diff --git a/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt b/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt new file mode 100644 index 0000000000..c8e2caaa5e --- /dev/null +++ b/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt @@ -0,0 +1,39 @@ +package com.irontec.kotlintest.deserializers + +import com.google.gson.JsonDeserializationContext +import com.google.gson.JsonDeserializer +import com.google.gson.JsonElement +import com.google.gson.JsonObject +import com.irontec.kotlintest.models.WeatherObject +import com.irontec.kotlintest.models.WindObject +import java.lang.reflect.Type + +/** + * Created by axier on 24/4/15. + */ +open class WeatherDeserializer : JsonDeserializer { + + override fun deserialize(json: JsonElement?, typeOfT: Type?, context: JsonDeserializationContext?): WeatherObject? { + val jsonObj = json as JsonObject + + val wheather = WeatherObject() + val wind = WindObject() + + val jsonWeatherArray = jsonObj.getAsJsonArray("weather").get(0) + val jsonMainObj = jsonObj.getAsJsonObject("main") + val jsonWindObj = jsonObj.getAsJsonObject("wind") + + wheather.main = jsonWeatherArray.getAsJsonObject().get("main").getAsString() + wheather.description = jsonWeatherArray.getAsJsonObject().get("description").getAsString() + wheather.temp = jsonMainObj.get("temp").getAsFloat() + wheather.temp_Max = jsonMainObj.get("temp_max").getAsFloat() + wheather.temp_Min = jsonMainObj.get("temp_min").getAsFloat() + wheather.humidity = jsonMainObj.get("humidity").getAsInt() + wind.speed = jsonWindObj.get("speed").getAsFloat() + wind.deg = jsonWindObj.get("deg").getAsFloat() + wheather.wind = wind + + return wheather + + } +} \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt b/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt new file mode 100644 index 0000000000..caf561293b --- /dev/null +++ b/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt @@ -0,0 +1,24 @@ +package com.irontec.kotlintest.models + +/** + * Created by axier on 24/4/15. + */ +public class WeatherObject { + + public var main: String = "" + public var description: String = "" + public var temp: Float = 0.0f + public var temp_Max: Float = 0.0f + public var temp_Min: Float = 0.0f + public var humidity: Int = 0 + public var wind: WindObject? = null + + init { + println(this.toString()) + } + + override fun toString() = + "Main ${main}, description ${description}, temp ${temp}, temp_Max ${temp_Max}," + + ", temp_Min ${temp_Min}, humidity ${humidity}, wind ${wind.toString()}" + +} \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt b/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt new file mode 100644 index 0000000000..5ab3506947 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt @@ -0,0 +1,17 @@ +package com.irontec.kotlintest.models + +/** + * Created by axier on 24/4/15. + */ +public class WindObject { + + public var speed: Float = 0.0f + public var deg: Float = 0.0f + + init { + println(this.toString()) + } + + override fun toString() = "Speed ${speed}, deg ${deg}" + +} \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt b/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt new file mode 100644 index 0000000000..87830ead49 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt @@ -0,0 +1,21 @@ +package com.irontec.kotlintest.networking + +import com.squareup.okhttp.OkHttpClient +import com.squareup.okhttp.Request +import java.io.InputStream + +/** + * Created by axier on 23/4/15. + */ +open class NetworkClient { + + fun get(url: String): InputStream { + val request = Request.Builder().url(url).build() + val response = OkHttpClient().newCall(request).execute() + val body = response.body() + // body.toString() returns a string representing the object and not the body itself, probably + // kotlins fault when using third party libraries. Use byteStream() and convert it to a String + return body.byteStream() + } + +} \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/app/src/main/res/menu/menu_main.xml b/gradle/anko-asynchronous-tasks/app/src/main/res/menu/menu_main.xml new file mode 100644 index 0000000000..b1cb90811d --- /dev/null +++ b/gradle/anko-asynchronous-tasks/app/src/main/res/menu/menu_main.xml @@ -0,0 +1,6 @@ + + + diff --git a/gradle/anko-asynchronous-tasks/app/src/main/res/mipmap-hdpi/ic_launcher.png b/gradle/anko-asynchronous-tasks/app/src/main/res/mipmap-hdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..cde69bcccec65160d92116f20ffce4fce0b5245c GIT binary patch literal 3418 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 literal 0 HcmV?d00001 diff --git a/gradle/anko-asynchronous-tasks/app/src/main/res/mipmap-xhdpi/ic_launcher.png b/gradle/anko-asynchronous-tasks/app/src/main/res/mipmap-xhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..bfa42f0e7b91d006d22352c9ff2f134e504e3c1d GIT binary patch literal 4842 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 literal 0 HcmV?d00001 diff --git a/gradle/anko-asynchronous-tasks/app/src/main/res/mipmap-xxhdpi/ic_launcher.png b/gradle/anko-asynchronous-tasks/app/src/main/res/mipmap-xxhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..324e72cdd7480cb983fa1bcc7ce686e51ef87fe7 GIT binary patch literal 7718 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 literal 0 HcmV?d00001 diff --git a/gradle/anko-asynchronous-tasks/app/src/main/res/values-w820dp/dimens.xml b/gradle/anko-asynchronous-tasks/app/src/main/res/values-w820dp/dimens.xml new file mode 100644 index 0000000000..63fc816444 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/app/src/main/res/values-w820dp/dimens.xml @@ -0,0 +1,6 @@ + + + 64dp + diff --git a/gradle/anko-asynchronous-tasks/app/src/main/res/values/dimens.xml b/gradle/anko-asynchronous-tasks/app/src/main/res/values/dimens.xml new file mode 100644 index 0000000000..47c8224673 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/app/src/main/res/values/dimens.xml @@ -0,0 +1,5 @@ + + + 16dp + 16dp + diff --git a/gradle/anko-asynchronous-tasks/app/src/main/res/values/strings.xml b/gradle/anko-asynchronous-tasks/app/src/main/res/values/strings.xml new file mode 100644 index 0000000000..7e8ae97852 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/app/src/main/res/values/strings.xml @@ -0,0 +1,6 @@ + + kotlintest + + Hello world! + Settings + diff --git a/gradle/anko-asynchronous-tasks/app/src/main/res/values/styles.xml b/gradle/anko-asynchronous-tasks/app/src/main/res/values/styles.xml new file mode 100644 index 0000000000..766ab99304 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/app/src/main/res/values/styles.xml @@ -0,0 +1,8 @@ + + + + + + diff --git a/gradle/anko-asynchronous-tasks/build.gradle b/gradle/anko-asynchronous-tasks/build.gradle new file mode 100644 index 0000000000..d3ff69d6e7 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/build.gradle @@ -0,0 +1,19 @@ +// Top-level build file where you can add configuration options common to all sub-projects/modules. + +buildscript { + repositories { + jcenter() + } + dependencies { + classpath 'com.android.tools.build:gradle:1.1.0' + + // NOTE: Do not place your application dependencies here; they belong + // in the individual module build.gradle files + } +} + +allprojects { + repositories { + jcenter() + } +} diff --git a/gradle/anko-asynchronous-tasks/gradle.properties b/gradle/anko-asynchronous-tasks/gradle.properties new file mode 100644 index 0000000000..1d3591c8a4 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/gradle.properties @@ -0,0 +1,18 @@ +# 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. +# Default value: -Xmx10248m -XX:MaxPermSize=256m +# org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8 + +# 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 \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/gradle/wrapper/gradle-wrapper.jar b/gradle/anko-asynchronous-tasks/gradle/wrapper/gradle-wrapper.jar new file mode 100644 index 0000000000000000000000000000000000000000..8c0fb64a8698b08ecc4158d828ca593c4928e9dd GIT binary patch literal 49896 zcmagFb986H(k`5d^NVfUwr$(C?M#x1ZQHiZiEVpg+jrjgoQrerx!>1o_ul)D>ebz~ zs=Mmxr&>W81QY-S1PKWQ%N-;H^tS;2*XwVA`dej1RRn1z<;3VgfE4~kaG`A%QSPsR z#ovnZe+tS9%1MfeDyz`RirvdjPRK~p(#^q2(^5@O&NM19EHdvN-A&StN>0g6QA^VN z0Gx%Gq#PD$QMRFzmK+utjS^Y1F0e8&u&^=w5K<;4Rz|i3A=o|IKLY+g`iK6vfr9?+ z-`>gmU&i?FGSL5&F?TXFu`&Js6h;15QFkXp2M1H9|Eq~bpov-GU(uz%mH0n55wUl- zv#~ccAz`F5wlQ>e_KlJS3@{)B?^v*EQM=IxLa&76^y51a((wq|2-`qON>+4dLc{Oo z51}}o^Zen(oAjxDK7b++9_Yg`67p$bPo3~BCpGM7uAWmvIhWc5Gi+gQZ|Pwa-Gll@<1xmcPy z|NZmu6m)g5Ftu~BG&Xdxclw7Cij{xbBMBn-LMII#Slp`AElb&2^Hw+w>(3crLH!;I zN+Vk$D+wP1#^!MDCiad@vM>H#6+`Ct#~6VHL4lzmy;lSdk>`z6)=>Wh15Q2)dQtGqvn0vJU@+(B5{MUc*qs4!T+V=q=wy)<6$~ z!G>e_4dN@lGeF_$q9`Ju6Ncb*x?O7=l{anm7Eahuj_6lA{*#Gv*TaJclevPVbbVYu z(NY?5q+xxbO6%g1xF0r@Ix8fJ~u)VRUp`S%&rN$&e!Od`~s+64J z5*)*WSi*i{k%JjMSIN#X;jC{HG$-^iX+5f5BGOIHWAl*%15Z#!xntpk($-EGKCzKa zT7{siZ9;4TICsWQ$pu&wKZQTCvpI$Xvzwxoi+XkkpeE&&kFb!B?h2hi%^YlXt|-@5 zHJ~%AN!g_^tmn1?HSm^|gCE#!GRtK2(L{9pL#hp0xh zME}|DB>(5)`iE7CM)&_+S}-Bslc#@B5W4_+k4Cp$l>iVyg$KP>CN?SVGZ(&02>iZK zB<^HP$g$Lq*L$BWd?2(F?-MUbNWTJVQdW7$#8a|k_30#vHAD1Z{c#p;bETk0VnU5A zBgLe2HFJ3032$G<`m*OB!KM$*sdM20jm)It5OSru@tXpK5LT>#8)N!*skNu1$TpIw zufjjdp#lyH5bZ%|Iuo|iu9vG1HrIVWLH>278xo>aVBkPN3V$~!=KnlXQ4eDqS7%E% zQ!z^$Q$b^6Q)g#cLpwur(|<0gWHo6A6jc;n`t(V9T;LzTAU{IAu*uEQ%Ort1k+Kn+f_N`9|bxYC+~Z1 zCC1UCWv*Orx$_@ydv9mIe(liLfOr7mhbV@tKw{6)q^1DH1nmvZ0cj215R<~&I<4S| zgnr;9Cdjqpz#o8i0CQjtl`}{c*P)aSdH|abxGdrR)-3z+02-eX(k*B)Uqv6~^nh** z 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 \(.*\)$'` + if expr "$link" : '/.*' > /dev/null; then + PRG="$link" + else + PRG=`dirname "$PRG"`"/$link" + fi +done +SAVED="`pwd`" +cd "`dirname \"$PRG\"`/" >&- +APP_HOME="`pwd -P`" +cd "$SAVED" >&- + +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" ] ; 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"` + + # 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 + +# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules +function splitJvmOpts() { + JVM_OPTS=("$@") +} +eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS +JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME" + +exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@" diff --git a/gradle/anko-asynchronous-tasks/gradlew.bat b/gradle/anko-asynchronous-tasks/gradlew.bat new file mode 100644 index 0000000000..aec99730b4 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/gradlew.bat @@ -0,0 +1,90 @@ +@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 + +@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= + +set DIRNAME=%~dp0 +if "%DIRNAME%" == "" set DIRNAME=. +set APP_BASE_NAME=%~n0 +set APP_HOME=%DIRNAME% + +@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 Windowz variants + +if not "%OS%" == "Windows_NT" goto win9xME_args +if "%@eval[2+2]" == "4" goto 4NT_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=%* +goto execute + +:4NT_args +@rem Get arguments from the 4NT Shell from JP Software +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/gradle/anko-asynchronous-tasks/settings.gradle b/gradle/anko-asynchronous-tasks/settings.gradle new file mode 100644 index 0000000000..e7b4def49c --- /dev/null +++ b/gradle/anko-asynchronous-tasks/settings.gradle @@ -0,0 +1 @@ +include ':app' diff --git a/gradle/anko-simple-ui/.gitignore b/gradle/anko-simple-ui/.gitignore new file mode 100644 index 0000000000..ccf2efe026 --- /dev/null +++ b/gradle/anko-simple-ui/.gitignore @@ -0,0 +1,27 @@ +# Built application files +*.apk +*.ap_ + +# Files for the Dalvik VM +*.dex + +# Java class files +*.class + +# Generated files +bin/ +gen/ + +# Gradle files +.gradle/ +build/ +/*/build/ + +# Local configuration file (sdk path, etc) +local.properties + +# Proguard folder generated by Eclipse +proguard/ + +# Log Files +*.log diff --git a/gradle/anko-simple-ui/MyApplication.iml b/gradle/anko-simple-ui/MyApplication.iml new file mode 100644 index 0000000000..960784f551 --- /dev/null +++ b/gradle/anko-simple-ui/MyApplication.iml @@ -0,0 +1,19 @@ + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/app/.gitignore b/gradle/anko-simple-ui/app/.gitignore new file mode 100644 index 0000000000..796b96d1c4 --- /dev/null +++ b/gradle/anko-simple-ui/app/.gitignore @@ -0,0 +1 @@ +/build diff --git a/gradle/anko-simple-ui/app/app.iml b/gradle/anko-simple-ui/app/app.iml new file mode 100644 index 0000000000..36f5f43c43 --- /dev/null +++ b/gradle/anko-simple-ui/app/app.iml @@ -0,0 +1,100 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/app/build.gradle b/gradle/anko-simple-ui/app/build.gradle new file mode 100644 index 0000000000..222efc6577 --- /dev/null +++ b/gradle/anko-simple-ui/app/build.gradle @@ -0,0 +1,46 @@ +apply plugin: 'com.android.application' +apply plugin: 'kotlin-android' + +android { + compileSdkVersion 22 + buildToolsVersion "22.0.1" + + defaultConfig { + applicationId "com.irontec.kotlintest" + minSdkVersion 16 + targetSdkVersion 22 + versionCode 1 + versionName "1.0" + } + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' + } + } + sourceSets { + main.java.srcDirs += 'src/main/kotlin' + } +} + +dependencies { + compile fileTree(dir: 'libs', include: ['*.jar']) + compile 'com.android.support:appcompat-v7:22.1.0' + compile 'com.google.code.gson:gson:2.3.1' + compile 'com.squareup.okhttp:okhttp:2.3.0' + compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" + compile "org.jetbrains.anko:anko:$anko_version" +} +buildscript { + ext.kotlin_version = '0.11.91.2' + ext.anko_version = '0.6-15' + repositories { + mavenCentral() + } + dependencies { + classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" + } +} +repositories { + mavenCentral() +} diff --git a/gradle/anko-simple-ui/app/proguard-rules.pro b/gradle/anko-simple-ui/app/proguard-rules.pro new file mode 100644 index 0000000000..d6d8d1fbb0 --- /dev/null +++ b/gradle/anko-simple-ui/app/proguard-rules.pro @@ -0,0 +1,17 @@ +# Add project specific ProGuard rules here. +# By default, the flags in this file are appended to flags specified +# in /Users/axier/Library/Android/sdk/tools/proguard/proguard-android.txt +# You can edit the include path and order by changing the proguardFiles +# directive in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# Add any project specific keep options here: + +# 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 *; +#} diff --git a/gradle/anko-simple-ui/app/src/main/AndroidManifest.xml b/gradle/anko-simple-ui/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000000..e609988df0 --- /dev/null +++ b/gradle/anko-simple-ui/app/src/main/AndroidManifest.xml @@ -0,0 +1,23 @@ + + + + + + + + + + + + + + + + diff --git a/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/MainActivity.kt b/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/MainActivity.kt new file mode 100644 index 0000000000..92b04ae18c --- /dev/null +++ b/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/MainActivity.kt @@ -0,0 +1,87 @@ +package com.irontec.kotlintest + +import android.app.Activity +import android.os.AsyncTask +import android.os.Bundle +import android.support.v7.app.AppCompatActivity +import android.util.Log +import android.view.Menu +import android.view.MenuItem +import android.widget.TextView +import com.google.gson.Gson +import com.google.gson.GsonBuilder +import com.irontec.kotlintest.deserializers.WeatherDeserializer +import com.irontec.kotlintest.models.WeatherObject +import com.irontec.kotlintest.networking.NetworkClient +import org.json.JSONObject +import java.io.BufferedInputStream +import java.io.BufferedReader +import java.io.InputStreamReader +import java.net.HttpURLConnection +import java.net.URL +import org.jetbrains.anko.* + + +public class MainActivity : AppCompatActivity() { + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + + verticalLayout { + padding = dip(5) + val mTextView = textView { + textSize = 12f + }.layoutParams(width = matchParent, height = dip(300)) + button("Retrieve Weather") { + textSize = 14f + onClick { GetJsonWithOkHttpClient(mTextView).execute() } + }.layoutParams(width = matchParent, height = wrapContent) + } + + } + + open class GetJsonWithOkHttpClient(textView: TextView) : AsyncTask() { + + val mInnerTextView = textView + + override fun doInBackground(vararg params: Void?): String? { + val networkClient = NetworkClient() + val stream = BufferedInputStream( + networkClient.get("https://raw.githubusercontent.com/irontec/android-kotlin-samples/master/common-data/bilbao.json")) + return readStream(stream); + } + + override fun onPostExecute(result: String?) { + super.onPostExecute(result) + + + val gsonBuilder = GsonBuilder().serializeNulls(); + gsonBuilder.registerTypeAdapter(javaClass(), WeatherDeserializer()); + val gson = gsonBuilder.create(); + val weather = gson.fromJson(result, javaClass()) as WeatherObject + + mInnerTextView.setText(weather.toString()) + + } + + fun readStream(inputStream: BufferedInputStream): String { + val bufferedReader = BufferedReader(InputStreamReader(inputStream)); + val stringBuilder = StringBuilder(); + bufferedReader.forEachLine { stringBuilder.append(it) } + return stringBuilder.toString() + } + } + + override fun onCreateOptionsMenu(menu: Menu): Boolean { + getMenuInflater().inflate(R.menu.menu_main, menu) + return true + } + + override fun onOptionsItemSelected(item: MenuItem): Boolean { + val id = item.getItemId() + if (id == R.id.action_settings) { + return true + } + return super.onOptionsItemSelected(item) + } +} diff --git a/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt b/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt new file mode 100644 index 0000000000..c8e2caaa5e --- /dev/null +++ b/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt @@ -0,0 +1,39 @@ +package com.irontec.kotlintest.deserializers + +import com.google.gson.JsonDeserializationContext +import com.google.gson.JsonDeserializer +import com.google.gson.JsonElement +import com.google.gson.JsonObject +import com.irontec.kotlintest.models.WeatherObject +import com.irontec.kotlintest.models.WindObject +import java.lang.reflect.Type + +/** + * Created by axier on 24/4/15. + */ +open class WeatherDeserializer : JsonDeserializer { + + override fun deserialize(json: JsonElement?, typeOfT: Type?, context: JsonDeserializationContext?): WeatherObject? { + val jsonObj = json as JsonObject + + val wheather = WeatherObject() + val wind = WindObject() + + val jsonWeatherArray = jsonObj.getAsJsonArray("weather").get(0) + val jsonMainObj = jsonObj.getAsJsonObject("main") + val jsonWindObj = jsonObj.getAsJsonObject("wind") + + wheather.main = jsonWeatherArray.getAsJsonObject().get("main").getAsString() + wheather.description = jsonWeatherArray.getAsJsonObject().get("description").getAsString() + wheather.temp = jsonMainObj.get("temp").getAsFloat() + wheather.temp_Max = jsonMainObj.get("temp_max").getAsFloat() + wheather.temp_Min = jsonMainObj.get("temp_min").getAsFloat() + wheather.humidity = jsonMainObj.get("humidity").getAsInt() + wind.speed = jsonWindObj.get("speed").getAsFloat() + wind.deg = jsonWindObj.get("deg").getAsFloat() + wheather.wind = wind + + return wheather + + } +} \ No newline at end of file diff --git a/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt b/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt new file mode 100644 index 0000000000..caf561293b --- /dev/null +++ b/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt @@ -0,0 +1,24 @@ +package com.irontec.kotlintest.models + +/** + * Created by axier on 24/4/15. + */ +public class WeatherObject { + + public var main: String = "" + public var description: String = "" + public var temp: Float = 0.0f + public var temp_Max: Float = 0.0f + public var temp_Min: Float = 0.0f + public var humidity: Int = 0 + public var wind: WindObject? = null + + init { + println(this.toString()) + } + + override fun toString() = + "Main ${main}, description ${description}, temp ${temp}, temp_Max ${temp_Max}," + + ", temp_Min ${temp_Min}, humidity ${humidity}, wind ${wind.toString()}" + +} \ No newline at end of file diff --git a/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt b/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt new file mode 100644 index 0000000000..5ab3506947 --- /dev/null +++ b/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt @@ -0,0 +1,17 @@ +package com.irontec.kotlintest.models + +/** + * Created by axier on 24/4/15. + */ +public class WindObject { + + public var speed: Float = 0.0f + public var deg: Float = 0.0f + + init { + println(this.toString()) + } + + override fun toString() = "Speed ${speed}, deg ${deg}" + +} \ No newline at end of file diff --git a/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt b/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt new file mode 100644 index 0000000000..87830ead49 --- /dev/null +++ b/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt @@ -0,0 +1,21 @@ +package com.irontec.kotlintest.networking + +import com.squareup.okhttp.OkHttpClient +import com.squareup.okhttp.Request +import java.io.InputStream + +/** + * Created by axier on 23/4/15. + */ +open class NetworkClient { + + fun get(url: String): InputStream { + val request = Request.Builder().url(url).build() + val response = OkHttpClient().newCall(request).execute() + val body = response.body() + // body.toString() returns a string representing the object and not the body itself, probably + // kotlins fault when using third party libraries. Use byteStream() and convert it to a String + return body.byteStream() + } + +} \ No newline at end of file diff --git a/gradle/anko-simple-ui/app/src/main/res/menu/menu_main.xml b/gradle/anko-simple-ui/app/src/main/res/menu/menu_main.xml new file mode 100644 index 0000000000..b1cb90811d --- /dev/null +++ b/gradle/anko-simple-ui/app/src/main/res/menu/menu_main.xml @@ -0,0 +1,6 @@ + + + diff --git a/gradle/anko-simple-ui/app/src/main/res/mipmap-hdpi/ic_launcher.png b/gradle/anko-simple-ui/app/src/main/res/mipmap-hdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..cde69bcccec65160d92116f20ffce4fce0b5245c GIT binary patch literal 3418 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 literal 0 HcmV?d00001 diff --git a/gradle/anko-simple-ui/app/src/main/res/mipmap-xhdpi/ic_launcher.png b/gradle/anko-simple-ui/app/src/main/res/mipmap-xhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..bfa42f0e7b91d006d22352c9ff2f134e504e3c1d GIT binary patch literal 4842 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 literal 0 HcmV?d00001 diff --git a/gradle/anko-simple-ui/app/src/main/res/mipmap-xxhdpi/ic_launcher.png b/gradle/anko-simple-ui/app/src/main/res/mipmap-xxhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..324e72cdd7480cb983fa1bcc7ce686e51ef87fe7 GIT binary patch literal 7718 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 literal 0 HcmV?d00001 diff --git a/gradle/anko-simple-ui/app/src/main/res/values-w820dp/dimens.xml b/gradle/anko-simple-ui/app/src/main/res/values-w820dp/dimens.xml new file mode 100644 index 0000000000..63fc816444 --- /dev/null +++ b/gradle/anko-simple-ui/app/src/main/res/values-w820dp/dimens.xml @@ -0,0 +1,6 @@ + + + 64dp + diff --git a/gradle/anko-simple-ui/app/src/main/res/values/dimens.xml b/gradle/anko-simple-ui/app/src/main/res/values/dimens.xml new file mode 100644 index 0000000000..47c8224673 --- /dev/null +++ b/gradle/anko-simple-ui/app/src/main/res/values/dimens.xml @@ -0,0 +1,5 @@ + + + 16dp + 16dp + diff --git a/gradle/anko-simple-ui/app/src/main/res/values/strings.xml b/gradle/anko-simple-ui/app/src/main/res/values/strings.xml new file mode 100644 index 0000000000..7e8ae97852 --- /dev/null +++ b/gradle/anko-simple-ui/app/src/main/res/values/strings.xml @@ -0,0 +1,6 @@ + + kotlintest + + Hello world! + Settings + diff --git a/gradle/anko-simple-ui/app/src/main/res/values/styles.xml b/gradle/anko-simple-ui/app/src/main/res/values/styles.xml new file mode 100644 index 0000000000..766ab99304 --- /dev/null +++ b/gradle/anko-simple-ui/app/src/main/res/values/styles.xml @@ -0,0 +1,8 @@ + + + + + + diff --git a/gradle/anko-simple-ui/build.gradle b/gradle/anko-simple-ui/build.gradle new file mode 100644 index 0000000000..d3ff69d6e7 --- /dev/null +++ b/gradle/anko-simple-ui/build.gradle @@ -0,0 +1,19 @@ +// Top-level build file where you can add configuration options common to all sub-projects/modules. + +buildscript { + repositories { + jcenter() + } + dependencies { + classpath 'com.android.tools.build:gradle:1.1.0' + + // NOTE: Do not place your application dependencies here; they belong + // in the individual module build.gradle files + } +} + +allprojects { + repositories { + jcenter() + } +} diff --git a/gradle/anko-simple-ui/gradle.properties b/gradle/anko-simple-ui/gradle.properties new file mode 100644 index 0000000000..1d3591c8a4 --- /dev/null +++ b/gradle/anko-simple-ui/gradle.properties @@ -0,0 +1,18 @@ +# 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. +# Default value: -Xmx10248m -XX:MaxPermSize=256m +# org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8 + +# 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 \ No newline at end of file diff --git a/gradle/anko-simple-ui/gradle/wrapper/gradle-wrapper.jar b/gradle/anko-simple-ui/gradle/wrapper/gradle-wrapper.jar new file mode 100644 index 0000000000000000000000000000000000000000..8c0fb64a8698b08ecc4158d828ca593c4928e9dd GIT binary patch literal 49896 zcmagFb986H(k`5d^NVfUwr$(C?M#x1ZQHiZiEVpg+jrjgoQrerx!>1o_ul)D>ebz~ zs=Mmxr&>W81QY-S1PKWQ%N-;H^tS;2*XwVA`dej1RRn1z<;3VgfE4~kaG`A%QSPsR z#ovnZe+tS9%1MfeDyz`RirvdjPRK~p(#^q2(^5@O&NM19EHdvN-A&StN>0g6QA^VN z0Gx%Gq#PD$QMRFzmK+utjS^Y1F0e8&u&^=w5K<;4Rz|i3A=o|IKLY+g`iK6vfr9?+ z-`>gmU&i?FGSL5&F?TXFu`&Js6h;15QFkXp2M1H9|Eq~bpov-GU(uz%mH0n55wUl- zv#~ccAz`F5wlQ>e_KlJS3@{)B?^v*EQM=IxLa&76^y51a((wq|2-`qON>+4dLc{Oo z51}}o^Zen(oAjxDK7b++9_Yg`67p$bPo3~BCpGM7uAWmvIhWc5Gi+gQZ|Pwa-Gll@<1xmcPy z|NZmu6m)g5Ftu~BG&Xdxclw7Cij{xbBMBn-LMII#Slp`AElb&2^Hw+w>(3crLH!;I zN+Vk$D+wP1#^!MDCiad@vM>H#6+`Ct#~6VHL4lzmy;lSdk>`z6)=>Wh15Q2)dQtGqvn0vJU@+(B5{MUc*qs4!T+V=q=wy)<6$~ z!G>e_4dN@lGeF_$q9`Ju6Ncb*x?O7=l{anm7Eahuj_6lA{*#Gv*TaJclevPVbbVYu z(NY?5q+xxbO6%g1xF0r@Ix8fJ~u)VRUp`S%&rN$&e!Od`~s+64J z5*)*WSi*i{k%JjMSIN#X;jC{HG$-^iX+5f5BGOIHWAl*%15Z#!xntpk($-EGKCzKa zT7{siZ9;4TICsWQ$pu&wKZQTCvpI$Xvzwxoi+XkkpeE&&kFb!B?h2hi%^YlXt|-@5 zHJ~%AN!g_^tmn1?HSm^|gCE#!GRtK2(L{9pL#hp0xh zME}|DB>(5)`iE7CM)&_+S}-Bslc#@B5W4_+k4Cp$l>iVyg$KP>CN?SVGZ(&02>iZK zB<^HP$g$Lq*L$BWd?2(F?-MUbNWTJVQdW7$#8a|k_30#vHAD1Z{c#p;bETk0VnU5A zBgLe2HFJ3032$G<`m*OB!KM$*sdM20jm)It5OSru@tXpK5LT>#8)N!*skNu1$TpIw zufjjdp#lyH5bZ%|Iuo|iu9vG1HrIVWLH>278xo>aVBkPN3V$~!=KnlXQ4eDqS7%E% zQ!z^$Q$b^6Q)g#cLpwur(|<0gWHo6A6jc;n`t(V9T;LzTAU{IAu*uEQ%Ort1k+Kn+f_N`9|bxYC+~Z1 zCC1UCWv*Orx$_@ydv9mIe(liLfOr7mhbV@tKw{6)q^1DH1nmvZ0cj215R<~&I<4S| zgnr;9Cdjqpz#o8i0CQjtl`}{c*P)aSdH|abxGdrR)-3z+02-eX(k*B)Uqv6~^nh** z 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 \(.*\)$'` + if expr "$link" : '/.*' > /dev/null; then + PRG="$link" + else + PRG=`dirname "$PRG"`"/$link" + fi +done +SAVED="`pwd`" +cd "`dirname \"$PRG\"`/" >&- +APP_HOME="`pwd -P`" +cd "$SAVED" >&- + +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" ] ; 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"` + + # 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 + +# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules +function splitJvmOpts() { + JVM_OPTS=("$@") +} +eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS +JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME" + +exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@" diff --git a/gradle/anko-simple-ui/gradlew.bat b/gradle/anko-simple-ui/gradlew.bat new file mode 100644 index 0000000000..aec99730b4 --- /dev/null +++ b/gradle/anko-simple-ui/gradlew.bat @@ -0,0 +1,90 @@ +@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 + +@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= + +set DIRNAME=%~dp0 +if "%DIRNAME%" == "" set DIRNAME=. +set APP_BASE_NAME=%~n0 +set APP_HOME=%DIRNAME% + +@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 Windowz variants + +if not "%OS%" == "Windows_NT" goto win9xME_args +if "%@eval[2+2]" == "4" goto 4NT_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=%* +goto execute + +:4NT_args +@rem Get arguments from the 4NT Shell from JP Software +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/gradle/anko-simple-ui/settings.gradle b/gradle/anko-simple-ui/settings.gradle new file mode 100644 index 0000000000..e7b4def49c --- /dev/null +++ b/gradle/anko-simple-ui/settings.gradle @@ -0,0 +1 @@ +include ':app' diff --git a/gradle/common-data/bilbao.json b/gradle/common-data/bilbao.json new file mode 100644 index 0000000000..bb0aa6e113 --- /dev/null +++ b/gradle/common-data/bilbao.json @@ -0,0 +1,41 @@ +{ + "coord": { + "lon": -2.93, + "lat": 43.26 + }, + "sys": { + "message": 0.0139, + "country": "ES", + "sunrise": 1429766168, + "sunset": 1429815829 + }, + "weather": [ + { + "id": 802, + "main": "Clouds", + "description": "scattered clouds", + "icon": "03d" + } + ], + "base": "stations", + "main": { + "temp": 283.681, + "temp_min": 283.681, + "temp_max": 283.681, + "pressure": 991.72, + "sea_level": 1034.92, + "grnd_leve": 991.72, + "humidity": 98 + }, + "wind": { + "speed": 1.07, + "deg": 144.001 + }, + "clouds": { + "all": 36 + }, + "dt": 1429773245, + "id": 3128026, + "name": "Bilbao", + "cod": 200 +} diff --git a/gradle/gson-deserializers-okhttp-asyncTask/.gitignore b/gradle/gson-deserializers-okhttp-asyncTask/.gitignore new file mode 100644 index 0000000000..ccf2efe026 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/.gitignore @@ -0,0 +1,27 @@ +# Built application files +*.apk +*.ap_ + +# Files for the Dalvik VM +*.dex + +# Java class files +*.class + +# Generated files +bin/ +gen/ + +# Gradle files +.gradle/ +build/ +/*/build/ + +# Local configuration file (sdk path, etc) +local.properties + +# Proguard folder generated by Eclipse +proguard/ + +# Log Files +*.log diff --git a/gradle/gson-deserializers-okhttp-asyncTask/MyApplication.iml b/gradle/gson-deserializers-okhttp-asyncTask/MyApplication.iml new file mode 100644 index 0000000000..0bb6048ae0 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/MyApplication.iml @@ -0,0 +1,19 @@ + + + + + + + + + + + + + + + + + + diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/.gitignore b/gradle/gson-deserializers-okhttp-asyncTask/app/.gitignore new file mode 100644 index 0000000000..796b96d1c4 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/.gitignore @@ -0,0 +1 @@ +/build diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/app.iml b/gradle/gson-deserializers-okhttp-asyncTask/app/app.iml new file mode 100644 index 0000000000..71452a7f66 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/app.iml @@ -0,0 +1,99 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/build.gradle b/gradle/gson-deserializers-okhttp-asyncTask/app/build.gradle new file mode 100644 index 0000000000..c12f0007c3 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/build.gradle @@ -0,0 +1,44 @@ +apply plugin: 'com.android.application' +apply plugin: 'kotlin-android' + +android { + compileSdkVersion 22 + buildToolsVersion "22.0.1" + + defaultConfig { + applicationId "com.irontec.kotlintest" + minSdkVersion 16 + targetSdkVersion 22 + versionCode 1 + versionName "1.0" + } + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' + } + } + sourceSets { + main.java.srcDirs += 'src/main/kotlin' + } +} + +dependencies { + compile fileTree(dir: 'libs', include: ['*.jar']) + compile 'com.android.support:appcompat-v7:22.1.0' + compile 'com.google.code.gson:gson:2.3.1' + compile 'com.squareup.okhttp:okhttp:2.3.0' + compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" +} +buildscript { + ext.kotlin_version = '0.11.91.2' + repositories { + mavenCentral() + } + dependencies { + classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" + } +} +repositories { + mavenCentral() +} diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/proguard-rules.pro b/gradle/gson-deserializers-okhttp-asyncTask/app/proguard-rules.pro new file mode 100644 index 0000000000..d6d8d1fbb0 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/proguard-rules.pro @@ -0,0 +1,17 @@ +# Add project specific ProGuard rules here. +# By default, the flags in this file are appended to flags specified +# in /Users/axier/Library/Android/sdk/tools/proguard/proguard-android.txt +# You can edit the include path and order by changing the proguardFiles +# directive in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# Add any project specific keep options here: + +# 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 *; +#} diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/AndroidManifest.xml b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000000..e609988df0 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/AndroidManifest.xml @@ -0,0 +1,23 @@ + + + + + + + + + + + + + + + + diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt new file mode 100644 index 0000000000..e2307adcfe --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt @@ -0,0 +1,83 @@ +package com.irontec.kotlintest + +import android.os.AsyncTask +import android.os.Bundle +import android.support.v7.app.AppCompatActivity +import android.util.Log +import android.view.Menu +import android.view.MenuItem +import android.widget.TextView +import com.google.gson.Gson +import com.google.gson.GsonBuilder +import com.irontec.kotlintest.deserializers.WeatherDeserializer +import com.irontec.kotlintest.models.WeatherObject +import com.irontec.kotlintest.networking.NetworkClient +import org.json.JSONObject +import java.io.BufferedInputStream +import java.io.BufferedReader +import java.io.InputStreamReader +import java.net.HttpURLConnection +import java.net.URL + + +public class MainActivity : AppCompatActivity() { + + open val mTextView: TextView + get() { + return findViewById(R.id.text) as TextView + } + + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + setContentView(R.layout.activity_main) + + GetJsonWithOkHttpClient(mTextView).execute() + + } + + open class GetJsonWithOkHttpClient(textView: TextView) : AsyncTask() { + + val mInnerTextView = textView + + override fun doInBackground(vararg params: Void?): String? { + val networkClient = NetworkClient() + val stream = BufferedInputStream( + networkClient.get("https://raw.githubusercontent.com/irontec/android-kotlin-samples/master/common-data/bilbao.json")) + return readStream(stream); + } + + override fun onPostExecute(result: String?) { + super.onPostExecute(result) + + + val gsonBuilder = GsonBuilder().serializeNulls(); + gsonBuilder.registerTypeAdapter(javaClass(), WeatherDeserializer()); + val gson = gsonBuilder.create(); + val weather = gson.fromJson(result, javaClass()) as WeatherObject + + mInnerTextView.setText(weather.toString()) + + } + + fun readStream(inputStream: BufferedInputStream): String { + val bufferedReader = BufferedReader(InputStreamReader(inputStream)); + val stringBuilder = StringBuilder(); + bufferedReader.forEachLine { stringBuilder.append(it) } + return stringBuilder.toString() + } + } + + override fun onCreateOptionsMenu(menu: Menu): Boolean { + getMenuInflater().inflate(R.menu.menu_main, menu) + return true + } + + override fun onOptionsItemSelected(item: MenuItem): Boolean { + val id = item.getItemId() + if (id == R.id.action_settings) { + return true + } + return super.onOptionsItemSelected(item) + } +} diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt new file mode 100644 index 0000000000..c8e2caaa5e --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt @@ -0,0 +1,39 @@ +package com.irontec.kotlintest.deserializers + +import com.google.gson.JsonDeserializationContext +import com.google.gson.JsonDeserializer +import com.google.gson.JsonElement +import com.google.gson.JsonObject +import com.irontec.kotlintest.models.WeatherObject +import com.irontec.kotlintest.models.WindObject +import java.lang.reflect.Type + +/** + * Created by axier on 24/4/15. + */ +open class WeatherDeserializer : JsonDeserializer { + + override fun deserialize(json: JsonElement?, typeOfT: Type?, context: JsonDeserializationContext?): WeatherObject? { + val jsonObj = json as JsonObject + + val wheather = WeatherObject() + val wind = WindObject() + + val jsonWeatherArray = jsonObj.getAsJsonArray("weather").get(0) + val jsonMainObj = jsonObj.getAsJsonObject("main") + val jsonWindObj = jsonObj.getAsJsonObject("wind") + + wheather.main = jsonWeatherArray.getAsJsonObject().get("main").getAsString() + wheather.description = jsonWeatherArray.getAsJsonObject().get("description").getAsString() + wheather.temp = jsonMainObj.get("temp").getAsFloat() + wheather.temp_Max = jsonMainObj.get("temp_max").getAsFloat() + wheather.temp_Min = jsonMainObj.get("temp_min").getAsFloat() + wheather.humidity = jsonMainObj.get("humidity").getAsInt() + wind.speed = jsonWindObj.get("speed").getAsFloat() + wind.deg = jsonWindObj.get("deg").getAsFloat() + wheather.wind = wind + + return wheather + + } +} \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt new file mode 100644 index 0000000000..caf561293b --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt @@ -0,0 +1,24 @@ +package com.irontec.kotlintest.models + +/** + * Created by axier on 24/4/15. + */ +public class WeatherObject { + + public var main: String = "" + public var description: String = "" + public var temp: Float = 0.0f + public var temp_Max: Float = 0.0f + public var temp_Min: Float = 0.0f + public var humidity: Int = 0 + public var wind: WindObject? = null + + init { + println(this.toString()) + } + + override fun toString() = + "Main ${main}, description ${description}, temp ${temp}, temp_Max ${temp_Max}," + + ", temp_Min ${temp_Min}, humidity ${humidity}, wind ${wind.toString()}" + +} \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt new file mode 100644 index 0000000000..5ab3506947 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt @@ -0,0 +1,17 @@ +package com.irontec.kotlintest.models + +/** + * Created by axier on 24/4/15. + */ +public class WindObject { + + public var speed: Float = 0.0f + public var deg: Float = 0.0f + + init { + println(this.toString()) + } + + override fun toString() = "Speed ${speed}, deg ${deg}" + +} \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt new file mode 100644 index 0000000000..87830ead49 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt @@ -0,0 +1,21 @@ +package com.irontec.kotlintest.networking + +import com.squareup.okhttp.OkHttpClient +import com.squareup.okhttp.Request +import java.io.InputStream + +/** + * Created by axier on 23/4/15. + */ +open class NetworkClient { + + fun get(url: String): InputStream { + val request = Request.Builder().url(url).build() + val response = OkHttpClient().newCall(request).execute() + val body = response.body() + // body.toString() returns a string representing the object and not the body itself, probably + // kotlins fault when using third party libraries. Use byteStream() and convert it to a String + return body.byteStream() + } + +} \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/layout/activity_main.xml b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/layout/activity_main.xml new file mode 100644 index 0000000000..addda73474 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/layout/activity_main.xml @@ -0,0 +1,10 @@ + + + + + diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/menu/menu_main.xml b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/menu/menu_main.xml new file mode 100644 index 0000000000..b1cb90811d --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/menu/menu_main.xml @@ -0,0 +1,6 @@ + + + diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-hdpi/ic_launcher.png b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-hdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..cde69bcccec65160d92116f20ffce4fce0b5245c GIT binary patch literal 3418 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 literal 0 HcmV?d00001 diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-xhdpi/ic_launcher.png b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-xhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..bfa42f0e7b91d006d22352c9ff2f134e504e3c1d GIT binary patch literal 4842 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 literal 0 HcmV?d00001 diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-xxhdpi/ic_launcher.png b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-xxhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..324e72cdd7480cb983fa1bcc7ce686e51ef87fe7 GIT binary patch literal 7718 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 literal 0 HcmV?d00001 diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values-w820dp/dimens.xml b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values-w820dp/dimens.xml new file mode 100644 index 0000000000..63fc816444 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values-w820dp/dimens.xml @@ -0,0 +1,6 @@ + + + 64dp + diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/dimens.xml b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/dimens.xml new file mode 100644 index 0000000000..47c8224673 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/dimens.xml @@ -0,0 +1,5 @@ + + + 16dp + 16dp + diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/strings.xml b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/strings.xml new file mode 100644 index 0000000000..7e8ae97852 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/strings.xml @@ -0,0 +1,6 @@ + + kotlintest + + Hello world! + Settings + diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/styles.xml b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/styles.xml new file mode 100644 index 0000000000..766ab99304 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/styles.xml @@ -0,0 +1,8 @@ + + + + + + diff --git a/gradle/gson-deserializers-okhttp-asyncTask/build.gradle b/gradle/gson-deserializers-okhttp-asyncTask/build.gradle new file mode 100644 index 0000000000..d3ff69d6e7 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/build.gradle @@ -0,0 +1,19 @@ +// Top-level build file where you can add configuration options common to all sub-projects/modules. + +buildscript { + repositories { + jcenter() + } + dependencies { + classpath 'com.android.tools.build:gradle:1.1.0' + + // NOTE: Do not place your application dependencies here; they belong + // in the individual module build.gradle files + } +} + +allprojects { + repositories { + jcenter() + } +} diff --git a/gradle/gson-deserializers-okhttp-asyncTask/gradle.properties b/gradle/gson-deserializers-okhttp-asyncTask/gradle.properties new file mode 100644 index 0000000000..1d3591c8a4 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/gradle.properties @@ -0,0 +1,18 @@ +# 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. +# Default value: -Xmx10248m -XX:MaxPermSize=256m +# org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8 + +# 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 \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asyncTask/gradle/wrapper/gradle-wrapper.jar b/gradle/gson-deserializers-okhttp-asyncTask/gradle/wrapper/gradle-wrapper.jar new file mode 100644 index 0000000000000000000000000000000000000000..8c0fb64a8698b08ecc4158d828ca593c4928e9dd GIT binary patch literal 49896 zcmagFb986H(k`5d^NVfUwr$(C?M#x1ZQHiZiEVpg+jrjgoQrerx!>1o_ul)D>ebz~ zs=Mmxr&>W81QY-S1PKWQ%N-;H^tS;2*XwVA`dej1RRn1z<;3VgfE4~kaG`A%QSPsR z#ovnZe+tS9%1MfeDyz`RirvdjPRK~p(#^q2(^5@O&NM19EHdvN-A&StN>0g6QA^VN z0Gx%Gq#PD$QMRFzmK+utjS^Y1F0e8&u&^=w5K<;4Rz|i3A=o|IKLY+g`iK6vfr9?+ z-`>gmU&i?FGSL5&F?TXFu`&Js6h;15QFkXp2M1H9|Eq~bpov-GU(uz%mH0n55wUl- zv#~ccAz`F5wlQ>e_KlJS3@{)B?^v*EQM=IxLa&76^y51a((wq|2-`qON>+4dLc{Oo z51}}o^Zen(oAjxDK7b++9_Yg`67p$bPo3~BCpGM7uAWmvIhWc5Gi+gQZ|Pwa-Gll@<1xmcPy z|NZmu6m)g5Ftu~BG&Xdxclw7Cij{xbBMBn-LMII#Slp`AElb&2^Hw+w>(3crLH!;I zN+Vk$D+wP1#^!MDCiad@vM>H#6+`Ct#~6VHL4lzmy;lSdk>`z6)=>Wh15Q2)dQtGqvn0vJU@+(B5{MUc*qs4!T+V=q=wy)<6$~ z!G>e_4dN@lGeF_$q9`Ju6Ncb*x?O7=l{anm7Eahuj_6lA{*#Gv*TaJclevPVbbVYu z(NY?5q+xxbO6%g1xF0r@Ix8fJ~u)VRUp`S%&rN$&e!Od`~s+64J z5*)*WSi*i{k%JjMSIN#X;jC{HG$-^iX+5f5BGOIHWAl*%15Z#!xntpk($-EGKCzKa zT7{siZ9;4TICsWQ$pu&wKZQTCvpI$Xvzwxoi+XkkpeE&&kFb!B?h2hi%^YlXt|-@5 zHJ~%AN!g_^tmn1?HSm^|gCE#!GRtK2(L{9pL#hp0xh zME}|DB>(5)`iE7CM)&_+S}-Bslc#@B5W4_+k4Cp$l>iVyg$KP>CN?SVGZ(&02>iZK zB<^HP$g$Lq*L$BWd?2(F?-MUbNWTJVQdW7$#8a|k_30#vHAD1Z{c#p;bETk0VnU5A zBgLe2HFJ3032$G<`m*OB!KM$*sdM20jm)It5OSru@tXpK5LT>#8)N!*skNu1$TpIw zufjjdp#lyH5bZ%|Iuo|iu9vG1HrIVWLH>278xo>aVBkPN3V$~!=KnlXQ4eDqS7%E% zQ!z^$Q$b^6Q)g#cLpwur(|<0gWHo6A6jc;n`t(V9T;LzTAU{IAu*uEQ%Ort1k+Kn+f_N`9|bxYC+~Z1 zCC1UCWv*Orx$_@ydv9mIe(liLfOr7mhbV@tKw{6)q^1DH1nmvZ0cj215R<~&I<4S| zgnr;9Cdjqpz#o8i0CQjtl`}{c*P)aSdH|abxGdrR)-3z+02-eX(k*B)Uqv6~^nh** z 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 \(.*\)$'` + if expr "$link" : '/.*' > /dev/null; then + PRG="$link" + else + PRG=`dirname "$PRG"`"/$link" + fi +done +SAVED="`pwd`" +cd "`dirname \"$PRG\"`/" >&- +APP_HOME="`pwd -P`" +cd "$SAVED" >&- + +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" ] ; 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"` + + # 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 + +# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules +function splitJvmOpts() { + JVM_OPTS=("$@") +} +eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS +JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME" + +exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@" diff --git a/gradle/gson-deserializers-okhttp-asyncTask/gradlew.bat b/gradle/gson-deserializers-okhttp-asyncTask/gradlew.bat new file mode 100644 index 0000000000..aec99730b4 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/gradlew.bat @@ -0,0 +1,90 @@ +@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 + +@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= + +set DIRNAME=%~dp0 +if "%DIRNAME%" == "" set DIRNAME=. +set APP_BASE_NAME=%~n0 +set APP_HOME=%DIRNAME% + +@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 Windowz variants + +if not "%OS%" == "Windows_NT" goto win9xME_args +if "%@eval[2+2]" == "4" goto 4NT_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=%* +goto execute + +:4NT_args +@rem Get arguments from the 4NT Shell from JP Software +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/gradle/gson-deserializers-okhttp-asyncTask/settings.gradle b/gradle/gson-deserializers-okhttp-asyncTask/settings.gradle new file mode 100644 index 0000000000..e7b4def49c --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asyncTask/settings.gradle @@ -0,0 +1 @@ +include ':app' diff --git a/gradle/httpurlconnection-asynctask/.gitignore b/gradle/httpurlconnection-asynctask/.gitignore new file mode 100644 index 0000000000..ccf2efe026 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.gitignore @@ -0,0 +1,27 @@ +# Built application files +*.apk +*.ap_ + +# Files for the Dalvik VM +*.dex + +# Java class files +*.class + +# Generated files +bin/ +gen/ + +# Gradle files +.gradle/ +build/ +/*/build/ + +# Local configuration file (sdk path, etc) +local.properties + +# Proguard folder generated by Eclipse +proguard/ + +# Log Files +*.log diff --git a/gradle/httpurlconnection-asynctask/MyApplication.iml b/gradle/httpurlconnection-asynctask/MyApplication.iml new file mode 100644 index 0000000000..0bb6048ae0 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/MyApplication.iml @@ -0,0 +1,19 @@ + + + + + + + + + + + + + + + + + + diff --git a/gradle/httpurlconnection-asynctask/app/.gitignore b/gradle/httpurlconnection-asynctask/app/.gitignore new file mode 100644 index 0000000000..796b96d1c4 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/app/.gitignore @@ -0,0 +1 @@ +/build diff --git a/gradle/httpurlconnection-asynctask/app/app.iml b/gradle/httpurlconnection-asynctask/app/app.iml new file mode 100644 index 0000000000..ff46dc445e --- /dev/null +++ b/gradle/httpurlconnection-asynctask/app/app.iml @@ -0,0 +1,96 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/gradle/httpurlconnection-asynctask/app/build.gradle b/gradle/httpurlconnection-asynctask/app/build.gradle new file mode 100644 index 0000000000..5c2ef7ba5f --- /dev/null +++ b/gradle/httpurlconnection-asynctask/app/build.gradle @@ -0,0 +1,42 @@ +apply plugin: 'com.android.application' +apply plugin: 'kotlin-android' + +android { + compileSdkVersion 22 + buildToolsVersion "22.0.1" + + defaultConfig { + applicationId "com.irontec.kotlintest" + minSdkVersion 16 + targetSdkVersion 22 + versionCode 1 + versionName "1.0" + } + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' + } + } + sourceSets { + main.java.srcDirs += 'src/main/kotlin' + } +} + +dependencies { + compile fileTree(dir: 'libs', include: ['*.jar']) + compile 'com.android.support:appcompat-v7:22.0.0' + compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" +} +buildscript { + ext.kotlin_version = '0.11.91.2' + repositories { + mavenCentral() + } + dependencies { + classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" + } +} +repositories { + mavenCentral() +} diff --git a/gradle/httpurlconnection-asynctask/app/proguard-rules.pro b/gradle/httpurlconnection-asynctask/app/proguard-rules.pro new file mode 100644 index 0000000000..d6d8d1fbb0 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/app/proguard-rules.pro @@ -0,0 +1,17 @@ +# Add project specific ProGuard rules here. +# By default, the flags in this file are appended to flags specified +# in /Users/axier/Library/Android/sdk/tools/proguard/proguard-android.txt +# You can edit the include path and order by changing the proguardFiles +# directive in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# Add any project specific keep options here: + +# 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 *; +#} diff --git a/gradle/httpurlconnection-asynctask/app/src/main/AndroidManifest.xml b/gradle/httpurlconnection-asynctask/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000000..e609988df0 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/app/src/main/AndroidManifest.xml @@ -0,0 +1,23 @@ + + + + + + + + + + + + + + + + diff --git a/gradle/httpurlconnection-asynctask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt b/gradle/httpurlconnection-asynctask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt new file mode 100644 index 0000000000..1ec6b7f271 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt @@ -0,0 +1,91 @@ +package com.irontec.kotlintest + +import android.os.AsyncTask +import android.support.v7.app.ActionBarActivity +import android.os.Bundle +import android.util.Log +import android.view.Menu +import android.view.MenuItem +import android.widget.TextView +import org.json.JSONObject +import java.io.BufferedInputStream +import java.io.BufferedReader +import java.io.InputStreamReader +import java.net.HttpURLConnection +import java.net.URL + + +public class MainActivity : ActionBarActivity() { + + open val mTextView: TextView + get() { + return findViewById(R.id.text) as TextView + } + + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + setContentView(R.layout.activity_main) + + GetWeatherTask(mTextView).execute() + } + + class GetWeatherTask(textView: TextView) : AsyncTask() { + + val innerTextView: TextView? = textView + + override fun doInBackground(vararg params: Void?): String? { + val url = URL("https://raw.githubusercontent.com/irontec/android-kotlin-samples/master/common-data/bilbao.json") + val httpClient = url.openConnection() as HttpURLConnection + if(httpClient.getResponseCode() == HttpURLConnection.HTTP_OK){ + try { + val stream = BufferedInputStream(httpClient.getInputStream()) + val data: String = readStream(inputStream = stream) + return data; + } catch (e : Exception) { + e.printStackTrace() + } finally { + httpClient.disconnect() + } + }else{ + println("ERROR ${httpClient.getResponseCode()}") + } + return null + } + + fun readStream(inputStream: BufferedInputStream): String { + val bufferedReader = BufferedReader(InputStreamReader(inputStream)); + val stringBuilder = StringBuilder(); + bufferedReader.forEachLine { stringBuilder.append(it) } + return stringBuilder.toString() + } + + override fun onPreExecute() { + super.onPreExecute() + } + + override fun onPostExecute(result: String?) { + super.onPostExecute(result) + + innerTextView?.setText(JSONObject(result).toString()) + + /** + * ... Work with the weather data + */ + + } + } + + override fun onCreateOptionsMenu(menu: Menu): Boolean { + getMenuInflater().inflate(R.menu.menu_main, menu) + return true + } + + override fun onOptionsItemSelected(item: MenuItem): Boolean { + val id = item.getItemId() + if (id == R.id.action_settings) { + return true + } + return super.onOptionsItemSelected(item) + } +} diff --git a/gradle/httpurlconnection-asynctask/app/src/main/res/layout/activity_main.xml b/gradle/httpurlconnection-asynctask/app/src/main/res/layout/activity_main.xml new file mode 100644 index 0000000000..addda73474 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/app/src/main/res/layout/activity_main.xml @@ -0,0 +1,10 @@ + + + + + diff --git a/gradle/httpurlconnection-asynctask/app/src/main/res/menu/menu_main.xml b/gradle/httpurlconnection-asynctask/app/src/main/res/menu/menu_main.xml new file mode 100644 index 0000000000..b1cb90811d --- /dev/null +++ b/gradle/httpurlconnection-asynctask/app/src/main/res/menu/menu_main.xml @@ -0,0 +1,6 @@ + + + diff --git a/gradle/httpurlconnection-asynctask/app/src/main/res/mipmap-hdpi/ic_launcher.png b/gradle/httpurlconnection-asynctask/app/src/main/res/mipmap-hdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..cde69bcccec65160d92116f20ffce4fce0b5245c GIT binary patch literal 3418 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 literal 0 HcmV?d00001 diff --git a/gradle/httpurlconnection-asynctask/app/src/main/res/mipmap-xhdpi/ic_launcher.png b/gradle/httpurlconnection-asynctask/app/src/main/res/mipmap-xhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..bfa42f0e7b91d006d22352c9ff2f134e504e3c1d GIT binary patch literal 4842 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 literal 0 HcmV?d00001 diff --git a/gradle/httpurlconnection-asynctask/app/src/main/res/mipmap-xxhdpi/ic_launcher.png b/gradle/httpurlconnection-asynctask/app/src/main/res/mipmap-xxhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..324e72cdd7480cb983fa1bcc7ce686e51ef87fe7 GIT binary patch literal 7718 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 literal 0 HcmV?d00001 diff --git a/gradle/httpurlconnection-asynctask/app/src/main/res/values-w820dp/dimens.xml b/gradle/httpurlconnection-asynctask/app/src/main/res/values-w820dp/dimens.xml new file mode 100644 index 0000000000..63fc816444 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/app/src/main/res/values-w820dp/dimens.xml @@ -0,0 +1,6 @@ + + + 64dp + diff --git a/gradle/httpurlconnection-asynctask/app/src/main/res/values/dimens.xml b/gradle/httpurlconnection-asynctask/app/src/main/res/values/dimens.xml new file mode 100644 index 0000000000..47c8224673 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/app/src/main/res/values/dimens.xml @@ -0,0 +1,5 @@ + + + 16dp + 16dp + diff --git a/gradle/httpurlconnection-asynctask/app/src/main/res/values/strings.xml b/gradle/httpurlconnection-asynctask/app/src/main/res/values/strings.xml new file mode 100644 index 0000000000..7e8ae97852 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/app/src/main/res/values/strings.xml @@ -0,0 +1,6 @@ + + kotlintest + + Hello world! + Settings + diff --git a/gradle/httpurlconnection-asynctask/app/src/main/res/values/styles.xml b/gradle/httpurlconnection-asynctask/app/src/main/res/values/styles.xml new file mode 100644 index 0000000000..766ab99304 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/app/src/main/res/values/styles.xml @@ -0,0 +1,8 @@ + + + + + + diff --git a/gradle/httpurlconnection-asynctask/build.gradle b/gradle/httpurlconnection-asynctask/build.gradle new file mode 100644 index 0000000000..d3ff69d6e7 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/build.gradle @@ -0,0 +1,19 @@ +// Top-level build file where you can add configuration options common to all sub-projects/modules. + +buildscript { + repositories { + jcenter() + } + dependencies { + classpath 'com.android.tools.build:gradle:1.1.0' + + // NOTE: Do not place your application dependencies here; they belong + // in the individual module build.gradle files + } +} + +allprojects { + repositories { + jcenter() + } +} diff --git a/gradle/httpurlconnection-asynctask/gradle.properties b/gradle/httpurlconnection-asynctask/gradle.properties new file mode 100644 index 0000000000..1d3591c8a4 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/gradle.properties @@ -0,0 +1,18 @@ +# 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. +# Default value: -Xmx10248m -XX:MaxPermSize=256m +# org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8 + +# 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 \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/gradle/wrapper/gradle-wrapper.jar b/gradle/httpurlconnection-asynctask/gradle/wrapper/gradle-wrapper.jar new file mode 100644 index 0000000000000000000000000000000000000000..8c0fb64a8698b08ecc4158d828ca593c4928e9dd GIT binary patch literal 49896 zcmagFb986H(k`5d^NVfUwr$(C?M#x1ZQHiZiEVpg+jrjgoQrerx!>1o_ul)D>ebz~ zs=Mmxr&>W81QY-S1PKWQ%N-;H^tS;2*XwVA`dej1RRn1z<;3VgfE4~kaG`A%QSPsR z#ovnZe+tS9%1MfeDyz`RirvdjPRK~p(#^q2(^5@O&NM19EHdvN-A&StN>0g6QA^VN z0Gx%Gq#PD$QMRFzmK+utjS^Y1F0e8&u&^=w5K<;4Rz|i3A=o|IKLY+g`iK6vfr9?+ z-`>gmU&i?FGSL5&F?TXFu`&Js6h;15QFkXp2M1H9|Eq~bpov-GU(uz%mH0n55wUl- zv#~ccAz`F5wlQ>e_KlJS3@{)B?^v*EQM=IxLa&76^y51a((wq|2-`qON>+4dLc{Oo z51}}o^Zen(oAjxDK7b++9_Yg`67p$bPo3~BCpGM7uAWmvIhWc5Gi+gQZ|Pwa-Gll@<1xmcPy z|NZmu6m)g5Ftu~BG&Xdxclw7Cij{xbBMBn-LMII#Slp`AElb&2^Hw+w>(3crLH!;I zN+Vk$D+wP1#^!MDCiad@vM>H#6+`Ct#~6VHL4lzmy;lSdk>`z6)=>Wh15Q2)dQtGqvn0vJU@+(B5{MUc*qs4!T+V=q=wy)<6$~ z!G>e_4dN@lGeF_$q9`Ju6Ncb*x?O7=l{anm7Eahuj_6lA{*#Gv*TaJclevPVbbVYu z(NY?5q+xxbO6%g1xF0r@Ix8fJ~u)VRUp`S%&rN$&e!Od`~s+64J z5*)*WSi*i{k%JjMSIN#X;jC{HG$-^iX+5f5BGOIHWAl*%15Z#!xntpk($-EGKCzKa zT7{siZ9;4TICsWQ$pu&wKZQTCvpI$Xvzwxoi+XkkpeE&&kFb!B?h2hi%^YlXt|-@5 zHJ~%AN!g_^tmn1?HSm^|gCE#!GRtK2(L{9pL#hp0xh zME}|DB>(5)`iE7CM)&_+S}-Bslc#@B5W4_+k4Cp$l>iVyg$KP>CN?SVGZ(&02>iZK zB<^HP$g$Lq*L$BWd?2(F?-MUbNWTJVQdW7$#8a|k_30#vHAD1Z{c#p;bETk0VnU5A zBgLe2HFJ3032$G<`m*OB!KM$*sdM20jm)It5OSru@tXpK5LT>#8)N!*skNu1$TpIw zufjjdp#lyH5bZ%|Iuo|iu9vG1HrIVWLH>278xo>aVBkPN3V$~!=KnlXQ4eDqS7%E% zQ!z^$Q$b^6Q)g#cLpwur(|<0gWHo6A6jc;n`t(V9T;LzTAU{IAu*uEQ%Ort1k+Kn+f_N`9|bxYC+~Z1 zCC1UCWv*Orx$_@ydv9mIe(liLfOr7mhbV@tKw{6)q^1DH1nmvZ0cj215R<~&I<4S| zgnr;9Cdjqpz#o8i0CQjtl`}{c*P)aSdH|abxGdrR)-3z+02-eX(k*B)Uqv6~^nh** z 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 \(.*\)$'` + if expr "$link" : '/.*' > /dev/null; then + PRG="$link" + else + PRG=`dirname "$PRG"`"/$link" + fi +done +SAVED="`pwd`" +cd "`dirname \"$PRG\"`/" >&- +APP_HOME="`pwd -P`" +cd "$SAVED" >&- + +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" ] ; 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"` + + # 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 + +# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules +function splitJvmOpts() { + JVM_OPTS=("$@") +} +eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS +JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME" + +exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@" diff --git a/gradle/httpurlconnection-asynctask/gradlew.bat b/gradle/httpurlconnection-asynctask/gradlew.bat new file mode 100644 index 0000000000..aec99730b4 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/gradlew.bat @@ -0,0 +1,90 @@ +@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 + +@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= + +set DIRNAME=%~dp0 +if "%DIRNAME%" == "" set DIRNAME=. +set APP_BASE_NAME=%~n0 +set APP_HOME=%DIRNAME% + +@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 Windowz variants + +if not "%OS%" == "Windows_NT" goto win9xME_args +if "%@eval[2+2]" == "4" goto 4NT_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=%* +goto execute + +:4NT_args +@rem Get arguments from the 4NT Shell from JP Software +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/gradle/httpurlconnection-asynctask/settings.gradle b/gradle/httpurlconnection-asynctask/settings.gradle new file mode 100644 index 0000000000..e7b4def49c --- /dev/null +++ b/gradle/httpurlconnection-asynctask/settings.gradle @@ -0,0 +1 @@ +include ':app' diff --git a/gradle/listview-baseadapter-data-object/.gitignore b/gradle/listview-baseadapter-data-object/.gitignore new file mode 100644 index 0000000000..ccf2efe026 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.gitignore @@ -0,0 +1,27 @@ +# Built application files +*.apk +*.ap_ + +# Files for the Dalvik VM +*.dex + +# Java class files +*.class + +# Generated files +bin/ +gen/ + +# Gradle files +.gradle/ +build/ +/*/build/ + +# Local configuration file (sdk path, etc) +local.properties + +# Proguard folder generated by Eclipse +proguard/ + +# Log Files +*.log diff --git a/gradle/listview-baseadapter-data-object/MyApplication.iml b/gradle/listview-baseadapter-data-object/MyApplication.iml new file mode 100644 index 0000000000..0bb6048ae0 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/MyApplication.iml @@ -0,0 +1,19 @@ + + + + + + + + + + + + + + + + + + diff --git a/gradle/listview-baseadapter-data-object/app/.gitignore b/gradle/listview-baseadapter-data-object/app/.gitignore new file mode 100644 index 0000000000..796b96d1c4 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/app/.gitignore @@ -0,0 +1 @@ +/build diff --git a/gradle/listview-baseadapter-data-object/app/app.iml b/gradle/listview-baseadapter-data-object/app/app.iml new file mode 100644 index 0000000000..ff46dc445e --- /dev/null +++ b/gradle/listview-baseadapter-data-object/app/app.iml @@ -0,0 +1,96 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/gradle/listview-baseadapter-data-object/app/build.gradle b/gradle/listview-baseadapter-data-object/app/build.gradle new file mode 100644 index 0000000000..5c2ef7ba5f --- /dev/null +++ b/gradle/listview-baseadapter-data-object/app/build.gradle @@ -0,0 +1,42 @@ +apply plugin: 'com.android.application' +apply plugin: 'kotlin-android' + +android { + compileSdkVersion 22 + buildToolsVersion "22.0.1" + + defaultConfig { + applicationId "com.irontec.kotlintest" + minSdkVersion 16 + targetSdkVersion 22 + versionCode 1 + versionName "1.0" + } + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' + } + } + sourceSets { + main.java.srcDirs += 'src/main/kotlin' + } +} + +dependencies { + compile fileTree(dir: 'libs', include: ['*.jar']) + compile 'com.android.support:appcompat-v7:22.0.0' + compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" +} +buildscript { + ext.kotlin_version = '0.11.91.2' + repositories { + mavenCentral() + } + dependencies { + classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" + } +} +repositories { + mavenCentral() +} diff --git a/gradle/listview-baseadapter-data-object/app/proguard-rules.pro b/gradle/listview-baseadapter-data-object/app/proguard-rules.pro new file mode 100644 index 0000000000..d6d8d1fbb0 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/app/proguard-rules.pro @@ -0,0 +1,17 @@ +# Add project specific ProGuard rules here. +# By default, the flags in this file are appended to flags specified +# in /Users/axier/Library/Android/sdk/tools/proguard/proguard-android.txt +# You can edit the include path and order by changing the proguardFiles +# directive in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# Add any project specific keep options here: + +# 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 *; +#} diff --git a/gradle/listview-baseadapter-data-object/app/src/main/AndroidManifest.xml b/gradle/listview-baseadapter-data-object/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000000..e609988df0 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/app/src/main/AndroidManifest.xml @@ -0,0 +1,23 @@ + + + + + + + + + + + + + + + + diff --git a/gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/MainActivity.kt b/gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/MainActivity.kt new file mode 100644 index 0000000000..7caf18d971 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/MainActivity.kt @@ -0,0 +1,50 @@ +package com.irontec.kotlintest + +import android.support.v7.app.ActionBarActivity +import android.os.Bundle +import android.util.Log +import android.view.Menu +import android.view.MenuItem +import android.webkit.WebView +import android.widget.ListView +import com.irontec.kotlintest.adapters.CustomListAdapter +import com.irontec.kotlintest.models.CustomPojo + + +public class MainActivity : ActionBarActivity() { + + val mListView: ListView + get() { + return findViewById(R.id.list) as ListView + } + + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + setContentView(R.layout.activity_main) + + val listdata = Array(90, {i -> CustomPojo(name = i.toString())}) + + val adapter = CustomListAdapter(data = listdata, context = this) + + mListView.setAdapter(adapter) + } + + + override fun onCreateOptionsMenu(menu: Menu): Boolean { + getMenuInflater().inflate(R.menu.menu_main, menu) + return true + } + + override fun onOptionsItemSelected(item: MenuItem): Boolean { + val id = item.getItemId() + if (id == R.id.action_settings) { + return true + } + return super.onOptionsItemSelected(item) + } + + fun getLastNumber(dataset: Array) : Int { + return dataset.last(); + } +} diff --git a/gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/adapters/CustomListAdapter.kt b/gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/adapters/CustomListAdapter.kt new file mode 100644 index 0000000000..7f6c4d0e33 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/adapters/CustomListAdapter.kt @@ -0,0 +1,59 @@ +package com.irontec.kotlintest.adapters + +import android.content.Context +import android.view.LayoutInflater +import android.view.View +import android.view.ViewGroup +import android.widget.BaseAdapter +import android.widget.TextView +import com.irontec.kotlintest.R +import com.irontec.kotlintest.models.CustomPojo + +/** + * Created by axier on 22/4/15. + */ +open class CustomListAdapter(data: Array, context: Context) : BaseAdapter() { + + var localData = data; + + override fun getCount(): Int { + return localData.size() + } + + override fun getItem(position: Int): Any { + return localData.get(position) + } + + override fun getItemId(position: Int): Long { + return position.toLong() + } + + private val mInflater: LayoutInflater? + { + mInflater = LayoutInflater.from(context) + } + + override fun getView(position: Int, convertView: View?, parent: ViewGroup): View? { + + val view: View? + val vh: ListRowHolder + if (convertView == null) { + view = mInflater?.inflate(R.layout.row_item, parent, false) + vh = ListRowHolder(view) + view?.setTag(vh) + } else { + view = convertView + vh = view.getTag() as ListRowHolder + } + vh.label.setText(localData.get(index = position).toString()) + return view; + } + + private class ListRowHolder(row: View?) { + public val label: TextView + { + this.label = row?.findViewById(R.id.label) as TextView + } + } + +} \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/models/CustomPojo.kt b/gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/models/CustomPojo.kt new file mode 100644 index 0000000000..dbbd0a4ad4 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/models/CustomPojo.kt @@ -0,0 +1,14 @@ +package com.irontec.kotlintest.models + +/** + * Created by axier on 21/4/15. + */ + +open class CustomPojo (var name: String) { + + init { + println("Customer initialized with value ${name}") + } + + override fun toString() = "$name" +} \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/app/src/main/res/layout/activity_main.xml b/gradle/listview-baseadapter-data-object/app/src/main/res/layout/activity_main.xml new file mode 100644 index 0000000000..5aa463765d --- /dev/null +++ b/gradle/listview-baseadapter-data-object/app/src/main/res/layout/activity_main.xml @@ -0,0 +1,10 @@ + + + + + diff --git a/gradle/listview-baseadapter-data-object/app/src/main/res/layout/row_item.xml b/gradle/listview-baseadapter-data-object/app/src/main/res/layout/row_item.xml new file mode 100644 index 0000000000..3bd32284d0 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/app/src/main/res/layout/row_item.xml @@ -0,0 +1,11 @@ + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/app/src/main/res/menu/menu_main.xml b/gradle/listview-baseadapter-data-object/app/src/main/res/menu/menu_main.xml new file mode 100644 index 0000000000..b1cb90811d --- /dev/null +++ b/gradle/listview-baseadapter-data-object/app/src/main/res/menu/menu_main.xml @@ -0,0 +1,6 @@ + + + diff --git a/gradle/listview-baseadapter-data-object/app/src/main/res/mipmap-hdpi/ic_launcher.png b/gradle/listview-baseadapter-data-object/app/src/main/res/mipmap-hdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..cde69bcccec65160d92116f20ffce4fce0b5245c GIT binary patch literal 3418 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 literal 0 HcmV?d00001 diff --git a/gradle/listview-baseadapter-data-object/app/src/main/res/mipmap-xhdpi/ic_launcher.png b/gradle/listview-baseadapter-data-object/app/src/main/res/mipmap-xhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..bfa42f0e7b91d006d22352c9ff2f134e504e3c1d GIT binary patch literal 4842 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 literal 0 HcmV?d00001 diff --git a/gradle/listview-baseadapter-data-object/app/src/main/res/mipmap-xxhdpi/ic_launcher.png b/gradle/listview-baseadapter-data-object/app/src/main/res/mipmap-xxhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..324e72cdd7480cb983fa1bcc7ce686e51ef87fe7 GIT binary patch literal 7718 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 literal 0 HcmV?d00001 diff --git a/gradle/listview-baseadapter-data-object/app/src/main/res/values-w820dp/dimens.xml b/gradle/listview-baseadapter-data-object/app/src/main/res/values-w820dp/dimens.xml new file mode 100644 index 0000000000..63fc816444 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/app/src/main/res/values-w820dp/dimens.xml @@ -0,0 +1,6 @@ + + + 64dp + diff --git a/gradle/listview-baseadapter-data-object/app/src/main/res/values/dimens.xml b/gradle/listview-baseadapter-data-object/app/src/main/res/values/dimens.xml new file mode 100644 index 0000000000..47c8224673 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/app/src/main/res/values/dimens.xml @@ -0,0 +1,5 @@ + + + 16dp + 16dp + diff --git a/gradle/listview-baseadapter-data-object/app/src/main/res/values/strings.xml b/gradle/listview-baseadapter-data-object/app/src/main/res/values/strings.xml new file mode 100644 index 0000000000..7e8ae97852 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/app/src/main/res/values/strings.xml @@ -0,0 +1,6 @@ + + kotlintest + + Hello world! + Settings + diff --git a/gradle/listview-baseadapter-data-object/app/src/main/res/values/styles.xml b/gradle/listview-baseadapter-data-object/app/src/main/res/values/styles.xml new file mode 100644 index 0000000000..766ab99304 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/app/src/main/res/values/styles.xml @@ -0,0 +1,8 @@ + + + + + + diff --git a/gradle/listview-baseadapter-data-object/build.gradle b/gradle/listview-baseadapter-data-object/build.gradle new file mode 100644 index 0000000000..d3ff69d6e7 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/build.gradle @@ -0,0 +1,19 @@ +// Top-level build file where you can add configuration options common to all sub-projects/modules. + +buildscript { + repositories { + jcenter() + } + dependencies { + classpath 'com.android.tools.build:gradle:1.1.0' + + // NOTE: Do not place your application dependencies here; they belong + // in the individual module build.gradle files + } +} + +allprojects { + repositories { + jcenter() + } +} diff --git a/gradle/listview-baseadapter-data-object/gradle.properties b/gradle/listview-baseadapter-data-object/gradle.properties new file mode 100644 index 0000000000..1d3591c8a4 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/gradle.properties @@ -0,0 +1,18 @@ +# 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. +# Default value: -Xmx10248m -XX:MaxPermSize=256m +# org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8 + +# 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 \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/gradle/wrapper/gradle-wrapper.jar b/gradle/listview-baseadapter-data-object/gradle/wrapper/gradle-wrapper.jar new file mode 100644 index 0000000000000000000000000000000000000000..8c0fb64a8698b08ecc4158d828ca593c4928e9dd GIT binary patch literal 49896 zcmagFb986H(k`5d^NVfUwr$(C?M#x1ZQHiZiEVpg+jrjgoQrerx!>1o_ul)D>ebz~ zs=Mmxr&>W81QY-S1PKWQ%N-;H^tS;2*XwVA`dej1RRn1z<;3VgfE4~kaG`A%QSPsR z#ovnZe+tS9%1MfeDyz`RirvdjPRK~p(#^q2(^5@O&NM19EHdvN-A&StN>0g6QA^VN z0Gx%Gq#PD$QMRFzmK+utjS^Y1F0e8&u&^=w5K<;4Rz|i3A=o|IKLY+g`iK6vfr9?+ z-`>gmU&i?FGSL5&F?TXFu`&Js6h;15QFkXp2M1H9|Eq~bpov-GU(uz%mH0n55wUl- zv#~ccAz`F5wlQ>e_KlJS3@{)B?^v*EQM=IxLa&76^y51a((wq|2-`qON>+4dLc{Oo z51}}o^Zen(oAjxDK7b++9_Yg`67p$bPo3~BCpGM7uAWmvIhWc5Gi+gQZ|Pwa-Gll@<1xmcPy z|NZmu6m)g5Ftu~BG&Xdxclw7Cij{xbBMBn-LMII#Slp`AElb&2^Hw+w>(3crLH!;I zN+Vk$D+wP1#^!MDCiad@vM>H#6+`Ct#~6VHL4lzmy;lSdk>`z6)=>Wh15Q2)dQtGqvn0vJU@+(B5{MUc*qs4!T+V=q=wy)<6$~ z!G>e_4dN@lGeF_$q9`Ju6Ncb*x?O7=l{anm7Eahuj_6lA{*#Gv*TaJclevPVbbVYu z(NY?5q+xxbO6%g1xF0r@Ix8fJ~u)VRUp`S%&rN$&e!Od`~s+64J z5*)*WSi*i{k%JjMSIN#X;jC{HG$-^iX+5f5BGOIHWAl*%15Z#!xntpk($-EGKCzKa zT7{siZ9;4TICsWQ$pu&wKZQTCvpI$Xvzwxoi+XkkpeE&&kFb!B?h2hi%^YlXt|-@5 zHJ~%AN!g_^tmn1?HSm^|gCE#!GRtK2(L{9pL#hp0xh zME}|DB>(5)`iE7CM)&_+S}-Bslc#@B5W4_+k4Cp$l>iVyg$KP>CN?SVGZ(&02>iZK zB<^HP$g$Lq*L$BWd?2(F?-MUbNWTJVQdW7$#8a|k_30#vHAD1Z{c#p;bETk0VnU5A zBgLe2HFJ3032$G<`m*OB!KM$*sdM20jm)It5OSru@tXpK5LT>#8)N!*skNu1$TpIw zufjjdp#lyH5bZ%|Iuo|iu9vG1HrIVWLH>278xo>aVBkPN3V$~!=KnlXQ4eDqS7%E% zQ!z^$Q$b^6Q)g#cLpwur(|<0gWHo6A6jc;n`t(V9T;LzTAU{IAu*uEQ%Ort1k+Kn+f_N`9|bxYC+~Z1 zCC1UCWv*Orx$_@ydv9mIe(liLfOr7mhbV@tKw{6)q^1DH1nmvZ0cj215R<~&I<4S| zgnr;9Cdjqpz#o8i0CQjtl`}{c*P)aSdH|abxGdrR)-3z+02-eX(k*B)Uqv6~^nh** z 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 \(.*\)$'` + if expr "$link" : '/.*' > /dev/null; then + PRG="$link" + else + PRG=`dirname "$PRG"`"/$link" + fi +done +SAVED="`pwd`" +cd "`dirname \"$PRG\"`/" >&- +APP_HOME="`pwd -P`" +cd "$SAVED" >&- + +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" ] ; 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"` + + # 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 + +# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules +function splitJvmOpts() { + JVM_OPTS=("$@") +} +eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS +JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME" + +exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@" diff --git a/gradle/listview-baseadapter-data-object/gradlew.bat b/gradle/listview-baseadapter-data-object/gradlew.bat new file mode 100644 index 0000000000..aec99730b4 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/gradlew.bat @@ -0,0 +1,90 @@ +@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 + +@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= + +set DIRNAME=%~dp0 +if "%DIRNAME%" == "" set DIRNAME=. +set APP_BASE_NAME=%~n0 +set APP_HOME=%DIRNAME% + +@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 Windowz variants + +if not "%OS%" == "Windows_NT" goto win9xME_args +if "%@eval[2+2]" == "4" goto 4NT_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=%* +goto execute + +:4NT_args +@rem Get arguments from the 4NT Shell from JP Software +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/gradle/listview-baseadapter-data-object/settings.gradle b/gradle/listview-baseadapter-data-object/settings.gradle new file mode 100644 index 0000000000..e7b4def49c --- /dev/null +++ b/gradle/listview-baseadapter-data-object/settings.gradle @@ -0,0 +1 @@ +include ':app' diff --git a/gradle/okhttp-asynctask/.gitignore b/gradle/okhttp-asynctask/.gitignore new file mode 100644 index 0000000000..ccf2efe026 --- /dev/null +++ b/gradle/okhttp-asynctask/.gitignore @@ -0,0 +1,27 @@ +# Built application files +*.apk +*.ap_ + +# Files for the Dalvik VM +*.dex + +# Java class files +*.class + +# Generated files +bin/ +gen/ + +# Gradle files +.gradle/ +build/ +/*/build/ + +# Local configuration file (sdk path, etc) +local.properties + +# Proguard folder generated by Eclipse +proguard/ + +# Log Files +*.log diff --git a/gradle/okhttp-asynctask/MyApplication.iml b/gradle/okhttp-asynctask/MyApplication.iml new file mode 100644 index 0000000000..0bb6048ae0 --- /dev/null +++ b/gradle/okhttp-asynctask/MyApplication.iml @@ -0,0 +1,19 @@ + + + + + + + + + + + + + + + + + + diff --git a/gradle/okhttp-asynctask/app/.gitignore b/gradle/okhttp-asynctask/app/.gitignore new file mode 100644 index 0000000000..796b96d1c4 --- /dev/null +++ b/gradle/okhttp-asynctask/app/.gitignore @@ -0,0 +1 @@ +/build diff --git a/gradle/okhttp-asynctask/app/app.iml b/gradle/okhttp-asynctask/app/app.iml new file mode 100644 index 0000000000..11f218e259 --- /dev/null +++ b/gradle/okhttp-asynctask/app/app.iml @@ -0,0 +1,98 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/gradle/okhttp-asynctask/app/build.gradle b/gradle/okhttp-asynctask/app/build.gradle new file mode 100644 index 0000000000..475b2fb948 --- /dev/null +++ b/gradle/okhttp-asynctask/app/build.gradle @@ -0,0 +1,43 @@ +apply plugin: 'com.android.application' +apply plugin: 'kotlin-android' + +android { + compileSdkVersion 22 + buildToolsVersion "22.0.1" + + defaultConfig { + applicationId "com.irontec.kotlintest" + minSdkVersion 16 + targetSdkVersion 22 + versionCode 1 + versionName "1.0" + } + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' + } + } + sourceSets { + main.java.srcDirs += 'src/main/kotlin' + } +} + +dependencies { + compile fileTree(dir: 'libs', include: ['*.jar']) + compile 'com.android.support:appcompat-v7:22.0.0' + compile 'com.squareup.okhttp:okhttp:2.3.0' + compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" +} +buildscript { + ext.kotlin_version = '0.11.91.2' + repositories { + mavenCentral() + } + dependencies { + classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" + } +} +repositories { + mavenCentral() +} diff --git a/gradle/okhttp-asynctask/app/proguard-rules.pro b/gradle/okhttp-asynctask/app/proguard-rules.pro new file mode 100644 index 0000000000..d6d8d1fbb0 --- /dev/null +++ b/gradle/okhttp-asynctask/app/proguard-rules.pro @@ -0,0 +1,17 @@ +# Add project specific ProGuard rules here. +# By default, the flags in this file are appended to flags specified +# in /Users/axier/Library/Android/sdk/tools/proguard/proguard-android.txt +# You can edit the include path and order by changing the proguardFiles +# directive in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# Add any project specific keep options here: + +# 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 *; +#} diff --git a/gradle/okhttp-asynctask/app/src/main/AndroidManifest.xml b/gradle/okhttp-asynctask/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000000..e609988df0 --- /dev/null +++ b/gradle/okhttp-asynctask/app/src/main/AndroidManifest.xml @@ -0,0 +1,23 @@ + + + + + + + + + + + + + + + + diff --git a/gradle/okhttp-asynctask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt b/gradle/okhttp-asynctask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt new file mode 100644 index 0000000000..92739aa0b9 --- /dev/null +++ b/gradle/okhttp-asynctask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt @@ -0,0 +1,73 @@ +package com.irontec.kotlintest + +import android.os.AsyncTask +import android.support.v7.app.ActionBarActivity +import android.os.Bundle +import android.util.Log +import android.view.Menu +import android.view.MenuItem +import android.widget.TextView +import com.irontec.kotlintest.networking.NetworkClient +import org.json.JSONObject +import java.io.BufferedInputStream +import java.io.BufferedReader +import java.io.InputStreamReader +import java.net.HttpURLConnection +import java.net.URL + + +public class MainActivity : ActionBarActivity() { + + open val mTextView: TextView + get() { + return findViewById(R.id.text) as TextView + } + + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + setContentView(R.layout.activity_main) + + GetJsonWithOkHttpClient(mTextView).execute() + + } + + open class GetJsonWithOkHttpClient(textView: TextView) : AsyncTask() { + + val mInnerTextView = textView + + override fun doInBackground(vararg params: Void?): String? { + val networkClient = NetworkClient() + val stream = BufferedInputStream( + networkClient.get("https://raw.githubusercontent.com/irontec/android-kotlin-samples/master/common-data/bilbao.json")) + return readStream(stream); + } + + override fun onPostExecute(result: String?) { + super.onPostExecute(result) + + mInnerTextView.setText(result) + + } + + fun readStream(inputStream: BufferedInputStream): String { + val bufferedReader = BufferedReader(InputStreamReader(inputStream)); + val stringBuilder = StringBuilder(); + bufferedReader.forEachLine { stringBuilder.append(it) } + return stringBuilder.toString() + } + } + + override fun onCreateOptionsMenu(menu: Menu): Boolean { + getMenuInflater().inflate(R.menu.menu_main, menu) + return true + } + + override fun onOptionsItemSelected(item: MenuItem): Boolean { + val id = item.getItemId() + if (id == R.id.action_settings) { + return true + } + return super.onOptionsItemSelected(item) + } +} diff --git a/gradle/okhttp-asynctask/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt b/gradle/okhttp-asynctask/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt new file mode 100644 index 0000000000..87830ead49 --- /dev/null +++ b/gradle/okhttp-asynctask/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt @@ -0,0 +1,21 @@ +package com.irontec.kotlintest.networking + +import com.squareup.okhttp.OkHttpClient +import com.squareup.okhttp.Request +import java.io.InputStream + +/** + * Created by axier on 23/4/15. + */ +open class NetworkClient { + + fun get(url: String): InputStream { + val request = Request.Builder().url(url).build() + val response = OkHttpClient().newCall(request).execute() + val body = response.body() + // body.toString() returns a string representing the object and not the body itself, probably + // kotlins fault when using third party libraries. Use byteStream() and convert it to a String + return body.byteStream() + } + +} \ No newline at end of file diff --git a/gradle/okhttp-asynctask/app/src/main/res/layout/activity_main.xml b/gradle/okhttp-asynctask/app/src/main/res/layout/activity_main.xml new file mode 100644 index 0000000000..addda73474 --- /dev/null +++ b/gradle/okhttp-asynctask/app/src/main/res/layout/activity_main.xml @@ -0,0 +1,10 @@ + + + + + diff --git a/gradle/okhttp-asynctask/app/src/main/res/menu/menu_main.xml b/gradle/okhttp-asynctask/app/src/main/res/menu/menu_main.xml new file mode 100644 index 0000000000..b1cb90811d --- /dev/null +++ b/gradle/okhttp-asynctask/app/src/main/res/menu/menu_main.xml @@ -0,0 +1,6 @@ + + + diff --git a/gradle/okhttp-asynctask/app/src/main/res/mipmap-hdpi/ic_launcher.png b/gradle/okhttp-asynctask/app/src/main/res/mipmap-hdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..cde69bcccec65160d92116f20ffce4fce0b5245c GIT binary patch literal 3418 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 literal 0 HcmV?d00001 diff --git a/gradle/okhttp-asynctask/app/src/main/res/mipmap-xhdpi/ic_launcher.png b/gradle/okhttp-asynctask/app/src/main/res/mipmap-xhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..bfa42f0e7b91d006d22352c9ff2f134e504e3c1d GIT binary patch literal 4842 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 literal 0 HcmV?d00001 diff --git a/gradle/okhttp-asynctask/app/src/main/res/mipmap-xxhdpi/ic_launcher.png b/gradle/okhttp-asynctask/app/src/main/res/mipmap-xxhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..324e72cdd7480cb983fa1bcc7ce686e51ef87fe7 GIT binary patch literal 7718 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 literal 0 HcmV?d00001 diff --git a/gradle/okhttp-asynctask/app/src/main/res/values-w820dp/dimens.xml b/gradle/okhttp-asynctask/app/src/main/res/values-w820dp/dimens.xml new file mode 100644 index 0000000000..63fc816444 --- /dev/null +++ b/gradle/okhttp-asynctask/app/src/main/res/values-w820dp/dimens.xml @@ -0,0 +1,6 @@ + + + 64dp + diff --git a/gradle/okhttp-asynctask/app/src/main/res/values/dimens.xml b/gradle/okhttp-asynctask/app/src/main/res/values/dimens.xml new file mode 100644 index 0000000000..47c8224673 --- /dev/null +++ b/gradle/okhttp-asynctask/app/src/main/res/values/dimens.xml @@ -0,0 +1,5 @@ + + + 16dp + 16dp + diff --git a/gradle/okhttp-asynctask/app/src/main/res/values/strings.xml b/gradle/okhttp-asynctask/app/src/main/res/values/strings.xml new file mode 100644 index 0000000000..7e8ae97852 --- /dev/null +++ b/gradle/okhttp-asynctask/app/src/main/res/values/strings.xml @@ -0,0 +1,6 @@ + + kotlintest + + Hello world! + Settings + diff --git a/gradle/okhttp-asynctask/app/src/main/res/values/styles.xml b/gradle/okhttp-asynctask/app/src/main/res/values/styles.xml new file mode 100644 index 0000000000..766ab99304 --- /dev/null +++ b/gradle/okhttp-asynctask/app/src/main/res/values/styles.xml @@ -0,0 +1,8 @@ + + + + + + diff --git a/gradle/okhttp-asynctask/build.gradle b/gradle/okhttp-asynctask/build.gradle new file mode 100644 index 0000000000..d3ff69d6e7 --- /dev/null +++ b/gradle/okhttp-asynctask/build.gradle @@ -0,0 +1,19 @@ +// Top-level build file where you can add configuration options common to all sub-projects/modules. + +buildscript { + repositories { + jcenter() + } + dependencies { + classpath 'com.android.tools.build:gradle:1.1.0' + + // NOTE: Do not place your application dependencies here; they belong + // in the individual module build.gradle files + } +} + +allprojects { + repositories { + jcenter() + } +} diff --git a/gradle/okhttp-asynctask/gradle.properties b/gradle/okhttp-asynctask/gradle.properties new file mode 100644 index 0000000000..1d3591c8a4 --- /dev/null +++ b/gradle/okhttp-asynctask/gradle.properties @@ -0,0 +1,18 @@ +# 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. +# Default value: -Xmx10248m -XX:MaxPermSize=256m +# org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8 + +# 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 \ No newline at end of file diff --git a/gradle/okhttp-asynctask/gradle/wrapper/gradle-wrapper.jar b/gradle/okhttp-asynctask/gradle/wrapper/gradle-wrapper.jar new file mode 100644 index 0000000000000000000000000000000000000000..8c0fb64a8698b08ecc4158d828ca593c4928e9dd GIT binary patch literal 49896 zcmagFb986H(k`5d^NVfUwr$(C?M#x1ZQHiZiEVpg+jrjgoQrerx!>1o_ul)D>ebz~ zs=Mmxr&>W81QY-S1PKWQ%N-;H^tS;2*XwVA`dej1RRn1z<;3VgfE4~kaG`A%QSPsR z#ovnZe+tS9%1MfeDyz`RirvdjPRK~p(#^q2(^5@O&NM19EHdvN-A&StN>0g6QA^VN z0Gx%Gq#PD$QMRFzmK+utjS^Y1F0e8&u&^=w5K<;4Rz|i3A=o|IKLY+g`iK6vfr9?+ z-`>gmU&i?FGSL5&F?TXFu`&Js6h;15QFkXp2M1H9|Eq~bpov-GU(uz%mH0n55wUl- zv#~ccAz`F5wlQ>e_KlJS3@{)B?^v*EQM=IxLa&76^y51a((wq|2-`qON>+4dLc{Oo z51}}o^Zen(oAjxDK7b++9_Yg`67p$bPo3~BCpGM7uAWmvIhWc5Gi+gQZ|Pwa-Gll@<1xmcPy z|NZmu6m)g5Ftu~BG&Xdxclw7Cij{xbBMBn-LMII#Slp`AElb&2^Hw+w>(3crLH!;I zN+Vk$D+wP1#^!MDCiad@vM>H#6+`Ct#~6VHL4lzmy;lSdk>`z6)=>Wh15Q2)dQtGqvn0vJU@+(B5{MUc*qs4!T+V=q=wy)<6$~ z!G>e_4dN@lGeF_$q9`Ju6Ncb*x?O7=l{anm7Eahuj_6lA{*#Gv*TaJclevPVbbVYu z(NY?5q+xxbO6%g1xF0r@Ix8fJ~u)VRUp`S%&rN$&e!Od`~s+64J z5*)*WSi*i{k%JjMSIN#X;jC{HG$-^iX+5f5BGOIHWAl*%15Z#!xntpk($-EGKCzKa zT7{siZ9;4TICsWQ$pu&wKZQTCvpI$Xvzwxoi+XkkpeE&&kFb!B?h2hi%^YlXt|-@5 zHJ~%AN!g_^tmn1?HSm^|gCE#!GRtK2(L{9pL#hp0xh zME}|DB>(5)`iE7CM)&_+S}-Bslc#@B5W4_+k4Cp$l>iVyg$KP>CN?SVGZ(&02>iZK zB<^HP$g$Lq*L$BWd?2(F?-MUbNWTJVQdW7$#8a|k_30#vHAD1Z{c#p;bETk0VnU5A zBgLe2HFJ3032$G<`m*OB!KM$*sdM20jm)It5OSru@tXpK5LT>#8)N!*skNu1$TpIw zufjjdp#lyH5bZ%|Iuo|iu9vG1HrIVWLH>278xo>aVBkPN3V$~!=KnlXQ4eDqS7%E% zQ!z^$Q$b^6Q)g#cLpwur(|<0gWHo6A6jc;n`t(V9T;LzTAU{IAu*uEQ%Ort1k+Kn+f_N`9|bxYC+~Z1 zCC1UCWv*Orx$_@ydv9mIe(liLfOr7mhbV@tKw{6)q^1DH1nmvZ0cj215R<~&I<4S| zgnr;9Cdjqpz#o8i0CQjtl`}{c*P)aSdH|abxGdrR)-3z+02-eX(k*B)Uqv6~^nh** z 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 \(.*\)$'` + if expr "$link" : '/.*' > /dev/null; then + PRG="$link" + else + PRG=`dirname "$PRG"`"/$link" + fi +done +SAVED="`pwd`" +cd "`dirname \"$PRG\"`/" >&- +APP_HOME="`pwd -P`" +cd "$SAVED" >&- + +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" ] ; 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"` + + # 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 + +# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules +function splitJvmOpts() { + JVM_OPTS=("$@") +} +eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS +JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME" + +exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@" diff --git a/gradle/okhttp-asynctask/gradlew.bat b/gradle/okhttp-asynctask/gradlew.bat new file mode 100644 index 0000000000..aec99730b4 --- /dev/null +++ b/gradle/okhttp-asynctask/gradlew.bat @@ -0,0 +1,90 @@ +@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 + +@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= + +set DIRNAME=%~dp0 +if "%DIRNAME%" == "" set DIRNAME=. +set APP_BASE_NAME=%~n0 +set APP_HOME=%DIRNAME% + +@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 Windowz variants + +if not "%OS%" == "Windows_NT" goto win9xME_args +if "%@eval[2+2]" == "4" goto 4NT_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=%* +goto execute + +:4NT_args +@rem Get arguments from the 4NT Shell from JP Software +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/gradle/okhttp-asynctask/settings.gradle b/gradle/okhttp-asynctask/settings.gradle new file mode 100644 index 0000000000..e7b4def49c --- /dev/null +++ b/gradle/okhttp-asynctask/settings.gradle @@ -0,0 +1 @@ +include ':app' From ec8749f92a8e860e2c2b960f520176f49a9aabfd Mon Sep 17 00:00:00 2001 From: Axier Fernandez Date: Tue, 20 Jun 2017 16:59:23 +0200 Subject: [PATCH 2/9] Camel case fixed, Void replaced by Unit, semicolons cleaned, libraries updated. --- .DS_Store | Bin 0 -> 6148 bytes gradle/.DS_Store | Bin 0 -> 8196 bytes gradle/anko-asynchronous-tasks/.DS_Store | Bin 0 -> 6148 bytes .../.idea/compiler.xml | 22 + .../.idea/copyright/profiles_settings.xml | 3 + .../anko-asynchronous-tasks/.idea/gradle.xml | 18 + .../animated_vector_drawable_25_3_1.xml | 12 + .../libraries/anko_appcompat_v7_0_9_1.xml | 11 + .../.idea/libraries/anko_common_0_9_1.xml | 11 + .../.idea/libraries/anko_sdk15_0_9_1.xml | 11 + .../.idea/libraries/anko_support_v4_0_9_1.xml | 11 + .../.idea/libraries/annotations_13_0.xml | 11 + .../.idea/libraries/appcompat_v7_25_3_1.xml | 12 + .../.idea/libraries/gson_2_7.xml | 11 + .../.idea/libraries/kotlin_stdlib_1_1_2.xml | 11 + .../.idea/libraries/okhttp_2_3_0.xml | 11 + .../.idea/libraries/okio_1_3_0.xml | 11 + .../libraries/support_annotations_25_3_1.xml | 11 + .../.idea/libraries/support_compat_25_3_1.xml | 12 + .../libraries/support_core_ui_25_3_1.xml | 12 + .../libraries/support_core_utils_25_3_1.xml | 12 + .../libraries/support_fragment_25_3_1.xml | 12 + .../libraries/support_media_compat_25_3_1.xml | 12 + .../.idea/libraries/support_v4_25_3_1.xml | 10 + .../support_vector_drawable_25_3_1.xml | 12 + gradle/anko-asynchronous-tasks/.idea/misc.xml | 62 + .../anko-asynchronous-tasks/.idea/modules.xml | 9 + .../.idea/runConfigurations.xml | 12 + .../.idea/workspace.xml | 2456 ++++++++++++++++ .../Anko_asynchronous_tasks.iml | 36 + .../anko-asynchronous-tasks.iml | 36 + gradle/anko-asynchronous-tasks/app/.DS_Store | Bin 0 -> 6148 bytes gradle/anko-asynchronous-tasks/app/app.iml | 99 +- .../anko-asynchronous-tasks/app/build.gradle | 29 +- .../anko-asynchronous-tasks/app/src/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/AndroidManifest.xml | 2 +- .../app/src/main/java/.DS_Store | Bin 0 -> 6148 bytes .../kotlintest/models/WeatherObject.kt | 24 - .../app/src/main/java/org/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/java/org/example/.DS_Store | Bin 0 -> 6148 bytes .../example/kotlin}/MainActivity.kt | 52 +- .../deserializers/WeatherDeserializer.kt | 22 +- .../example/kotlin/models/WeatherObject.kt | 30 + .../org/example/kotlin}/models/WindObject.kt | 8 +- .../kotlin}/networking/NetworkClient.kt | 2 +- gradle/anko-asynchronous-tasks/build.gradle | 9 +- .../gradle/wrapper/gradle-wrapper.properties | 4 +- gradle/anko-simple-ui/.DS_Store | Bin 0 -> 6148 bytes gradle/anko-simple-ui/.idea/compiler.xml | 22 + .../.idea/copyright/profiles_settings.xml | 3 + gradle/anko-simple-ui/.idea/gradle.xml | 18 + .../animated_vector_drawable_25_3_1.xml | 12 + .../libraries/anko_appcompat_v7_0_9_1.xml | 11 + .../.idea/libraries/anko_common_0_9_1.xml | 11 + .../.idea/libraries/anko_sdk15_0_9_1.xml | 11 + .../.idea/libraries/anko_support_v4_0_9_1.xml | 11 + .../.idea/libraries/annotations_13_0.xml | 11 + .../.idea/libraries/appcompat_v7_25_3_1.xml | 12 + .../.idea/libraries/gson_2_7.xml | 11 + .../.idea/libraries/kotlin_stdlib_1_1_2.xml | 11 + .../.idea/libraries/okhttp_2_3_0.xml | 11 + .../.idea/libraries/okio_1_3_0.xml | 11 + .../libraries/support_annotations_25_3_1.xml | 11 + .../.idea/libraries/support_compat_25_3_1.xml | 12 + .../libraries/support_core_ui_25_3_1.xml | 12 + .../libraries/support_core_utils_25_3_1.xml | 12 + .../libraries/support_fragment_25_3_1.xml | 12 + .../libraries/support_media_compat_25_3_1.xml | 12 + .../.idea/libraries/support_v4_25_3_1.xml | 10 + .../support_vector_drawable_25_3_1.xml | 12 + gradle/anko-simple-ui/.idea/misc.xml | 62 + gradle/anko-simple-ui/.idea/modules.xml | 9 + .../.idea/runConfigurations.xml | 12 + gradle/anko-simple-ui/.idea/workspace.xml | 2453 ++++++++++++++++ gradle/anko-simple-ui/Anko_simple_ui.iml | 36 + gradle/anko-simple-ui/anko-simple-ui.iml | 36 + gradle/anko-simple-ui/app/.DS_Store | Bin 0 -> 6148 bytes gradle/anko-simple-ui/app/app.iml | 99 +- gradle/anko-simple-ui/app/build.gradle | 29 +- gradle/anko-simple-ui/app/src/.DS_Store | Bin 0 -> 6148 bytes gradle/anko-simple-ui/app/src/main/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/AndroidManifest.xml | 2 +- .../app/src/main/java/.DS_Store | Bin 0 -> 6148 bytes .../kotlintest/models/WeatherObject.kt | 24 - .../app/src/main/java/org/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/java/org/example/.DS_Store | Bin 0 -> 6148 bytes .../example/kotlin}/MainActivity.kt | 58 +- .../deserializers/WeatherDeserializer.kt | 22 +- .../example/kotlin/models/WeatherObject.kt | 30 + .../org/example/kotlin}/models/WindObject.kt | 8 +- .../kotlin}/networking/NetworkClient.kt | 2 +- gradle/anko-simple-ui/build.gradle | 7 +- .../gradle/wrapper/gradle-wrapper.properties | 4 +- .../app/app.iml | 98 +- .../app/build.gradle | 23 +- .../app/src/main/AndroidManifest.xml | 2 +- .../kotlintest/models/WeatherObject.kt | 24 - .../build.gradle | 8 +- .../gradle/wrapper/gradle-wrapper.properties | 4 +- .../.DS_Store | Bin 0 -> 6148 bytes .../.idea/compiler.xml | 22 + .../.idea/copyright/profiles_settings.xml | 3 + .../.idea/gradle.xml | 18 + .../animated_vector_drawable_25_3_1.xml | 12 + .../.idea/libraries/annotations_13_0.xml | 11 + .../.idea/libraries/appcompat_v7_25_3_1.xml | 12 + .../.idea/libraries/gson_2_7.xml | 11 + .../.idea/libraries/kotlin_stdlib_1_1_2.xml | 11 + .../.idea/libraries/okhttp_2_3_0.xml | 11 + .../.idea/libraries/okio_1_3_0.xml | 11 + .../libraries/support_annotations_25_3_1.xml | 11 + .../.idea/libraries/support_compat_25_3_1.xml | 12 + .../libraries/support_core_ui_25_3_1.xml | 12 + .../libraries/support_core_utils_25_3_1.xml | 12 + .../libraries/support_fragment_25_3_1.xml | 12 + .../libraries/support_media_compat_25_3_1.xml | 12 + .../.idea/libraries/support_v4_25_3_1.xml | 10 + .../support_vector_drawable_25_3_1.xml | 12 + .../.idea/misc.xml | 62 + .../.idea/modules.xml | 9 + .../.idea/runConfigurations.xml | 12 + .../.idea/workspace.xml | 2495 +++++++++++++++++ .../Gson_deserializers_OkHttp_AsyncTask.iml | 36 + .../app/.DS_Store | Bin 0 -> 6148 bytes .../app/src/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/java/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/java/org/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/java/org/example/.DS_Store | Bin 0 -> 6148 bytes .../java/org/example/kotlin}/MainActivity.kt | 49 +- .../deserializers/WeatherDeserializer.kt | 22 +- .../example/kotlin/models/WeatherObject.kt | 28 + .../org/example/kotlin}/models/WindObject.kt | 8 +- .../kotlin}/networking/NetworkClient.kt | 2 +- .../gson-deserializers-okhttp-asynctask.iml | 36 + gradle/httpurlconnection-asynctask/.DS_Store | Bin 0 -> 6148 bytes .../.idea/compiler.xml | 22 + .../.idea/copyright/profiles_settings.xml | 3 + .../.idea/gradle.xml | 18 + .../animated_vector_drawable_25_3_1.xml | 12 + .../.idea/libraries/annotations_13_0.xml | 11 + .../.idea/libraries/appcompat_v7_25_3_1.xml | 12 + .../.idea/libraries/kotlin_stdlib_1_1_2.xml | 11 + .../libraries/support_annotations_25_3_1.xml | 11 + .../.idea/libraries/support_compat_25_3_1.xml | 12 + .../libraries/support_core_ui_25_3_1.xml | 12 + .../libraries/support_core_utils_25_3_1.xml | 12 + .../libraries/support_fragment_25_3_1.xml | 12 + .../libraries/support_media_compat_25_3_1.xml | 12 + .../.idea/libraries/support_v4_25_3_1.xml | 10 + .../support_vector_drawable_25_3_1.xml | 12 + .../.idea/misc.xml | 62 + .../.idea/modules.xml | 9 + .../.idea/runConfigurations.xml | 12 + .../.idea/workspace.xml | 2344 ++++++++++++++++ .../HttpUrlConnection_AsyncTask.iml | 36 + .../httpurlconnection-asynctask/app/.DS_Store | Bin 0 -> 6148 bytes .../httpurlconnection-asynctask/app/app.iml | 94 +- .../app/build.gradle | 21 +- .../app/src/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/AndroidManifest.xml | 2 +- .../app/src/main/java/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/java/org/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/java/org/example/.DS_Store | Bin 0 -> 6148 bytes .../example/kotlin}/MainActivity.kt | 42 +- .../httpurlconnection-asynctask/build.gradle | 8 +- .../gradle/wrapper/gradle-wrapper.properties | 4 +- .../httpurlconnection-asynctask.iml | 36 + .../.DS_Store | Bin 0 -> 6148 bytes .../.idea/compiler.xml | 22 + .../.idea/copyright/profiles_settings.xml | 3 + .../.idea/gradle.xml | 18 + .../animated_vector_drawable_25_3_1.xml | 12 + .../.idea/libraries/annotations_13_0.xml | 11 + .../.idea/libraries/appcompat_v7_25_3_1.xml | 12 + .../.idea/libraries/kotlin_stdlib_1_1_2.xml | 11 + .../libraries/support_annotations_25_3_1.xml | 11 + .../.idea/libraries/support_compat_25_3_1.xml | 12 + .../libraries/support_core_ui_25_3_1.xml | 12 + .../libraries/support_core_utils_25_3_1.xml | 12 + .../libraries/support_fragment_25_3_1.xml | 12 + .../libraries/support_media_compat_25_3_1.xml | 12 + .../.idea/libraries/support_v4_25_3_1.xml | 10 + .../support_vector_drawable_25_3_1.xml | 12 + .../.idea/misc.xml | 62 + .../.idea/modules.xml | 9 + .../.idea/runConfigurations.xml | 12 + .../.idea/workspace.xml | 2421 ++++++++++++++++ .../ListView_BaseAdapter_Data_Object.iml | 36 + .../app/.DS_Store | Bin 0 -> 6148 bytes .../app/app.iml | 95 +- .../app/build.gradle | 21 +- .../app/src/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/AndroidManifest.xml | 2 +- .../app/src/main/java/.DS_Store | Bin 0 -> 6148 bytes .../com/irontec/kotlintest/MainActivity.kt | 50 - .../app/src/main/java/org/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/java/org/example/.DS_Store | Bin 0 -> 6148 bytes .../java/org/example/kotlin/MainActivity.kt | 41 + .../kotlin}/adapters/CustomListAdapter.kt | 38 +- .../example/kotlin}/models/CustomPojo.kt | 2 +- .../build.gradle | 8 +- .../gradle/wrapper/gradle-wrapper.properties | 4 +- .../listview-baseadapter-data-object.iml | 36 + gradle/okhttp-asynctask/.DS_Store | Bin 0 -> 6148 bytes gradle/okhttp-asynctask/.idea/compiler.xml | 22 + .../.idea/copyright/profiles_settings.xml | 3 + gradle/okhttp-asynctask/.idea/gradle.xml | 18 + .../animated_vector_drawable_25_3_1.xml | 12 + .../.idea/libraries/annotations_13_0.xml | 11 + .../.idea/libraries/appcompat_v7_25_3_1.xml | 12 + .../.idea/libraries/kotlin_stdlib_1_1_2.xml | 11 + .../.idea/libraries/okhttp_2_3_0.xml | 11 + .../.idea/libraries/okio_1_3_0.xml | 11 + .../libraries/support_annotations_25_3_1.xml | 11 + .../.idea/libraries/support_compat_25_3_1.xml | 12 + .../libraries/support_core_ui_25_3_1.xml | 12 + .../libraries/support_core_utils_25_3_1.xml | 12 + .../libraries/support_fragment_25_3_1.xml | 12 + .../libraries/support_media_compat_25_3_1.xml | 12 + .../.idea/libraries/support_v4_25_3_1.xml | 10 + .../support_vector_drawable_25_3_1.xml | 12 + gradle/okhttp-asynctask/.idea/misc.xml | 62 + gradle/okhttp-asynctask/.idea/modules.xml | 9 + .../.idea/runConfigurations.xml | 12 + gradle/okhttp-asynctask/.idea/workspace.xml | 2398 ++++++++++++++++ gradle/okhttp-asynctask/OkHttp_AsyncTask.iml | 36 + gradle/okhttp-asynctask/app/.DS_Store | Bin 0 -> 6148 bytes gradle/okhttp-asynctask/app/app.iml | 97 +- gradle/okhttp-asynctask/app/build.gradle | 21 +- gradle/okhttp-asynctask/app/src/.DS_Store | Bin 0 -> 6148 bytes .../okhttp-asynctask/app/src/main/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/AndroidManifest.xml | 2 +- .../app/src/main/java/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/java/org/.DS_Store | Bin 0 -> 6148 bytes .../app/src/main/java/org/example/.DS_Store | Bin 0 -> 6148 bytes .../example/kotlin}/MainActivity.kt | 38 +- .../kotlin}/networking/NetworkClient.kt | 2 +- gradle/okhttp-asynctask/build.gradle | 8 +- .../gradle/wrapper/gradle-wrapper.properties | 4 +- gradle/okhttp-asynctask/okhttp-asynctask.iml | 36 + 244 files changed, 17591 insertions(+), 645 deletions(-) create mode 100644 .DS_Store create mode 100644 gradle/.DS_Store create mode 100644 gradle/anko-asynchronous-tasks/.DS_Store create mode 100644 gradle/anko-asynchronous-tasks/.idea/compiler.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/copyright/profiles_settings.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/gradle.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/animated_vector_drawable_25_3_1.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/anko_appcompat_v7_0_9_1.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/anko_common_0_9_1.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/anko_sdk15_0_9_1.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/anko_support_v4_0_9_1.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/annotations_13_0.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/appcompat_v7_25_3_1.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/gson_2_7.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/kotlin_stdlib_1_1_2.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/okhttp_2_3_0.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/okio_1_3_0.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/support_annotations_25_3_1.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/support_compat_25_3_1.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/support_core_ui_25_3_1.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/support_core_utils_25_3_1.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/support_fragment_25_3_1.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/support_media_compat_25_3_1.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/support_v4_25_3_1.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/support_vector_drawable_25_3_1.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/misc.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/modules.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/runConfigurations.xml create mode 100644 gradle/anko-asynchronous-tasks/.idea/workspace.xml create mode 100644 gradle/anko-asynchronous-tasks/Anko_asynchronous_tasks.iml create mode 100644 gradle/anko-asynchronous-tasks/anko-asynchronous-tasks.iml create mode 100644 gradle/anko-asynchronous-tasks/app/.DS_Store create mode 100644 gradle/anko-asynchronous-tasks/app/src/.DS_Store create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/.DS_Store create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/java/.DS_Store delete mode 100644 gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/java/org/.DS_Store create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/java/org/example/.DS_Store rename gradle/anko-asynchronous-tasks/app/src/main/java/{com/irontec/kotlintest => org/example/kotlin}/MainActivity.kt (59%) rename gradle/{anko-simple-ui/app/src/main/java/com/irontec/kotlintest => anko-asynchronous-tasks/app/src/main/java/org/example/kotlin}/deserializers/WeatherDeserializer.kt (52%) create mode 100644 gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/models/WeatherObject.kt rename gradle/{anko-simple-ui/app/src/main/java/com/irontec/kotlintest => anko-asynchronous-tasks/app/src/main/java/org/example/kotlin}/models/WindObject.kt (54%) rename gradle/anko-asynchronous-tasks/app/src/main/java/{com/irontec/kotlintest => org/example/kotlin}/networking/NetworkClient.kt (93%) create mode 100644 gradle/anko-simple-ui/.DS_Store create mode 100644 gradle/anko-simple-ui/.idea/compiler.xml create mode 100644 gradle/anko-simple-ui/.idea/copyright/profiles_settings.xml create mode 100644 gradle/anko-simple-ui/.idea/gradle.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/animated_vector_drawable_25_3_1.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/anko_appcompat_v7_0_9_1.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/anko_common_0_9_1.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/anko_sdk15_0_9_1.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/anko_support_v4_0_9_1.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/annotations_13_0.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/appcompat_v7_25_3_1.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/gson_2_7.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/kotlin_stdlib_1_1_2.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/okhttp_2_3_0.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/okio_1_3_0.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/support_annotations_25_3_1.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/support_compat_25_3_1.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/support_core_ui_25_3_1.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/support_core_utils_25_3_1.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/support_fragment_25_3_1.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/support_media_compat_25_3_1.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/support_v4_25_3_1.xml create mode 100644 gradle/anko-simple-ui/.idea/libraries/support_vector_drawable_25_3_1.xml create mode 100644 gradle/anko-simple-ui/.idea/misc.xml create mode 100644 gradle/anko-simple-ui/.idea/modules.xml create mode 100644 gradle/anko-simple-ui/.idea/runConfigurations.xml create mode 100644 gradle/anko-simple-ui/.idea/workspace.xml create mode 100644 gradle/anko-simple-ui/Anko_simple_ui.iml create mode 100644 gradle/anko-simple-ui/anko-simple-ui.iml create mode 100644 gradle/anko-simple-ui/app/.DS_Store create mode 100644 gradle/anko-simple-ui/app/src/.DS_Store create mode 100644 gradle/anko-simple-ui/app/src/main/.DS_Store create mode 100644 gradle/anko-simple-ui/app/src/main/java/.DS_Store delete mode 100644 gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt create mode 100644 gradle/anko-simple-ui/app/src/main/java/org/.DS_Store create mode 100644 gradle/anko-simple-ui/app/src/main/java/org/example/.DS_Store rename gradle/anko-simple-ui/app/src/main/java/{com/irontec/kotlintest => org/example/kotlin}/MainActivity.kt (54%) rename gradle/{anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest => anko-simple-ui/app/src/main/java/org/example/kotlin}/deserializers/WeatherDeserializer.kt (52%) create mode 100644 gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/models/WeatherObject.kt rename gradle/{gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest => anko-simple-ui/app/src/main/java/org/example/kotlin}/models/WindObject.kt (54%) rename gradle/{gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest => anko-simple-ui/app/src/main/java/org/example/kotlin}/networking/NetworkClient.kt (93%) delete mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.DS_Store create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/compiler.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/copyright/profiles_settings.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/gradle.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/annotations_13_0.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/gson_2_7.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/okhttp_2_3_0.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/okio_1_3_0.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_annotations_25_3_1.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_compat_25_3_1.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_core_ui_25_3_1.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_core_utils_25_3_1.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_fragment_25_3_1.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_media_compat_25_3_1.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_v4_25_3_1.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/misc.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/modules.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/runConfigurations.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/workspace.xml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/Gson_deserializers_OkHttp_AsyncTask.iml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/app/.DS_Store create mode 100644 gradle/gson-deserializers-okhttp-asynctask/app/src/.DS_Store create mode 100644 gradle/gson-deserializers-okhttp-asynctask/app/src/main/.DS_Store create mode 100644 gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/.DS_Store create mode 100644 gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/.DS_Store create mode 100644 gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/.DS_Store rename gradle/{gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest => gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin}/MainActivity.kt (55%) rename gradle/{gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest => gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin}/deserializers/WeatherDeserializer.kt (52%) create mode 100644 gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/models/WeatherObject.kt rename gradle/{anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest => gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin}/models/WindObject.kt (54%) rename gradle/{okhttp-asynctask/app/src/main/java/com/irontec/kotlintest => gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin}/networking/NetworkClient.kt (93%) create mode 100644 gradle/gson-deserializers-okhttp-asynctask/gson-deserializers-okhttp-asynctask.iml create mode 100644 gradle/httpurlconnection-asynctask/.DS_Store create mode 100644 gradle/httpurlconnection-asynctask/.idea/compiler.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/copyright/profiles_settings.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/gradle.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/annotations_13_0.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/support_annotations_25_3_1.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/support_compat_25_3_1.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/support_core_ui_25_3_1.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/support_core_utils_25_3_1.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/support_fragment_25_3_1.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/support_media_compat_25_3_1.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/support_v4_25_3_1.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/misc.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/modules.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/runConfigurations.xml create mode 100644 gradle/httpurlconnection-asynctask/.idea/workspace.xml create mode 100644 gradle/httpurlconnection-asynctask/HttpUrlConnection_AsyncTask.iml create mode 100644 gradle/httpurlconnection-asynctask/app/.DS_Store create mode 100644 gradle/httpurlconnection-asynctask/app/src/.DS_Store create mode 100644 gradle/httpurlconnection-asynctask/app/src/main/.DS_Store create mode 100644 gradle/httpurlconnection-asynctask/app/src/main/java/.DS_Store create mode 100644 gradle/httpurlconnection-asynctask/app/src/main/java/org/.DS_Store create mode 100644 gradle/httpurlconnection-asynctask/app/src/main/java/org/example/.DS_Store rename gradle/httpurlconnection-asynctask/app/src/main/java/{com/irontec/kotlintest => org/example/kotlin}/MainActivity.kt (66%) create mode 100644 gradle/httpurlconnection-asynctask/httpurlconnection-asynctask.iml create mode 100644 gradle/listview-baseadapter-data-object/.DS_Store create mode 100644 gradle/listview-baseadapter-data-object/.idea/compiler.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/copyright/profiles_settings.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/gradle.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/animated_vector_drawable_25_3_1.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/annotations_13_0.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/appcompat_v7_25_3_1.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/kotlin_stdlib_1_1_2.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/support_annotations_25_3_1.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/support_compat_25_3_1.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/support_core_ui_25_3_1.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/support_core_utils_25_3_1.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/support_fragment_25_3_1.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/support_media_compat_25_3_1.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/support_v4_25_3_1.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/support_vector_drawable_25_3_1.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/misc.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/modules.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/runConfigurations.xml create mode 100644 gradle/listview-baseadapter-data-object/.idea/workspace.xml create mode 100644 gradle/listview-baseadapter-data-object/ListView_BaseAdapter_Data_Object.iml create mode 100644 gradle/listview-baseadapter-data-object/app/.DS_Store create mode 100644 gradle/listview-baseadapter-data-object/app/src/.DS_Store create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/.DS_Store create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/java/.DS_Store delete mode 100644 gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/MainActivity.kt create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/java/org/.DS_Store create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/java/org/example/.DS_Store create mode 100644 gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/MainActivity.kt rename gradle/listview-baseadapter-data-object/app/src/main/java/{com/irontec/kotlintest => org/example/kotlin}/adapters/CustomListAdapter.kt (60%) rename gradle/listview-baseadapter-data-object/app/src/main/java/{com/irontec/kotlintest => org/example/kotlin}/models/CustomPojo.kt (84%) create mode 100644 gradle/listview-baseadapter-data-object/listview-baseadapter-data-object.iml create mode 100644 gradle/okhttp-asynctask/.DS_Store create mode 100644 gradle/okhttp-asynctask/.idea/compiler.xml create mode 100644 gradle/okhttp-asynctask/.idea/copyright/profiles_settings.xml create mode 100644 gradle/okhttp-asynctask/.idea/gradle.xml create mode 100644 gradle/okhttp-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml create mode 100644 gradle/okhttp-asynctask/.idea/libraries/annotations_13_0.xml create mode 100644 gradle/okhttp-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml create mode 100644 gradle/okhttp-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml create mode 100644 gradle/okhttp-asynctask/.idea/libraries/okhttp_2_3_0.xml create mode 100644 gradle/okhttp-asynctask/.idea/libraries/okio_1_3_0.xml create mode 100644 gradle/okhttp-asynctask/.idea/libraries/support_annotations_25_3_1.xml create mode 100644 gradle/okhttp-asynctask/.idea/libraries/support_compat_25_3_1.xml create mode 100644 gradle/okhttp-asynctask/.idea/libraries/support_core_ui_25_3_1.xml create mode 100644 gradle/okhttp-asynctask/.idea/libraries/support_core_utils_25_3_1.xml create mode 100644 gradle/okhttp-asynctask/.idea/libraries/support_fragment_25_3_1.xml create mode 100644 gradle/okhttp-asynctask/.idea/libraries/support_media_compat_25_3_1.xml create mode 100644 gradle/okhttp-asynctask/.idea/libraries/support_v4_25_3_1.xml create mode 100644 gradle/okhttp-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml create mode 100644 gradle/okhttp-asynctask/.idea/misc.xml create mode 100644 gradle/okhttp-asynctask/.idea/modules.xml create mode 100644 gradle/okhttp-asynctask/.idea/runConfigurations.xml create mode 100644 gradle/okhttp-asynctask/.idea/workspace.xml create mode 100644 gradle/okhttp-asynctask/OkHttp_AsyncTask.iml create mode 100644 gradle/okhttp-asynctask/app/.DS_Store create mode 100644 gradle/okhttp-asynctask/app/src/.DS_Store create mode 100644 gradle/okhttp-asynctask/app/src/main/.DS_Store create mode 100644 gradle/okhttp-asynctask/app/src/main/java/.DS_Store create mode 100644 gradle/okhttp-asynctask/app/src/main/java/org/.DS_Store create mode 100644 gradle/okhttp-asynctask/app/src/main/java/org/example/.DS_Store rename gradle/okhttp-asynctask/app/src/main/java/{com/irontec/kotlintest => org/example/kotlin}/MainActivity.kt (63%) rename gradle/{anko-simple-ui/app/src/main/java/com/irontec/kotlintest => okhttp-asynctask/app/src/main/java/org/example/kotlin}/networking/NetworkClient.kt (93%) create mode 100644 gradle/okhttp-asynctask/okhttp-asynctask.iml diff --git a/.DS_Store b/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..c4b0b78bafad3ae99477db03f66ee86e2d386528 GIT binary patch literal 6148 zcmeHK%}T>S5Z-O8CWx4WV2`mkLT>Olyx9=r(=J*c#a32h)IB}ok$BY6#dBcH(6 zarURhP`!yrnSt4FGCQ-I{Ze*1gb->?y)GddAw&UX*id2kM%X;l1!+i66Oi&XLgKr5 zI&s6;U5G}fi6(orFP}8O8@~G+QgHYl^BW>V|S_kK^3VoNSs} zPIAqk0?&7)eG$ju+;-f{z|RNT)=3;?P7wLYm++gbAoAkeil>p6@^#LgYz(=4qk+~g zitheVN8d9J%Z^_3dIs3L2W6=!+dJLkv*G>YQ}JBByb5M1{0O;hN}RzP7_~!s>0Ri; zYqEse#DkqgVH}OXKU-|J2qH3o3?Ku`!+^Zul=bB~5}pJZKn8w^0d_y=pbSlkl|X)V zz`$Doz!tcrHqP-lSkejpmF|EE9q|2zl>WB?ghP6lYJZ}%-Yo2;!1r)0HO2OWYk pVR4nfc?uZ36hka4#cfb7;MbV}XiBUEf(Hcu2yhy3KnDJlflsh;SPK9E literal 0 HcmV?d00001 diff --git a/gradle/.DS_Store b/gradle/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..53d86cb5da610e06bb78bf39acbb2662f8b7d3a5 GIT binary patch literal 8196 zcmeI1-EPw`6vvOZ0;%}w1=5DNv4ps5rEX(XTuiFUxZn<{2rd9^$r7z$nN#Is(bg5^ zIpB?W0bYl{KPV+-RKSLyvnBiQ*gj7E>yh2#5)td={u|weTy;`+aFNs73t86 zVh@&|ykQikS-bt2EiKosT)pPh>rVZq^R_>Ti+<*2dD?T6*Xk+s1JBf7#BnsKyWYz% zD0Uimp2Q+^LlGoX!{59Lg&!BaI2V4Z=6UXB1K6q;?KJL=M(Z2vohEx z@{LEEn@Asy0? zA__n*r*L7J{dCn8LicGOo+N#$MLx)+$O%Zf;1tq{dXk@*5DKy$8af`98kg+buff-{euD%9YQiAb13Z0Tu96PwkKaN*{TM zKIz}m*Im?I<=Gy+)8rS{i~pERg>>W6?gw*MULjRE(&j!c>k+Fm{(pM*{r}u~>;Ox^ z68L`!u-bNiyNA#J^~Z5_DKggP$h*ig$#JDtWr9M5<4_fjLnnV2qRuf?+H{SUTG4{^ Y*DnI>`H$G_0;4E<{-0ModZFk47mEwBMgRZ+ literal 0 HcmV?d00001 diff --git a/gradle/anko-asynchronous-tasks/.DS_Store b/gradle/anko-asynchronous-tasks/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..aaceada73d98280034e3a8241daba9e46ffc63e5 GIT binary patch literal 6148 zcmeHK-EPw`6h2l-k?mz z_6f>&D4O*k)oTyqD070y@8#5AJ`W-<9<<_q-WU$IwznEJ`)++_RI`VT zM!jZl-@i8+S=Rck%?AgEr)O`5Z%6MwGI=;qaiU6D)%X)Wp`clK-R?zU937*EwHL|7 zS_Kr6H^I+)wC305@^4M7<}p^XG36a%8X-`;Ow zO8Rb{njGJ?Hqs#y3+s&)N)u%II+g{#imxL{L7UA5U{m8*A!;DzM?lhGGQ+?>W#9*R C)(Ce1 literal 0 HcmV?d00001 diff --git a/gradle/anko-asynchronous-tasks/.idea/compiler.xml b/gradle/anko-asynchronous-tasks/.idea/compiler.xml new file mode 100644 index 0000000000..96cc43efa6 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/compiler.xml @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/copyright/profiles_settings.xml b/gradle/anko-asynchronous-tasks/.idea/copyright/profiles_settings.xml new file mode 100644 index 0000000000..e7bedf3377 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/copyright/profiles_settings.xml @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/gradle.xml b/gradle/anko-asynchronous-tasks/.idea/gradle.xml new file mode 100644 index 0000000000..7ac24c777f --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/gradle.xml @@ -0,0 +1,18 @@ + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/animated_vector_drawable_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/animated_vector_drawable_25_3_1.xml new file mode 100644 index 0000000000..986b1cda5a --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/animated_vector_drawable_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/anko_appcompat_v7_0_9_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/anko_appcompat_v7_0_9_1.xml new file mode 100644 index 0000000000..8563a7f435 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/anko_appcompat_v7_0_9_1.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/anko_common_0_9_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/anko_common_0_9_1.xml new file mode 100644 index 0000000000..89174fc128 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/anko_common_0_9_1.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/anko_sdk15_0_9_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/anko_sdk15_0_9_1.xml new file mode 100644 index 0000000000..044ee0ce95 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/anko_sdk15_0_9_1.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/anko_support_v4_0_9_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/anko_support_v4_0_9_1.xml new file mode 100644 index 0000000000..ec9c330215 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/anko_support_v4_0_9_1.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/annotations_13_0.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/annotations_13_0.xml new file mode 100644 index 0000000000..24c0dcb114 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/annotations_13_0.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/appcompat_v7_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/appcompat_v7_25_3_1.xml new file mode 100644 index 0000000000..9e612993e4 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/appcompat_v7_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/gson_2_7.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/gson_2_7.xml new file mode 100644 index 0000000000..22607550e1 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/gson_2_7.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/kotlin_stdlib_1_1_2.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/kotlin_stdlib_1_1_2.xml new file mode 100644 index 0000000000..c0993f57d5 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/kotlin_stdlib_1_1_2.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/okhttp_2_3_0.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/okhttp_2_3_0.xml new file mode 100644 index 0000000000..e0ed48aea3 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/okhttp_2_3_0.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/okio_1_3_0.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/okio_1_3_0.xml new file mode 100644 index 0000000000..93a99cb20a --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/okio_1_3_0.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/support_annotations_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/support_annotations_25_3_1.xml new file mode 100644 index 0000000000..42adfc6edf --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/support_annotations_25_3_1.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/support_compat_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/support_compat_25_3_1.xml new file mode 100644 index 0000000000..1dff866919 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/support_compat_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/support_core_ui_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/support_core_ui_25_3_1.xml new file mode 100644 index 0000000000..c0bd9753a2 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/support_core_ui_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/support_core_utils_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/support_core_utils_25_3_1.xml new file mode 100644 index 0000000000..406ceb21a7 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/support_core_utils_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/support_fragment_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/support_fragment_25_3_1.xml new file mode 100644 index 0000000000..a356b6caab --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/support_fragment_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/support_media_compat_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/support_media_compat_25_3_1.xml new file mode 100644 index 0000000000..543c69e48e --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/support_media_compat_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/support_v4_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/support_v4_25_3_1.xml new file mode 100644 index 0000000000..8eab02bac5 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/support_v4_25_3_1.xml @@ -0,0 +1,10 @@ + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/support_vector_drawable_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/support_vector_drawable_25_3_1.xml new file mode 100644 index 0000000000..91427afa49 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/libraries/support_vector_drawable_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/misc.xml b/gradle/anko-asynchronous-tasks/.idea/misc.xml new file mode 100644 index 0000000000..5403283c7d --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/misc.xml @@ -0,0 +1,62 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Android API 25 Platform + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/modules.xml b/gradle/anko-asynchronous-tasks/.idea/modules.xml new file mode 100644 index 0000000000..57f5055c7e --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/modules.xml @@ -0,0 +1,9 @@ + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/runConfigurations.xml b/gradle/anko-asynchronous-tasks/.idea/runConfigurations.xml new file mode 100644 index 0000000000..7f68460d8b --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/runConfigurations.xml @@ -0,0 +1,12 @@ + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/workspace.xml b/gradle/anko-asynchronous-tasks/.idea/workspace.xml new file mode 100644 index 0000000000..f3e52772f1 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/.idea/workspace.xml @@ -0,0 +1,2456 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 1497970037697 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/Anko_asynchronous_tasks.iml b/gradle/anko-asynchronous-tasks/Anko_asynchronous_tasks.iml new file mode 100644 index 0000000000..d476d69463 --- /dev/null +++ b/gradle/anko-asynchronous-tasks/Anko_asynchronous_tasks.iml @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/anko-asynchronous-tasks.iml b/gradle/anko-asynchronous-tasks/anko-asynchronous-tasks.iml new file mode 100644 index 0000000000..b18040896f --- /dev/null +++ b/gradle/anko-asynchronous-tasks/anko-asynchronous-tasks.iml @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/app/.DS_Store b/gradle/anko-asynchronous-tasks/app/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..3b2e0efa7305c6e7705b833574ad18c738884030 GIT binary patch literal 6148 zcmeHK-A)rh82zR#b{jD^h6KHv8xt>zDIhe2m~1LsaA#5@7eHW_ZD5mSr`aDHtTlV% zOXw5$D!u>@;sfZJpH{jBE{&1-nwc~E%{eojv+d3f5wUI_tP(Ye$U%`g3S?pOK< z)!rJn_^8uqxA^+z#(3;F%g + + + + + + + + + - + - + + - + + - + - + + + + + + + + - + - - - + + + + + + + + + - - - - - - - - + - - - + - + - - - - - + + - - - + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/app/build.gradle b/gradle/anko-asynchronous-tasks/app/build.gradle index 222efc6577..f3eb37bbaf 100644 --- a/gradle/anko-asynchronous-tasks/app/build.gradle +++ b/gradle/anko-asynchronous-tasks/app/build.gradle @@ -2,13 +2,13 @@ apply plugin: 'com.android.application' apply plugin: 'kotlin-android' android { - compileSdkVersion 22 - buildToolsVersion "22.0.1" + compileSdkVersion 25 + buildToolsVersion "25.0.3" defaultConfig { - applicationId "com.irontec.kotlintest" + applicationId "org.example.kotlin" minSdkVersion 16 - targetSdkVersion 22 + targetSdkVersion 25 versionCode 1 versionName "1.0" } @@ -25,22 +25,17 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:22.1.0' - compile 'com.google.code.gson:gson:2.3.1' + compile 'com.android.support:appcompat-v7:25.3.1' + compile 'com.google.code.gson:gson:2.7' compile 'com.squareup.okhttp:okhttp:2.3.0' + // Kotlin compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" - compile "org.jetbrains.anko:anko:$anko_version" -} -buildscript { - ext.kotlin_version = '0.11.91.2' - ext.anko_version = '0.6-15' - repositories { - mavenCentral() - } - dependencies { - classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" - } + // Anko + compile "org.jetbrains.anko:anko-sdk15:$anko_version" + compile "org.jetbrains.anko:anko-support-v4:$anko_version" + compile "org.jetbrains.anko:anko-appcompat-v7:$anko_version" } + repositories { mavenCentral() } diff --git a/gradle/anko-asynchronous-tasks/app/src/.DS_Store b/gradle/anko-asynchronous-tasks/app/src/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..7fc4e7c0d22ff93a67d2257c8abe2ad3793efb82 GIT binary patch literal 6148 zcmeHK%}T>S5Z-O8CWzRBpx$y3JoJ#ZY7r4at%u%(iXK#IVu}r<+0vv2jgdTuzL78B zFDWkQGs%CVrs@P+Vsu2WJ_o+2RSYqWiK z<@n5jXTBiH-)DgDU5N~cO*|5O+P^)R+k6!w3d!S~I2@{des+ew7e=P}LJP&x-28&3 z>zcl#U3B^^?nHJp4x9GqOgwpR&r$Xa|f<@F?~)oYE4v1RV26(eah%!*Op*-leUTivMcw=V~`cgcPF@F+Kf z!j~#!S>Xhpz{o4S>5KxO1=rx4#82W7kpW}?8JK+r)XAnT&VDIa0WyFL{4fLjd@w*c zS_(6X;^=@uv;cr5a0>xj{Q3hL+yQ7Q%p`&bgvwMvnMzfQK~?8KWjf4TDn64a(+L%C zhIQ1Nsp?RuYCNbR!U?q`;)o0&10NaSy&p)K-~Wf-_x~aY2V?*l_@4~WQmfNyLT&19 zovM=GwFc-VC>I`=Nz7Bg5LYq8@~e0aR0#MDZU9;eGl}2$?4HnDoL59$8b8074yi*K<@A!y=$Ml2L>+{Q3X!2d zmo?~%A4XsiRp=|u{gi^=;=bP(7xuFgH{VTolEhiwXxxfYxia%;)~i;%>YTURK2rU5 z9^}2O6?8wFUL18oXMa#C8QDSjG4AyDYEL&*ng?;(>5hf(e2UXZ^;@c!MwyxCeUKj^ z*DSPGTO16QSC*S~x!QO$tjj^O*{I8v*RO^{&s%uDw7$K6e10*w99~_Uy^_H9Ze-r! zFZc#y#KdX4nY805kBw47fYYd;Gxb@bt_8Gw|;* zpzj9>)#y7cESjqWjd=n9D{vcut$z-6j&$fdEG%LKB5W$qrV97O5H=lt>Ee8cg+-fA z!aY8OTUodliZH8Verdu<_!hZk2AF|K2FkWu)AfJr{`dc668D$^X5hbKKvXu{n=Nd~ z)z+!a=~^qH`%o=9uCO>tfniE9Vs$Bg1~me|)CSOZSXhJy!ao9r25y*vKgz&Q({Xl- literal 0 HcmV?d00001 diff --git a/gradle/anko-asynchronous-tasks/app/src/main/AndroidManifest.xml b/gradle/anko-asynchronous-tasks/app/src/main/AndroidManifest.xml index e609988df0..7eac755c74 100644 --- a/gradle/anko-asynchronous-tasks/app/src/main/AndroidManifest.xml +++ b/gradle/anko-asynchronous-tasks/app/src/main/AndroidManifest.xml @@ -1,6 +1,6 @@ + package="org.example.kotlin" > diff --git a/gradle/anko-asynchronous-tasks/app/src/main/java/.DS_Store b/gradle/anko-asynchronous-tasks/app/src/main/java/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..9bf1062c9bdabc1cf291973ce54e9ee5e3be108a GIT binary patch literal 6148 zcmeHK%}T>S5Z-O8CWx4Wpx$y3JoL~XwTK9z)`%PwNHq5tSH^Ug?)nU8Hn8g?~KqY2O7`_oXFLh2b=*a?dxrVs) z0^z}vT#n>FFd+9X%LE&+ZatXUzayC0{ZOI`!6+|@`nbz)UO(`oxKMcKnQU%pdBreI z!(20N8aINmwwn5NmUHP zcBIxhbK@T5suwk_?a`=IE>-gOUg2<@w?~yqA#axt_Qzwx*xV@|*IRcFkE5sY^NZdJ z4qvH~b;Jq0f`RqjHwIxK!Y+6w(UT}bVt^PR1{Q?@Jl~AfMJb5tAO?tmUt>U?4>qVo z2Qk&Cjt&@93jmk{w-T_`&p)6o9e@sEsu4UOT&Du+RE{kM$KHYKbeMNAKGmqx8CP$H zb@0s`I~0zs2e(x?KTLwN~~y^o@K0 zA4eyXRMhHGQJI0sH#?b0HeZ%x2LMF1+bjbV0Kh@jn8{=FiRgZ<|D zCsL<=G!o5@-^hU8yBq{?1s+_$oBdNh_UO-I19kD41g(*1zt?H`5k)`xttjjyrP7ng zjAh3sa!x+)YbLZsZ z`lf$7xVxv7fWWVoWZL2o9?h@|Mu7QKLv5a3@`)#lL3*f z)oWE;o4s2{R;lk=iF$&nMaQKEUsKSas~BVTRXm4Ef_|wDMAu?!5IrdTBS188!wmc= F11~soUt|CP literal 0 HcmV?d00001 diff --git a/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/.DS_Store b/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..49dad4bec286fdd25284bcd6eed692077da5bcef GIT binary patch literal 6148 zcmeHK%}T>S5T0$Trij>spx*W(c<7<^uZRet)z7vPIk^Yt6iyXE%xG0yX>`2=qYG4eQO^o6%K9BKMI=NdTwD)MX?t|&DN*z)8im& zsBT$xqDGtgIq>2u%%y?qx#eDOZGEkjmm7uceqQ!Ur9xh=Z*BJbj4T>.onCreate(savedInstanceState) + super.onCreate(savedInstanceState) verticalLayout { padding = dip(5) val mTextView = textView { - textSize = 12f - }.layoutParams(width = matchParent, height = dip(300)) + textSize = 16f + width = matchParent + height = dip(300) + } button("Retrieve Weather") { textSize = 14f + width = matchParent + height = wrapContent onClick { // Declare a background asynchronous task, no need for an AsyncTask anymore - async { + doAsync { // Heavy duty work made on the background val networkClient = NetworkClient() val stream = BufferedInputStream( networkClient.get("https://raw.githubusercontent.com/irontec/android-kotlin-samples/master/common-data/bilbao.json")) val bufferedReader = BufferedReader(InputStreamReader(stream)); - val stringBuilder = StringBuilder(); + val stringBuilder = StringBuilder() bufferedReader.forEachLine { stringBuilder.append(it) } - val gsonBuilder = GsonBuilder().serializeNulls(); - gsonBuilder.registerTypeAdapter(javaClass(), WeatherDeserializer()); - val gson = gsonBuilder.create(); - val weather = gson.fromJson(stringBuilder.toString(), javaClass()) as WeatherObject + val gsonBuilder = GsonBuilder().serializeNulls() + gsonBuilder.registerTypeAdapter(WeatherObject::class.java, WeatherDeserializer()); + val gson = gsonBuilder.create() + val weather = gson.fromJson(stringBuilder.toString(), WeatherObject::class.java) uiThread { // Just set the TextView text on the UI-Thread - mTextView.setText(weather.toString()) + mTextView.text = weather.toString() } } } - }.layoutParams(width = matchParent, height = wrapContent) + } } } override fun onCreateOptionsMenu(menu: Menu): Boolean { - getMenuInflater().inflate(R.menu.menu_main, menu) + menuInflater.inflate(R.menu.menu_main, menu) return true } override fun onOptionsItemSelected(item: MenuItem): Boolean { - val id = item.getItemId() + val id = item.itemId if (id == R.id.action_settings) { return true } diff --git a/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt b/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/deserializers/WeatherDeserializer.kt similarity index 52% rename from gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt rename to gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/deserializers/WeatherDeserializer.kt index c8e2caaa5e..f327bdd45c 100644 --- a/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt +++ b/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/deserializers/WeatherDeserializer.kt @@ -1,11 +1,11 @@ -package com.irontec.kotlintest.deserializers +package org.example.kotlin.deserializers import com.google.gson.JsonDeserializationContext import com.google.gson.JsonDeserializer import com.google.gson.JsonElement import com.google.gson.JsonObject -import com.irontec.kotlintest.models.WeatherObject -import com.irontec.kotlintest.models.WindObject +import org.example.kotlin.models.WeatherObject +import org.example.kotlin.models.WindObject import java.lang.reflect.Type /** @@ -23,14 +23,14 @@ open class WeatherDeserializer : JsonDeserializer { val jsonMainObj = jsonObj.getAsJsonObject("main") val jsonWindObj = jsonObj.getAsJsonObject("wind") - wheather.main = jsonWeatherArray.getAsJsonObject().get("main").getAsString() - wheather.description = jsonWeatherArray.getAsJsonObject().get("description").getAsString() - wheather.temp = jsonMainObj.get("temp").getAsFloat() - wheather.temp_Max = jsonMainObj.get("temp_max").getAsFloat() - wheather.temp_Min = jsonMainObj.get("temp_min").getAsFloat() - wheather.humidity = jsonMainObj.get("humidity").getAsInt() - wind.speed = jsonWindObj.get("speed").getAsFloat() - wind.deg = jsonWindObj.get("deg").getAsFloat() + wheather.main = jsonWeatherArray.asJsonObject.get("main").asString + wheather.description = jsonWeatherArray.asJsonObject.get("description").asString + wheather.temp = jsonMainObj.get("temp").asFloat + wheather.tempMax = jsonMainObj.get("temp_max").asFloat + wheather.tempMin = jsonMainObj.get("temp_min").asFloat + wheather.humidity = jsonMainObj.get("humidity").asInt + wind.speed = jsonWindObj.get("speed").asFloat + wind.deg = jsonWindObj.get("deg").asFloat wheather.wind = wind return wheather diff --git a/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/models/WeatherObject.kt b/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/models/WeatherObject.kt new file mode 100644 index 0000000000..7abc7a94ce --- /dev/null +++ b/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/models/WeatherObject.kt @@ -0,0 +1,30 @@ +package org.example.kotlin.models + + +/** + * Created by axier on 24/4/15. + */ +class WeatherObject { + + var main: String = "" + var description: String = "" + var temp: Float = 0.0f + var tempMax: Float = 0.0f + var tempMin: Float = 0.0f + var humidity: Int = 0 + var wind: WindObject? = null + + init { + println(this.toString()) + } + + override fun toString() = + "Main ${main}\n" + + "description ${description}\n" + + "temp ${temp}\n" + + "temp_Max ${tempMax}\n" + + "temp_Min ${tempMin}\n" + + "humidity ${humidity}\n" + + "wind ${wind.toString()}" + +} \ No newline at end of file diff --git a/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt b/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/models/WindObject.kt similarity index 54% rename from gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt rename to gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/models/WindObject.kt index 5ab3506947..7daf2248b2 100644 --- a/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt +++ b/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/models/WindObject.kt @@ -1,12 +1,12 @@ -package com.irontec.kotlintest.models +package org.example.kotlin.models /** * Created by axier on 24/4/15. */ -public class WindObject { +class WindObject { - public var speed: Float = 0.0f - public var deg: Float = 0.0f + var speed: Float = 0.0f + var deg: Float = 0.0f init { println(this.toString()) diff --git a/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt b/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt similarity index 93% rename from gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt rename to gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt index 87830ead49..469d8df3d9 100644 --- a/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt +++ b/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt @@ -1,4 +1,4 @@ -package com.irontec.kotlintest.networking +package org.example.kotlin.networking import com.squareup.okhttp.OkHttpClient import com.squareup.okhttp.Request diff --git a/gradle/anko-asynchronous-tasks/build.gradle b/gradle/anko-asynchronous-tasks/build.gradle index d3ff69d6e7..c889cdb581 100644 --- a/gradle/anko-asynchronous-tasks/build.gradle +++ b/gradle/anko-asynchronous-tasks/build.gradle @@ -1,12 +1,17 @@ // Top-level build file where you can add configuration options common to all sub-projects/modules. buildscript { + + ext.kotlin_version = '1.1.2' + ext.anko_version = '0.9.1' + repositories { jcenter() } - dependencies { - classpath 'com.android.tools.build:gradle:1.1.0' + dependencies { + classpath 'com.android.tools.build:gradle:2.3.3' + classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files } diff --git a/gradle/anko-asynchronous-tasks/gradle/wrapper/gradle-wrapper.properties b/gradle/anko-asynchronous-tasks/gradle/wrapper/gradle-wrapper.properties index 0c71e760dc..4ebdf1a85c 100644 --- a/gradle/anko-asynchronous-tasks/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/anko-asynchronous-tasks/gradle/wrapper/gradle-wrapper.properties @@ -1,6 +1,6 @@ -#Wed Apr 10 15:27:10 PDT 2013 +#Wed Jun 14 17:38:46 CEST 2017 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-2.2.1-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip diff --git a/gradle/anko-simple-ui/.DS_Store b/gradle/anko-simple-ui/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..0c3f7cff22f10f287f4a9ed663bc7e9a50fc326c GIT binary patch literal 6148 zcmeHK-EPw`6h28b?{)Y+)kM;~!IndDxSgndK( z`O_!~(bi|0R_#%%Wgl3WwMVN)?OrEF&R@Z#m`%`nlo|srzYlZ zpZZ`mz`WRI{WyMUGR&|V8(jGM9-|3@ZMojxPdPv7u*I1MA5GhYQI*FA&e^-Df;TSxv zVlRYXgsl>cA%oqCGr}B|tkIoQ6}<|bl~avkom&Ph1OFled_K5HjBSmR0@cxhOg#aB zRa7fMnST%1#?{!?I4KY<5K)){3sa$=7@{yoy{q-w8Ycx7<|OpvL+HptzfgpV4*#xF zC($m@=9U4=K$(F`@mc5l|G~-c|FV(&vJ6-T{woGVb-TOW!I1RbIx{%FYh9#WBo@}2 o6sSy)>FZb(_$t1Hqy%j)7l3VzlLAo#u|EQe2Af$1{wM?A06Z@Mm;e9( literal 0 HcmV?d00001 diff --git a/gradle/anko-simple-ui/.idea/compiler.xml b/gradle/anko-simple-ui/.idea/compiler.xml new file mode 100644 index 0000000000..96cc43efa6 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/compiler.xml @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/copyright/profiles_settings.xml b/gradle/anko-simple-ui/.idea/copyright/profiles_settings.xml new file mode 100644 index 0000000000..e7bedf3377 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/copyright/profiles_settings.xml @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/gradle.xml b/gradle/anko-simple-ui/.idea/gradle.xml new file mode 100644 index 0000000000..7ac24c777f --- /dev/null +++ b/gradle/anko-simple-ui/.idea/gradle.xml @@ -0,0 +1,18 @@ + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/animated_vector_drawable_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/animated_vector_drawable_25_3_1.xml new file mode 100644 index 0000000000..986b1cda5a --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/animated_vector_drawable_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/anko_appcompat_v7_0_9_1.xml b/gradle/anko-simple-ui/.idea/libraries/anko_appcompat_v7_0_9_1.xml new file mode 100644 index 0000000000..8563a7f435 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/anko_appcompat_v7_0_9_1.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/anko_common_0_9_1.xml b/gradle/anko-simple-ui/.idea/libraries/anko_common_0_9_1.xml new file mode 100644 index 0000000000..89174fc128 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/anko_common_0_9_1.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/anko_sdk15_0_9_1.xml b/gradle/anko-simple-ui/.idea/libraries/anko_sdk15_0_9_1.xml new file mode 100644 index 0000000000..044ee0ce95 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/anko_sdk15_0_9_1.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/anko_support_v4_0_9_1.xml b/gradle/anko-simple-ui/.idea/libraries/anko_support_v4_0_9_1.xml new file mode 100644 index 0000000000..ec9c330215 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/anko_support_v4_0_9_1.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/annotations_13_0.xml b/gradle/anko-simple-ui/.idea/libraries/annotations_13_0.xml new file mode 100644 index 0000000000..24c0dcb114 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/annotations_13_0.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/appcompat_v7_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/appcompat_v7_25_3_1.xml new file mode 100644 index 0000000000..9e612993e4 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/appcompat_v7_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/gson_2_7.xml b/gradle/anko-simple-ui/.idea/libraries/gson_2_7.xml new file mode 100644 index 0000000000..22607550e1 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/gson_2_7.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/kotlin_stdlib_1_1_2.xml b/gradle/anko-simple-ui/.idea/libraries/kotlin_stdlib_1_1_2.xml new file mode 100644 index 0000000000..c0993f57d5 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/kotlin_stdlib_1_1_2.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/okhttp_2_3_0.xml b/gradle/anko-simple-ui/.idea/libraries/okhttp_2_3_0.xml new file mode 100644 index 0000000000..e0ed48aea3 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/okhttp_2_3_0.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/okio_1_3_0.xml b/gradle/anko-simple-ui/.idea/libraries/okio_1_3_0.xml new file mode 100644 index 0000000000..93a99cb20a --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/okio_1_3_0.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/support_annotations_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/support_annotations_25_3_1.xml new file mode 100644 index 0000000000..42adfc6edf --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/support_annotations_25_3_1.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/support_compat_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/support_compat_25_3_1.xml new file mode 100644 index 0000000000..1dff866919 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/support_compat_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/support_core_ui_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/support_core_ui_25_3_1.xml new file mode 100644 index 0000000000..c0bd9753a2 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/support_core_ui_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/support_core_utils_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/support_core_utils_25_3_1.xml new file mode 100644 index 0000000000..406ceb21a7 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/support_core_utils_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/support_fragment_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/support_fragment_25_3_1.xml new file mode 100644 index 0000000000..a356b6caab --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/support_fragment_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/support_media_compat_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/support_media_compat_25_3_1.xml new file mode 100644 index 0000000000..543c69e48e --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/support_media_compat_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/support_v4_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/support_v4_25_3_1.xml new file mode 100644 index 0000000000..8eab02bac5 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/support_v4_25_3_1.xml @@ -0,0 +1,10 @@ + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/support_vector_drawable_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/support_vector_drawable_25_3_1.xml new file mode 100644 index 0000000000..91427afa49 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/libraries/support_vector_drawable_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/misc.xml b/gradle/anko-simple-ui/.idea/misc.xml new file mode 100644 index 0000000000..5403283c7d --- /dev/null +++ b/gradle/anko-simple-ui/.idea/misc.xml @@ -0,0 +1,62 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Android API 25 Platform + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/modules.xml b/gradle/anko-simple-ui/.idea/modules.xml new file mode 100644 index 0000000000..8ae538b952 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/modules.xml @@ -0,0 +1,9 @@ + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/runConfigurations.xml b/gradle/anko-simple-ui/.idea/runConfigurations.xml new file mode 100644 index 0000000000..7f68460d8b --- /dev/null +++ b/gradle/anko-simple-ui/.idea/runConfigurations.xml @@ -0,0 +1,12 @@ + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/workspace.xml b/gradle/anko-simple-ui/.idea/workspace.xml new file mode 100644 index 0000000000..18095bcee5 --- /dev/null +++ b/gradle/anko-simple-ui/.idea/workspace.xml @@ -0,0 +1,2453 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 1497970301576 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/Anko_simple_ui.iml b/gradle/anko-simple-ui/Anko_simple_ui.iml new file mode 100644 index 0000000000..c38d04ae80 --- /dev/null +++ b/gradle/anko-simple-ui/Anko_simple_ui.iml @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/anko-simple-ui.iml b/gradle/anko-simple-ui/anko-simple-ui.iml new file mode 100644 index 0000000000..b08184cf5c --- /dev/null +++ b/gradle/anko-simple-ui/anko-simple-ui.iml @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/app/.DS_Store b/gradle/anko-simple-ui/app/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..3b2e0efa7305c6e7705b833574ad18c738884030 GIT binary patch literal 6148 zcmeHK-A)rh82zR#b{jD^h6KHv8xt>zDIhe2m~1LsaA#5@7eHW_ZD5mSr`aDHtTlV% zOXw5$D!u>@;sfZJpH{jBE{&1-nwc~E%{eojv+d3f5wUI_tP(Ye$U%`g3S?pOK< z)!rJn_^8uqxA^+z#(3;F%g + + + + + + + + + - + - + + - + + - + - + + + + + + + + - + - - - + + + + + + + + + - - - - - - - - + - - - + - + - - - - - + + - - - + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/app/build.gradle b/gradle/anko-simple-ui/app/build.gradle index 222efc6577..f3eb37bbaf 100644 --- a/gradle/anko-simple-ui/app/build.gradle +++ b/gradle/anko-simple-ui/app/build.gradle @@ -2,13 +2,13 @@ apply plugin: 'com.android.application' apply plugin: 'kotlin-android' android { - compileSdkVersion 22 - buildToolsVersion "22.0.1" + compileSdkVersion 25 + buildToolsVersion "25.0.3" defaultConfig { - applicationId "com.irontec.kotlintest" + applicationId "org.example.kotlin" minSdkVersion 16 - targetSdkVersion 22 + targetSdkVersion 25 versionCode 1 versionName "1.0" } @@ -25,22 +25,17 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:22.1.0' - compile 'com.google.code.gson:gson:2.3.1' + compile 'com.android.support:appcompat-v7:25.3.1' + compile 'com.google.code.gson:gson:2.7' compile 'com.squareup.okhttp:okhttp:2.3.0' + // Kotlin compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" - compile "org.jetbrains.anko:anko:$anko_version" -} -buildscript { - ext.kotlin_version = '0.11.91.2' - ext.anko_version = '0.6-15' - repositories { - mavenCentral() - } - dependencies { - classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" - } + // Anko + compile "org.jetbrains.anko:anko-sdk15:$anko_version" + compile "org.jetbrains.anko:anko-support-v4:$anko_version" + compile "org.jetbrains.anko:anko-appcompat-v7:$anko_version" } + repositories { mavenCentral() } diff --git a/gradle/anko-simple-ui/app/src/.DS_Store b/gradle/anko-simple-ui/app/src/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..7fc4e7c0d22ff93a67d2257c8abe2ad3793efb82 GIT binary patch literal 6148 zcmeHK%}T>S5Z-O8CWzRBpx$y3JoJ#ZY7r4at%u%(iXK#IVu}r<+0vv2jgdTuzL78B zFDWkQGs%CVrs@P+Vsu2WJ_o+2RSYqWiK z<@n5jXTBiH-)DgDU5N~cO*|5O+P^)R+k6!w3d!S~I2@{des+ew7e=P}LJP&x-28&3 z>zcl#U3B^^?nHJp4x9GqOgwpR&r$Xa|f<@F?~)oYE4v1RV26(eah%!*Op*-leUTivMcw=V~`cgcPF@F+Kf z!j~#!S>Xhpz{o4S>5KxO1=rx4#82W7kpW}?8JK+r)XAnT&VDIa0WyFL{4fLjd@w*c zS_(6X;^=@uv;cr5a0>xj{Q3hL+yQ7Q%p`&bgvwMvnMzfQK~?8KWjf4TDn64a(+L%C zhIQ1Nsp?RuYCNbR!U?q`;)o0&10NaSy&p)K-~Wf-_x~aY2V?*l_@4~WQmfNyLT&19 zovM=GwFc-VC>I`=Nz7Bg5LYq8@~e0aR0#MDZU9;eGl}2$?4HnDoL59$8b8074yi*K<@A!y=$Ml2L>+{Q3X!2d zmo?~%A4XsiRp=|u{gi^=;=bP(7xuFgH{VTolEhiwXxxfYxia%;)~i;%>YTURK2rU5 z9^}2O6?8wFUL18oXMa#C8QDSjG4AyDYEL&*ng?;(>5hf(e2UXZ^;@c!MwyxCeUKj^ z*DSPGTO16QSC*S~x!QO$tjj^O*{I8v*RO^{&s%uDw7$K6e10*w99~_Uy^_H9Ze-r! zFZc#y#KdX4nY805kBw47fYYd;Gxb@bt_8Gw|;* zpzj9>)#y7cESjqWjd=n9D{vcut$z-6j&$fdEG%LKB5W$qrV97O5H=lt>Ee8cg+-fA z!aY8OTUodliZH8Verdu<_!hZk2AF|K2FkWu)AfJr{`dc668D$^X5hbKKvXu{n=Nd~ z)z+!a=~^qH`%o=9uCO>tfniE9Vs$Bg1~me|)CSOZSXhJy!ao9r25y*vKgz&Q({Xl- literal 0 HcmV?d00001 diff --git a/gradle/anko-simple-ui/app/src/main/AndroidManifest.xml b/gradle/anko-simple-ui/app/src/main/AndroidManifest.xml index e609988df0..7eac755c74 100644 --- a/gradle/anko-simple-ui/app/src/main/AndroidManifest.xml +++ b/gradle/anko-simple-ui/app/src/main/AndroidManifest.xml @@ -1,6 +1,6 @@ + package="org.example.kotlin" > diff --git a/gradle/anko-simple-ui/app/src/main/java/.DS_Store b/gradle/anko-simple-ui/app/src/main/java/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..9bf1062c9bdabc1cf291973ce54e9ee5e3be108a GIT binary patch literal 6148 zcmeHK%}T>S5Z-O8CWx4Wpx$y3JoL~XwTK9z)`%PwNHq5tSH^Ug?)nU8Hn8g?~KqY2O7`_oXFLh2b=*a?dxrVs) z0^z}vT#n>FFd+9X%LE&+ZatXUzayC0{ZOI`!6+|@`nbz)UO(`oxKMcKnQU%pdBreI z!(20N8aINmwwn5NmUHP zcBIxhbK@T5suwk_?a`=IE>-gOUg2<@w?~yqA#axt_Qzwx*xV@|*IRcFkE5sY^NZdJ z4qvH~b;Jq0f`RqjHwIxK!Y+6w(UT}bVt^PR1{Q?@Jl~AfMJb5tAO?tmUt>U?4>qVo z2Qk&Cjt&@93jmk{w-T_`&p)6o9e@sEsu4UOT&Du+RE{kM$KHYKbeMNAKGmqx8CP$H zb@0s`I~0zs2e(x?KTLwN~~y^o@K0 zA4eyXRMhHGQJI0sH#?b0HeZ%x2LMF1+bjbV0Kh@jn8{=FiRgZ<|D zCsL<=G!o5@-^hU8yBq{?1s+_$oBdNh_UO-I19kD41g(*1zt?H`5k)`xttjjyrP7ng zjAh3sa!x+)YbLZsZ z`lf$7xVxv7fWWVoWZL2o9?h@|Mu7QKLv5a3@`)#lL3*f z)oWE;o4s2{R;lk=iF$&nMaQKEUsKSas~BVTRXm4Ef_|wDMAu?!5IrdTBS188!wmc= F11~soUt|CP literal 0 HcmV?d00001 diff --git a/gradle/anko-simple-ui/app/src/main/java/org/example/.DS_Store b/gradle/anko-simple-ui/app/src/main/java/org/example/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..58482d5adebe3668d7b91cf243fdb3f83498ed6b GIT binary patch literal 6148 zcmeHKF-`+P474Fak!VsUWY4b8 zvzwdZ9GjW1-yUzwR%W(@6Yan-H$JD&?5r{lgyW1Sd)W=+!+sd|v+C0caxd)JMtim4 z8=pVw7JmH^cKQHirGONW0#ZNnS z3P^!t1Zn@E;1?b*9v?BfO{LY literal 0 HcmV?d00001 diff --git a/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/MainActivity.kt b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/MainActivity.kt similarity index 54% rename from gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/MainActivity.kt rename to gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/MainActivity.kt index 92b04ae18c..96dd03e651 100644 --- a/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/MainActivity.kt +++ b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/MainActivity.kt @@ -1,84 +1,84 @@ -package com.irontec.kotlintest +package org.example.kotlin -import android.app.Activity import android.os.AsyncTask import android.os.Bundle import android.support.v7.app.AppCompatActivity -import android.util.Log import android.view.Menu import android.view.MenuItem import android.widget.TextView -import com.google.gson.Gson import com.google.gson.GsonBuilder -import com.irontec.kotlintest.deserializers.WeatherDeserializer -import com.irontec.kotlintest.models.WeatherObject -import com.irontec.kotlintest.networking.NetworkClient -import org.json.JSONObject +import org.example.kotlin.deserializers.WeatherDeserializer +import org.example.kotlin.models.WeatherObject +import org.example.kotlin.networking.NetworkClient +import org.jetbrains.anko.* import java.io.BufferedInputStream import java.io.BufferedReader import java.io.InputStreamReader -import java.net.HttpURLConnection -import java.net.URL -import org.jetbrains.anko.* -public class MainActivity : AppCompatActivity() { +class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { - super.onCreate(savedInstanceState) + super.onCreate(savedInstanceState) verticalLayout { padding = dip(5) val mTextView = textView { - textSize = 12f - }.layoutParams(width = matchParent, height = dip(300)) + textSize = 16f + width = matchParent + height = dip(300) + } button("Retrieve Weather") { textSize = 14f - onClick { GetJsonWithOkHttpClient(mTextView).execute() } - }.layoutParams(width = matchParent, height = wrapContent) + width = matchParent + height = wrapContent + onClick { + GetJsonWithOkHttpClient(mTextView).execute() + } + } } } - open class GetJsonWithOkHttpClient(textView: TextView) : AsyncTask() { + open class GetJsonWithOkHttpClient(textView: TextView) : AsyncTask() { val mInnerTextView = textView - override fun doInBackground(vararg params: Void?): String? { + override fun doInBackground(vararg params: Unit?): String? { val networkClient = NetworkClient() val stream = BufferedInputStream( networkClient.get("https://raw.githubusercontent.com/irontec/android-kotlin-samples/master/common-data/bilbao.json")) - return readStream(stream); + return readStream(stream) } override fun onPostExecute(result: String?) { super.onPostExecute(result) - val gsonBuilder = GsonBuilder().serializeNulls(); - gsonBuilder.registerTypeAdapter(javaClass(), WeatherDeserializer()); - val gson = gsonBuilder.create(); - val weather = gson.fromJson(result, javaClass()) as WeatherObject + val gsonBuilder = GsonBuilder().serializeNulls().setPrettyPrinting() + gsonBuilder.registerTypeAdapter(WeatherObject::class.java, WeatherDeserializer()) + val gson = gsonBuilder.create() + val weather = gson.fromJson(result, WeatherObject::class.java) - mInnerTextView.setText(weather.toString()) + mInnerTextView.text = weather.toString() } fun readStream(inputStream: BufferedInputStream): String { - val bufferedReader = BufferedReader(InputStreamReader(inputStream)); - val stringBuilder = StringBuilder(); + val bufferedReader = BufferedReader(InputStreamReader(inputStream)) + val stringBuilder = StringBuilder() bufferedReader.forEachLine { stringBuilder.append(it) } return stringBuilder.toString() } } override fun onCreateOptionsMenu(menu: Menu): Boolean { - getMenuInflater().inflate(R.menu.menu_main, menu) + menuInflater.inflate(R.menu.menu_main, menu) return true } override fun onOptionsItemSelected(item: MenuItem): Boolean { - val id = item.getItemId() + val id = item.itemId if (id == R.id.action_settings) { return true } diff --git a/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/deserializers/WeatherDeserializer.kt similarity index 52% rename from gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt rename to gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/deserializers/WeatherDeserializer.kt index c8e2caaa5e..f327bdd45c 100644 --- a/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt +++ b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/deserializers/WeatherDeserializer.kt @@ -1,11 +1,11 @@ -package com.irontec.kotlintest.deserializers +package org.example.kotlin.deserializers import com.google.gson.JsonDeserializationContext import com.google.gson.JsonDeserializer import com.google.gson.JsonElement import com.google.gson.JsonObject -import com.irontec.kotlintest.models.WeatherObject -import com.irontec.kotlintest.models.WindObject +import org.example.kotlin.models.WeatherObject +import org.example.kotlin.models.WindObject import java.lang.reflect.Type /** @@ -23,14 +23,14 @@ open class WeatherDeserializer : JsonDeserializer { val jsonMainObj = jsonObj.getAsJsonObject("main") val jsonWindObj = jsonObj.getAsJsonObject("wind") - wheather.main = jsonWeatherArray.getAsJsonObject().get("main").getAsString() - wheather.description = jsonWeatherArray.getAsJsonObject().get("description").getAsString() - wheather.temp = jsonMainObj.get("temp").getAsFloat() - wheather.temp_Max = jsonMainObj.get("temp_max").getAsFloat() - wheather.temp_Min = jsonMainObj.get("temp_min").getAsFloat() - wheather.humidity = jsonMainObj.get("humidity").getAsInt() - wind.speed = jsonWindObj.get("speed").getAsFloat() - wind.deg = jsonWindObj.get("deg").getAsFloat() + wheather.main = jsonWeatherArray.asJsonObject.get("main").asString + wheather.description = jsonWeatherArray.asJsonObject.get("description").asString + wheather.temp = jsonMainObj.get("temp").asFloat + wheather.tempMax = jsonMainObj.get("temp_max").asFloat + wheather.tempMin = jsonMainObj.get("temp_min").asFloat + wheather.humidity = jsonMainObj.get("humidity").asInt + wind.speed = jsonWindObj.get("speed").asFloat + wind.deg = jsonWindObj.get("deg").asFloat wheather.wind = wind return wheather diff --git a/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/models/WeatherObject.kt b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/models/WeatherObject.kt new file mode 100644 index 0000000000..716f495a68 --- /dev/null +++ b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/models/WeatherObject.kt @@ -0,0 +1,30 @@ +package org.example.kotlin.models + +import org.example.kotlin.models.WindObject + +/** + * Created by axier on 24/4/15. + */ +class WeatherObject { + + var main: String = "" + var description: String = "" + var temp: Float = 0.0f + var tempMax: Float = 0.0f + var tempMin: Float = 0.0f + var humidity: Int = 0 + var wind: WindObject? = null + + init { + println(this.toString()) + } + + override fun toString() = + "Main ${main}\n" + + "description ${description}\n" + + "temp ${temp}\n" + + "temp_Max ${tempMax}\n" + + "temp_Min ${tempMin}\n" + + "humidity ${humidity}\n" + + "wind ${wind.toString()}" +} \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/models/WindObject.kt similarity index 54% rename from gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt rename to gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/models/WindObject.kt index 5ab3506947..7daf2248b2 100644 --- a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt +++ b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/models/WindObject.kt @@ -1,12 +1,12 @@ -package com.irontec.kotlintest.models +package org.example.kotlin.models /** * Created by axier on 24/4/15. */ -public class WindObject { +class WindObject { - public var speed: Float = 0.0f - public var deg: Float = 0.0f + var speed: Float = 0.0f + var deg: Float = 0.0f init { println(this.toString()) diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt similarity index 93% rename from gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt rename to gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt index 87830ead49..469d8df3d9 100644 --- a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt +++ b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt @@ -1,4 +1,4 @@ -package com.irontec.kotlintest.networking +package org.example.kotlin.networking import com.squareup.okhttp.OkHttpClient import com.squareup.okhttp.Request diff --git a/gradle/anko-simple-ui/build.gradle b/gradle/anko-simple-ui/build.gradle index d3ff69d6e7..5ef970de8d 100644 --- a/gradle/anko-simple-ui/build.gradle +++ b/gradle/anko-simple-ui/build.gradle @@ -1,11 +1,16 @@ // Top-level build file where you can add configuration options common to all sub-projects/modules. buildscript { + + ext.kotlin_version = '1.1.2' + ext.anko_version = '0.9.1' + repositories { jcenter() } dependencies { - classpath 'com.android.tools.build:gradle:1.1.0' + classpath 'com.android.tools.build:gradle:2.3.3' + classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files diff --git a/gradle/anko-simple-ui/gradle/wrapper/gradle-wrapper.properties b/gradle/anko-simple-ui/gradle/wrapper/gradle-wrapper.properties index 0c71e760dc..d241a61eeb 100644 --- a/gradle/anko-simple-ui/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/anko-simple-ui/gradle/wrapper/gradle-wrapper.properties @@ -1,6 +1,6 @@ -#Wed Apr 10 15:27:10 PDT 2013 +#Wed Jun 14 16:55:31 CEST 2017 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-2.2.1-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/app.iml b/gradle/gson-deserializers-okhttp-asyncTask/app/app.iml index 71452a7f66..52dc392329 100644 --- a/gradle/gson-deserializers-okhttp-asyncTask/app/app.iml +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/app.iml @@ -1,5 +1,5 @@ - + @@ -9,12 +9,11 @@ + + + + + + + + + - + - + + - + + - + - + + + + + + + + - + - - - + + + + + + + + + - - - - - - - - + - - - + - + - - - - - + - - + + + + + + + + + + + + + - - + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/build.gradle b/gradle/gson-deserializers-okhttp-asyncTask/app/build.gradle index c12f0007c3..65958439c5 100644 --- a/gradle/gson-deserializers-okhttp-asyncTask/app/build.gradle +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/build.gradle @@ -1,14 +1,15 @@ apply plugin: 'com.android.application' apply plugin: 'kotlin-android' +apply plugin: 'kotlin-android-extensions' android { - compileSdkVersion 22 - buildToolsVersion "22.0.1" + compileSdkVersion 25 + buildToolsVersion "25.0.3" defaultConfig { - applicationId "com.irontec.kotlintest" + applicationId "org.example.kotlin" minSdkVersion 16 - targetSdkVersion 22 + targetSdkVersion 25 versionCode 1 versionName "1.0" } @@ -25,20 +26,12 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:22.1.0' - compile 'com.google.code.gson:gson:2.3.1' + compile 'com.android.support:appcompat-v7:25.3.1' + compile 'com.google.code.gson:gson:2.7' compile 'com.squareup.okhttp:okhttp:2.3.0' compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" } -buildscript { - ext.kotlin_version = '0.11.91.2' - repositories { - mavenCentral() - } - dependencies { - classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" - } -} + repositories { mavenCentral() } diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/AndroidManifest.xml b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/AndroidManifest.xml index e609988df0..7eac755c74 100644 --- a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/AndroidManifest.xml +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/AndroidManifest.xml @@ -1,6 +1,6 @@ + package="org.example.kotlin" > diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt b/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt deleted file mode 100644 index caf561293b..0000000000 --- a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/models/WeatherObject.kt +++ /dev/null @@ -1,24 +0,0 @@ -package com.irontec.kotlintest.models - -/** - * Created by axier on 24/4/15. - */ -public class WeatherObject { - - public var main: String = "" - public var description: String = "" - public var temp: Float = 0.0f - public var temp_Max: Float = 0.0f - public var temp_Min: Float = 0.0f - public var humidity: Int = 0 - public var wind: WindObject? = null - - init { - println(this.toString()) - } - - override fun toString() = - "Main ${main}, description ${description}, temp ${temp}, temp_Max ${temp_Max}," + - ", temp_Min ${temp_Min}, humidity ${humidity}, wind ${wind.toString()}" - -} \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asyncTask/build.gradle b/gradle/gson-deserializers-okhttp-asyncTask/build.gradle index d3ff69d6e7..e6c80a40c6 100644 --- a/gradle/gson-deserializers-okhttp-asyncTask/build.gradle +++ b/gradle/gson-deserializers-okhttp-asyncTask/build.gradle @@ -1,12 +1,16 @@ // Top-level build file where you can add configuration options common to all sub-projects/modules. buildscript { + + ext.kotlin_version = '1.1.2' + repositories { jcenter() } - dependencies { - classpath 'com.android.tools.build:gradle:1.1.0' + dependencies { + classpath 'com.android.tools.build:gradle:2.3.3' + classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files } diff --git a/gradle/gson-deserializers-okhttp-asyncTask/gradle/wrapper/gradle-wrapper.properties b/gradle/gson-deserializers-okhttp-asyncTask/gradle/wrapper/gradle-wrapper.properties index 0c71e760dc..f7fc37c8ca 100644 --- a/gradle/gson-deserializers-okhttp-asyncTask/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/gson-deserializers-okhttp-asyncTask/gradle/wrapper/gradle-wrapper.properties @@ -1,6 +1,6 @@ -#Wed Apr 10 15:27:10 PDT 2013 +#Wed Jun 14 17:49:57 CEST 2017 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-2.2.1-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip diff --git a/gradle/gson-deserializers-okhttp-asynctask/.DS_Store b/gradle/gson-deserializers-okhttp-asynctask/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..37b42619d92349aa47aa2f929660eda8b4fc2223 GIT binary patch literal 6148 zcmeHK&2G~`5T0$))}cUC38`@N1;HUj=?_E*A*G=RdO#qhf&-w`uC2zZYe%s|)P|s3 zcn1Vez^m{AJO~c}-|Q~Ic1y$wA+#gye)}`Cv-3^Xnog+NY z<&4bfk;_2AYs3d`7`y24az+dThJk;b0Y1AWa;QhW-7t54?_uWVcPTOmt>q4ro<8MY z++G+YX}$hc%$3UX3yW5zVpT3#uiM>t*iM~vkhGlsOW6xN-_`BCI1Z<6$9*37!%p?e zgE&f^AoBYe^;a)~$cu-qco2DsT<4jSc3~?Wb*k4!qm9jtM$O);-yPTNQKM0>*_(H6 zkH?m^dVT%=?*8$~>FDkF-A9!Mfv=R5WsN`K6B;_cH|>5D#?c{0SbLsa8c;wXc?Etx zV>Zjr#b26qiw>y|Rz2AHc{{OMuv?g+`@W#NlGTNm9=yb;ePD`R`jiyBeJiZ6m|J0( z*Cx*ShfL0w^4jp|BC51t#Y|+aZon$Rz9L!!1K5+?UjWMxdpwoB1amPRQ5XA85y2W} z6FPy-0s7oNg13Ne$84P&FXu#9nVc+R=e~?1fDJP}-KQV-U zI|yZt`KH#NC{*Soq-U(7Jq!Ip5&G#NY^hG7snFDh0mDF^fs*Q0`Tl?S`}cp|$n*>Y zhJpWz0a4y*@3at-zFW@($9JubvX8>TdJ~1x1eLyyWrMHct0+=1XLAGC)HqRy5s3LC NAZaj_Vc@Sa@B>L&5(@wT literal 0 HcmV?d00001 diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/compiler.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/compiler.xml new file mode 100644 index 0000000000..96cc43efa6 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/compiler.xml @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/copyright/profiles_settings.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/copyright/profiles_settings.xml new file mode 100644 index 0000000000..e7bedf3377 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/copyright/profiles_settings.xml @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/gradle.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/gradle.xml new file mode 100644 index 0000000000..7ac24c777f --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/gradle.xml @@ -0,0 +1,18 @@ + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml new file mode 100644 index 0000000000..986b1cda5a --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/annotations_13_0.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/annotations_13_0.xml new file mode 100644 index 0000000000..24c0dcb114 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/annotations_13_0.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml new file mode 100644 index 0000000000..9e612993e4 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/gson_2_7.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/gson_2_7.xml new file mode 100644 index 0000000000..22607550e1 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/gson_2_7.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml new file mode 100644 index 0000000000..c0993f57d5 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/okhttp_2_3_0.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/okhttp_2_3_0.xml new file mode 100644 index 0000000000..e0ed48aea3 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/okhttp_2_3_0.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/okio_1_3_0.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/okio_1_3_0.xml new file mode 100644 index 0000000000..93a99cb20a --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/okio_1_3_0.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_annotations_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_annotations_25_3_1.xml new file mode 100644 index 0000000000..42adfc6edf --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_annotations_25_3_1.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_compat_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_compat_25_3_1.xml new file mode 100644 index 0000000000..1dff866919 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_compat_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_core_ui_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_core_ui_25_3_1.xml new file mode 100644 index 0000000000..c0bd9753a2 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_core_ui_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_core_utils_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_core_utils_25_3_1.xml new file mode 100644 index 0000000000..406ceb21a7 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_core_utils_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_fragment_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_fragment_25_3_1.xml new file mode 100644 index 0000000000..a356b6caab --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_fragment_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_media_compat_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_media_compat_25_3_1.xml new file mode 100644 index 0000000000..543c69e48e --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_media_compat_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_v4_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_v4_25_3_1.xml new file mode 100644 index 0000000000..8eab02bac5 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_v4_25_3_1.xml @@ -0,0 +1,10 @@ + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml new file mode 100644 index 0000000000..91427afa49 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/misc.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/misc.xml new file mode 100644 index 0000000000..5403283c7d --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/misc.xml @@ -0,0 +1,62 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Android API 25 Platform + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/modules.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/modules.xml new file mode 100644 index 0000000000..8915191f2c --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/modules.xml @@ -0,0 +1,9 @@ + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/runConfigurations.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/runConfigurations.xml new file mode 100644 index 0000000000..7f68460d8b --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/runConfigurations.xml @@ -0,0 +1,12 @@ + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/workspace.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/workspace.xml new file mode 100644 index 0000000000..699ec47081 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/workspace.xml @@ -0,0 +1,2495 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 1497970422658 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/Gson_deserializers_OkHttp_AsyncTask.iml b/gradle/gson-deserializers-okhttp-asynctask/Gson_deserializers_OkHttp_AsyncTask.iml new file mode 100644 index 0000000000..c5d3524d90 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/Gson_deserializers_OkHttp_AsyncTask.iml @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/app/.DS_Store b/gradle/gson-deserializers-okhttp-asynctask/app/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..3b2e0efa7305c6e7705b833574ad18c738884030 GIT binary patch literal 6148 zcmeHK-A)rh82zR#b{jD^h6KHv8xt>zDIhe2m~1LsaA#5@7eHW_ZD5mSr`aDHtTlV% zOXw5$D!u>@;sfZJpH{jBE{&1-nwc~E%{eojv+d3f5wUI_tP(Ye$U%`g3S?pOK< z)!rJn_^8uqxA^+z#(3;F%gS5Z-O8CWzRBpx$y3JoJ#ZY7r4at%u%(iXK#IVu}r<+0vv2jgdTuzL78B zFDWkQGs%CVrs@P+Vsu2WJ_o+2RSYqWiK z<@n5jXTBiH-)DgDU5N~cO*|5O+P^)R+k6!w3d!S~I2@{des+ew7e=P}LJP&x-28&3 z>zcl#U3B^^?nHJp4x9GqOgwpR&r$Xa|f<@F?~)oYE4v1RV26(eah%!*Op*-leUTivMcw=V~`cgcPF@F+Kf z!j~#!S>Xhpz{o4S>5KxO1=rx4#82W7kpW}?8JK+r)XAnT&VDIa0WyFL{4fLjd@w*c zS_(6X;^=@uv;cr5a0>xj{Q3hL+yQ7Q%p`&bgvwMvnMzfQK~?8KWjf4TDn64a(+L%C zhIQ1Nsp?RuYCNbR!U?q`;)o0&10NaSy&p)K-~Wf-_x~aY2V?*l_@4~WQmfNyLT&19 zovM=GwFc-VC>I`=Nz7Bg5LYq8@~e0aR0#MDZU9;eGl}2$?4HnDoL59$8b8074yi*K<@A!y=$Ml2L>+{Q3X!2d zmo?~%A4XsiRp=|u{gi^=;=bP(7xuFgH{VTolEhiwXxxfYxia%;)~i;%>YTURK2rU5 z9^}2O6?8wFUL18oXMa#C8QDSjG4AyDYEL&*ng?;(>5hf(e2UXZ^;@c!MwyxCeUKj^ z*DSPGTO16QSC*S~x!QO$tjj^O*{I8v*RO^{&s%uDw7$K6e10*w99~_Uy^_H9Ze-r! zFZc#y#KdX4nY805kBw47fYYd;Gxb@bt_8Gw|;* zpzj9>)#y7cESjqWjd=n9D{vcut$z-6j&$fdEG%LKB5W$qrV97O5H=lt>Ee8cg+-fA z!aY8OTUodliZH8Verdu<_!hZk2AF|K2FkWu)AfJr{`dc668D$^X5hbKKvXu{n=Nd~ z)z+!a=~^qH`%o=9uCO>tfniE9Vs$Bg1~me|)CSOZSXhJy!ao9r25y*vKgz&Q({Xl- literal 0 HcmV?d00001 diff --git a/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/.DS_Store b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..9bf1062c9bdabc1cf291973ce54e9ee5e3be108a GIT binary patch literal 6148 zcmeHK%}T>S5Z-O8CWx4Wpx$y3JoL~XwTK9z)`%PwNHq5tSH^Ug?)nU8Hn8g?~KqY2O7`_oXFLh2b=*a?dxrVs) z0^z}vT#n>FFd+9X%LE&+ZatXUzayC0{ZOI`!6+|@`nbz)UO(`oxKMcKnQU%pdBreI z!(20N8aINmwwn5NmUHP zcBIxhbK@T5suwk_?a`=IE>-gOUg2<@w?~yqA#axt_Qzwx*xV@|*IRcFkE5sY^NZdJ z4qvH~b;Jq0f`RqjHwIxK!Y+6w(UT}bVt^PR1{Q?@Jl~AfMJb5tAO?tmUt>U?4>qVo z2Qk&Cjt&@93jmk{w-T_`&p)6o9e@sEsu4UOT&Du+RE{kM$KHYKbeMNAKGmqx8CP$H zb@0s`I~0zs2e(x?KTLwN~~y^o@K0 zA4eyXRMhHGQJI0sH#?b0HeZ%x2LMF1+bjbV0Kh@jn8{=FiRgZ<|D zCsL<=G!o5@-^hU8yBq{?1s+_$oBdNh_UO-I19kD41g(*1zt?H`5k)`xttjjyrP7ng zjAh3sa!x+)YbLZsZ z`lf$7xVxv7fWWVoWZL2o9?h@|Mu7QKLv5a3@`)#lL3*f z)oWE;o4s2{R;lk=iF$&nMaQKEUsKSas~BVTRXm4Ef_|wDMAu?!5IrdTBS188!wmc= F11~soUt|CP literal 0 HcmV?d00001 diff --git a/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/.DS_Store b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..58482d5adebe3668d7b91cf243fdb3f83498ed6b GIT binary patch literal 6148 zcmeHKF-`+P474Fak!VsUWY4b8 zvzwdZ9GjW1-yUzwR%W(@6Yan-H$JD&?5r{lgyW1Sd)W=+!+sd|v+C0caxd)JMtim4 z8=pVw7JmH^cKQHirGONW0#ZNnS z3P^!t1Zn@E;1?b*9v?BfO{LY literal 0 HcmV?d00001 diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt similarity index 55% rename from gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt rename to gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt index e2307adcfe..30855b56e6 100644 --- a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt +++ b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt @@ -1,80 +1,71 @@ -package com.irontec.kotlintest +package org.example.kotlin import android.os.AsyncTask import android.os.Bundle import android.support.v7.app.AppCompatActivity -import android.util.Log import android.view.Menu import android.view.MenuItem import android.widget.TextView -import com.google.gson.Gson import com.google.gson.GsonBuilder -import com.irontec.kotlintest.deserializers.WeatherDeserializer -import com.irontec.kotlintest.models.WeatherObject -import com.irontec.kotlintest.networking.NetworkClient -import org.json.JSONObject +import kotlinx.android.synthetic.main.activity_main.* +import org.example.kotlin.deserializers.WeatherDeserializer +import org.example.kotlin.models.WeatherObject +import org.example.kotlin.networking.NetworkClient import java.io.BufferedInputStream import java.io.BufferedReader import java.io.InputStreamReader -import java.net.HttpURLConnection -import java.net.URL -public class MainActivity : AppCompatActivity() { - - open val mTextView: TextView - get() { - return findViewById(R.id.text) as TextView - } - +class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) - GetJsonWithOkHttpClient(mTextView).execute() + //synthetic properties + GetJsonWithOkHttpClient(this.text).execute() } - open class GetJsonWithOkHttpClient(textView: TextView) : AsyncTask() { + open class GetJsonWithOkHttpClient(textView: TextView) : AsyncTask() { val mInnerTextView = textView - override fun doInBackground(vararg params: Void?): String? { + override fun doInBackground(vararg params: Unit?): String? { val networkClient = NetworkClient() val stream = BufferedInputStream( networkClient.get("https://raw.githubusercontent.com/irontec/android-kotlin-samples/master/common-data/bilbao.json")) - return readStream(stream); + return readStream(stream) } override fun onPostExecute(result: String?) { super.onPostExecute(result) - val gsonBuilder = GsonBuilder().serializeNulls(); - gsonBuilder.registerTypeAdapter(javaClass(), WeatherDeserializer()); - val gson = gsonBuilder.create(); - val weather = gson.fromJson(result, javaClass()) as WeatherObject + val gsonBuilder = GsonBuilder().serializeNulls() + gsonBuilder.registerTypeAdapter(WeatherObject::class.java, WeatherDeserializer()) + val gson = gsonBuilder.create() + val weather = gson.fromJson(result, WeatherObject::class.java) - mInnerTextView.setText(weather.toString()) + mInnerTextView.text = weather.toString() } fun readStream(inputStream: BufferedInputStream): String { - val bufferedReader = BufferedReader(InputStreamReader(inputStream)); - val stringBuilder = StringBuilder(); + val bufferedReader = BufferedReader(InputStreamReader(inputStream)) + val stringBuilder = StringBuilder() bufferedReader.forEachLine { stringBuilder.append(it) } return stringBuilder.toString() } } override fun onCreateOptionsMenu(menu: Menu): Boolean { - getMenuInflater().inflate(R.menu.menu_main, menu) + menuInflater.inflate(R.menu.menu_main, menu) return true } override fun onOptionsItemSelected(item: MenuItem): Boolean { - val id = item.getItemId() + val id = item.itemId if (id == R.id.action_settings) { return true } diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/deserializers/WeatherDeserializer.kt similarity index 52% rename from gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt rename to gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/deserializers/WeatherDeserializer.kt index c8e2caaa5e..f327bdd45c 100644 --- a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/java/com/irontec/kotlintest/deserializers/WeatherDeserializer.kt +++ b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/deserializers/WeatherDeserializer.kt @@ -1,11 +1,11 @@ -package com.irontec.kotlintest.deserializers +package org.example.kotlin.deserializers import com.google.gson.JsonDeserializationContext import com.google.gson.JsonDeserializer import com.google.gson.JsonElement import com.google.gson.JsonObject -import com.irontec.kotlintest.models.WeatherObject -import com.irontec.kotlintest.models.WindObject +import org.example.kotlin.models.WeatherObject +import org.example.kotlin.models.WindObject import java.lang.reflect.Type /** @@ -23,14 +23,14 @@ open class WeatherDeserializer : JsonDeserializer { val jsonMainObj = jsonObj.getAsJsonObject("main") val jsonWindObj = jsonObj.getAsJsonObject("wind") - wheather.main = jsonWeatherArray.getAsJsonObject().get("main").getAsString() - wheather.description = jsonWeatherArray.getAsJsonObject().get("description").getAsString() - wheather.temp = jsonMainObj.get("temp").getAsFloat() - wheather.temp_Max = jsonMainObj.get("temp_max").getAsFloat() - wheather.temp_Min = jsonMainObj.get("temp_min").getAsFloat() - wheather.humidity = jsonMainObj.get("humidity").getAsInt() - wind.speed = jsonWindObj.get("speed").getAsFloat() - wind.deg = jsonWindObj.get("deg").getAsFloat() + wheather.main = jsonWeatherArray.asJsonObject.get("main").asString + wheather.description = jsonWeatherArray.asJsonObject.get("description").asString + wheather.temp = jsonMainObj.get("temp").asFloat + wheather.tempMax = jsonMainObj.get("temp_max").asFloat + wheather.tempMin = jsonMainObj.get("temp_min").asFloat + wheather.humidity = jsonMainObj.get("humidity").asInt + wind.speed = jsonWindObj.get("speed").asFloat + wind.deg = jsonWindObj.get("deg").asFloat wheather.wind = wind return wheather diff --git a/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/models/WeatherObject.kt b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/models/WeatherObject.kt new file mode 100644 index 0000000000..a880fa71de --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/models/WeatherObject.kt @@ -0,0 +1,28 @@ +package org.example.kotlin.models + +/** + * Created by axier on 24/4/15. + */ +class WeatherObject { + + var main: String = "" + var description: String = "" + var temp: Float = 0.0f + var tempMax: Float = 0.0f + var tempMin: Float = 0.0f + var humidity: Int = 0 + var wind: WindObject? = null + + init { + println(this.toString()) + } + + override fun toString() = + "Main ${main}\n" + + "description ${description}\n" + + "temp ${temp}\n" + + "temp_Max ${tempMax}\n" + + "temp_Min ${tempMin}\n" + + "humidity ${humidity}\n" + + "wind ${wind.toString()}" +} \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/models/WindObject.kt similarity index 54% rename from gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt rename to gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/models/WindObject.kt index 5ab3506947..7daf2248b2 100644 --- a/gradle/anko-asynchronous-tasks/app/src/main/java/com/irontec/kotlintest/models/WindObject.kt +++ b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/models/WindObject.kt @@ -1,12 +1,12 @@ -package com.irontec.kotlintest.models +package org.example.kotlin.models /** * Created by axier on 24/4/15. */ -public class WindObject { +class WindObject { - public var speed: Float = 0.0f - public var deg: Float = 0.0f + var speed: Float = 0.0f + var deg: Float = 0.0f init { println(this.toString()) diff --git a/gradle/okhttp-asynctask/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt similarity index 93% rename from gradle/okhttp-asynctask/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt rename to gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt index 87830ead49..469d8df3d9 100644 --- a/gradle/okhttp-asynctask/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt +++ b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt @@ -1,4 +1,4 @@ -package com.irontec.kotlintest.networking +package org.example.kotlin.networking import com.squareup.okhttp.OkHttpClient import com.squareup.okhttp.Request diff --git a/gradle/gson-deserializers-okhttp-asynctask/gson-deserializers-okhttp-asynctask.iml b/gradle/gson-deserializers-okhttp-asynctask/gson-deserializers-okhttp-asynctask.iml new file mode 100644 index 0000000000..d609cdb283 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/gson-deserializers-okhttp-asynctask.iml @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.DS_Store b/gradle/httpurlconnection-asynctask/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..4434579fd7a748565782e7ea0ccd182253a9b0df GIT binary patch literal 6148 zcmeHK!EVz)5S?w()}cUC38`?x7bFe=r7aL4gp{U5q6Z|T6gU7%?b=GLx^@&hL?r~} z!apGR0)B-b;6wNTc(c1Lb{e9b5Q3d(_s#Ck%`jlQ=*R3;(|g|T=6)fC}z zF6U%H_gn@Fju9WaVeF#C;fxpt3KETM$A5vrz+R7ayUA@b{ zy4^5H(rWdaSSS=1mzJ$k$tqp4UN<}OpqV;pKWR9g9O#(C`%mgI2)w1FtZF=k&ro!JZ<@U*jH5Ps*m{v%>Qg`=c@zA6 z!DyDBi@z-CHnph-Rz3Lnc|Wl};kPuy_QQnjTGke`bTLbe+6SgsrBBJkY~Lp$EaxH& z^47%9{A1>sujH*Uql>K42`^?M>vf$vSWSv`^|7vy4zb1vKOY*el3TYBC!rH)+{gM6 zq6c(LVLrNG4)W0->*&v9^qncuTeN)^eScHTcUp<5^%}LZ1n%Xd67|1hFP|Y%*|Brru|Ia&_mSMm!@J}%yio4C-22#>z z>$&9kthG@NP*~V*tWdh3(#Nq>_$a=LA_ZeME5N$Ou|o7f%!h!a!BmEUKgz&Q7%vOk literal 0 HcmV?d00001 diff --git a/gradle/httpurlconnection-asynctask/.idea/compiler.xml b/gradle/httpurlconnection-asynctask/.idea/compiler.xml new file mode 100644 index 0000000000..96cc43efa6 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/compiler.xml @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/copyright/profiles_settings.xml b/gradle/httpurlconnection-asynctask/.idea/copyright/profiles_settings.xml new file mode 100644 index 0000000000..e7bedf3377 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/copyright/profiles_settings.xml @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/gradle.xml b/gradle/httpurlconnection-asynctask/.idea/gradle.xml new file mode 100644 index 0000000000..7ac24c777f --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/gradle.xml @@ -0,0 +1,18 @@ + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml new file mode 100644 index 0000000000..986b1cda5a --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/annotations_13_0.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/annotations_13_0.xml new file mode 100644 index 0000000000..24c0dcb114 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/libraries/annotations_13_0.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml new file mode 100644 index 0000000000..9e612993e4 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml new file mode 100644 index 0000000000..c0993f57d5 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/support_annotations_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/support_annotations_25_3_1.xml new file mode 100644 index 0000000000..42adfc6edf --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/libraries/support_annotations_25_3_1.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/support_compat_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/support_compat_25_3_1.xml new file mode 100644 index 0000000000..1dff866919 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/libraries/support_compat_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/support_core_ui_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/support_core_ui_25_3_1.xml new file mode 100644 index 0000000000..c0bd9753a2 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/libraries/support_core_ui_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/support_core_utils_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/support_core_utils_25_3_1.xml new file mode 100644 index 0000000000..406ceb21a7 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/libraries/support_core_utils_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/support_fragment_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/support_fragment_25_3_1.xml new file mode 100644 index 0000000000..a356b6caab --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/libraries/support_fragment_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/support_media_compat_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/support_media_compat_25_3_1.xml new file mode 100644 index 0000000000..543c69e48e --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/libraries/support_media_compat_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/support_v4_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/support_v4_25_3_1.xml new file mode 100644 index 0000000000..8eab02bac5 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/libraries/support_v4_25_3_1.xml @@ -0,0 +1,10 @@ + + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml new file mode 100644 index 0000000000..91427afa49 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/misc.xml b/gradle/httpurlconnection-asynctask/.idea/misc.xml new file mode 100644 index 0000000000..5403283c7d --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/misc.xml @@ -0,0 +1,62 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Android API 25 Platform + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/modules.xml b/gradle/httpurlconnection-asynctask/.idea/modules.xml new file mode 100644 index 0000000000..78f8bc36ce --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/modules.xml @@ -0,0 +1,9 @@ + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/runConfigurations.xml b/gradle/httpurlconnection-asynctask/.idea/runConfigurations.xml new file mode 100644 index 0000000000..7f68460d8b --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/runConfigurations.xml @@ -0,0 +1,12 @@ + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/workspace.xml b/gradle/httpurlconnection-asynctask/.idea/workspace.xml new file mode 100644 index 0000000000..579d30554c --- /dev/null +++ b/gradle/httpurlconnection-asynctask/.idea/workspace.xml @@ -0,0 +1,2344 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 1497970498549 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/HttpUrlConnection_AsyncTask.iml b/gradle/httpurlconnection-asynctask/HttpUrlConnection_AsyncTask.iml new file mode 100644 index 0000000000..0c0d564962 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/HttpUrlConnection_AsyncTask.iml @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/app/.DS_Store b/gradle/httpurlconnection-asynctask/app/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..3b2e0efa7305c6e7705b833574ad18c738884030 GIT binary patch literal 6148 zcmeHK-A)rh82zR#b{jD^h6KHv8xt>zDIhe2m~1LsaA#5@7eHW_ZD5mSr`aDHtTlV% zOXw5$D!u>@;sfZJpH{jBE{&1-nwc~E%{eojv+d3f5wUI_tP(Ye$U%`g3S?pOK< z)!rJn_^8uqxA^+z#(3;F%g - + @@ -9,12 +9,11 @@ + + + + + + + + + - + - + + - + + - + - + + + + + + + + - + - - - + + + + + + + + + - - - - - - - - + - - - + - + - - - - - + + + + + + + + + + + + - - + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/app/build.gradle b/gradle/httpurlconnection-asynctask/app/build.gradle index 5c2ef7ba5f..f09567afc3 100644 --- a/gradle/httpurlconnection-asynctask/app/build.gradle +++ b/gradle/httpurlconnection-asynctask/app/build.gradle @@ -1,14 +1,15 @@ apply plugin: 'com.android.application' apply plugin: 'kotlin-android' +apply plugin: 'kotlin-android-extensions' android { - compileSdkVersion 22 - buildToolsVersion "22.0.1" + compileSdkVersion 25 + buildToolsVersion "25.0.3" defaultConfig { - applicationId "com.irontec.kotlintest" + applicationId "org.example.kotlin" minSdkVersion 16 - targetSdkVersion 22 + targetSdkVersion 25 versionCode 1 versionName "1.0" } @@ -25,18 +26,10 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:22.0.0' + compile 'com.android.support:appcompat-v7:25.3.1' compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" } -buildscript { - ext.kotlin_version = '0.11.91.2' - repositories { - mavenCentral() - } - dependencies { - classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" - } -} + repositories { mavenCentral() } diff --git a/gradle/httpurlconnection-asynctask/app/src/.DS_Store b/gradle/httpurlconnection-asynctask/app/src/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..7fc4e7c0d22ff93a67d2257c8abe2ad3793efb82 GIT binary patch literal 6148 zcmeHK%}T>S5Z-O8CWzRBpx$y3JoJ#ZY7r4at%u%(iXK#IVu}r<+0vv2jgdTuzL78B zFDWkQGs%CVrs@P+Vsu2WJ_o+2RSYqWiK z<@n5jXTBiH-)DgDU5N~cO*|5O+P^)R+k6!w3d!S~I2@{des+ew7e=P}LJP&x-28&3 z>zcl#U3B^^?nHJp4x9GqOgwpR&r$Xa|f<@F?~)oYE4v1RV26(eah%!*Op*-leUTivMcw=V~`cgcPF@F+Kf z!j~#!S>Xhpz{o4S>5KxO1=rx4#82W7kpW}?8JK+r)XAnT&VDIa0WyFL{4fLjd@w*c zS_(6X;^=@uv;cr5a0>xj{Q3hL+yQ7Q%p`&bgvwMvnMzfQK~?8KWjf4TDn64a(+L%C zhIQ1Nsp?RuYCNbR!U?q`;)o0&10NaSy&p)K-~Wf-_x~aY2V?*l_@4~WQmfNyLT&19 zovM=GwFc-VC>I`=Nz7Bg5LYq8@~e0aR0#MDZU9;eGl}2$?4HnDoL59$8b8074yi*K<@A!y=$Ml2L>+{Q3X!2d zmo?~%A4XsiRp=|u{gi^=;=bP(7xuFgH{VTolEhiwXxxfYxia%;)~i;%>YTURK2rU5 z9^}2O6?8wFUL18oXMa#C8QDSjG4AyDYEL&*ng?;(>5hf(e2UXZ^;@c!MwyxCeUKj^ z*DSPGTO16QSC*S~x!QO$tjj^O*{I8v*RO^{&s%uDw7$K6e10*w99~_Uy^_H9Ze-r! zFZc#y#KdX4nY805kBw47fYYd;Gxb@bt_8Gw|;* zpzj9>)#y7cESjqWjd=n9D{vcut$z-6j&$fdEG%LKB5W$qrV97O5H=lt>Ee8cg+-fA z!aY8OTUodliZH8Verdu<_!hZk2AF|K2FkWu)AfJr{`dc668D$^X5hbKKvXu{n=Nd~ z)z+!a=~^qH`%o=9uCO>tfniE9Vs$Bg1~me|)CSOZSXhJy!ao9r25y*vKgz&Q({Xl- literal 0 HcmV?d00001 diff --git a/gradle/httpurlconnection-asynctask/app/src/main/AndroidManifest.xml b/gradle/httpurlconnection-asynctask/app/src/main/AndroidManifest.xml index e609988df0..7eac755c74 100644 --- a/gradle/httpurlconnection-asynctask/app/src/main/AndroidManifest.xml +++ b/gradle/httpurlconnection-asynctask/app/src/main/AndroidManifest.xml @@ -1,6 +1,6 @@ + package="org.example.kotlin" > diff --git a/gradle/httpurlconnection-asynctask/app/src/main/java/.DS_Store b/gradle/httpurlconnection-asynctask/app/src/main/java/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..9bf1062c9bdabc1cf291973ce54e9ee5e3be108a GIT binary patch literal 6148 zcmeHK%}T>S5Z-O8CWx4Wpx$y3JoL~XwTK9z)`%PwNHq5tSH^Ug?)nU8Hn8g?~KqY2O7`_oXFLh2b=*a?dxrVs) z0^z}vT#n>FFd+9X%LE&+ZatXUzayC0{ZOI`!6+|@`nbz)UO(`oxKMcKnQU%pdBreI z!(20N8aINmwwn5NmUHP zcBIxhbK@T5suwk_?a`=IE>-gOUg2<@w?~yqA#axt_Qzwx*xV@|*IRcFkE5sY^NZdJ z4qvH~b;Jq0f`RqjHwIxK!Y+6w(UT}bVt^PR1{Q?@Jl~AfMJb5tAO?tmUt>U?4>qVo z2Qk&Cjt&@93jmk{w-T_`&p)6o9e@sEsu4UOT&Du+RE{kM$KHYKbeMNAKGmqx8CP$H zb@0s`I~0zs2e(x?KTLwN~~y^o@K0 zA4eyXRMhHGQJI0sH#?b0HeZ%x2LMF1+bjbV0Kh@jn8{=FiRgZ<|D zCsL<=G!o5@-^hU8yBq{?1s+_$oBdNh_UO-I19kD41g(*1zt?H`5k)`xttjjyrP7ng zjAh3sa!x+)YbLZsZ z`lf$7xVxv7fWWVoWZL2o9?h@|Mu7QKLv5a3@`)#lL3*f z)oWE;o4s2{R;lk=iF$&nMaQKEUsKSas~BVTRXm4Ef_|wDMAu?!5IrdTBS188!wmc= F11~soUt|CP literal 0 HcmV?d00001 diff --git a/gradle/httpurlconnection-asynctask/app/src/main/java/org/example/.DS_Store b/gradle/httpurlconnection-asynctask/app/src/main/java/org/example/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..58482d5adebe3668d7b91cf243fdb3f83498ed6b GIT binary patch literal 6148 zcmeHKF-`+P474Fak!VsUWY4b8 zvzwdZ9GjW1-yUzwR%W(@6Yan-H$JD&?5r{lgyW1Sd)W=+!+sd|v+C0caxd)JMtim4 z8=pVw7JmH^cKQHirGONW0#ZNnS z3P^!t1Zn@E;1?b*9v?BfO{LY literal 0 HcmV?d00001 diff --git a/gradle/httpurlconnection-asynctask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt b/gradle/httpurlconnection-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt similarity index 66% rename from gradle/httpurlconnection-asynctask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt rename to gradle/httpurlconnection-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt index 1ec6b7f271..970cfec0c1 100644 --- a/gradle/httpurlconnection-asynctask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt +++ b/gradle/httpurlconnection-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt @@ -1,12 +1,12 @@ -package com.irontec.kotlintest +package org.example.kotlin import android.os.AsyncTask -import android.support.v7.app.ActionBarActivity import android.os.Bundle -import android.util.Log +import android.support.v7.app.AppCompatActivity import android.view.Menu import android.view.MenuItem import android.widget.TextView +import kotlinx.android.synthetic.main.activity_main.* import org.json.JSONObject import java.io.BufferedInputStream import java.io.BufferedReader @@ -15,47 +15,41 @@ import java.net.HttpURLConnection import java.net.URL -public class MainActivity : ActionBarActivity() { - - open val mTextView: TextView - get() { - return findViewById(R.id.text) as TextView - } - +class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) - GetWeatherTask(mTextView).execute() + GetWeatherTask(this.text).execute() } - class GetWeatherTask(textView: TextView) : AsyncTask() { + class GetWeatherTask(textView: TextView) : AsyncTask() { val innerTextView: TextView? = textView - override fun doInBackground(vararg params: Void?): String? { + override fun doInBackground(vararg params: Unit?): String? { val url = URL("https://raw.githubusercontent.com/irontec/android-kotlin-samples/master/common-data/bilbao.json") val httpClient = url.openConnection() as HttpURLConnection - if(httpClient.getResponseCode() == HttpURLConnection.HTTP_OK){ + if (httpClient.responseCode == HttpURLConnection.HTTP_OK) { try { - val stream = BufferedInputStream(httpClient.getInputStream()) + val stream = BufferedInputStream(httpClient.inputStream) val data: String = readStream(inputStream = stream) - return data; - } catch (e : Exception) { + return data + } catch (e: Exception) { e.printStackTrace() } finally { httpClient.disconnect() } - }else{ - println("ERROR ${httpClient.getResponseCode()}") + } else { + println("ERROR ${httpClient.responseCode}") } return null } fun readStream(inputStream: BufferedInputStream): String { - val bufferedReader = BufferedReader(InputStreamReader(inputStream)); - val stringBuilder = StringBuilder(); + val bufferedReader = BufferedReader(InputStreamReader(inputStream)) + val stringBuilder = StringBuilder() bufferedReader.forEachLine { stringBuilder.append(it) } return stringBuilder.toString() } @@ -67,7 +61,7 @@ public class MainActivity : ActionBarActivity() { override fun onPostExecute(result: String?) { super.onPostExecute(result) - innerTextView?.setText(JSONObject(result).toString()) + innerTextView?.text = JSONObject(result).toString() /** * ... Work with the weather data @@ -77,12 +71,12 @@ public class MainActivity : ActionBarActivity() { } override fun onCreateOptionsMenu(menu: Menu): Boolean { - getMenuInflater().inflate(R.menu.menu_main, menu) + menuInflater.inflate(R.menu.menu_main, menu) return true } override fun onOptionsItemSelected(item: MenuItem): Boolean { - val id = item.getItemId() + val id = item.itemId if (id == R.id.action_settings) { return true } diff --git a/gradle/httpurlconnection-asynctask/build.gradle b/gradle/httpurlconnection-asynctask/build.gradle index d3ff69d6e7..e6c80a40c6 100644 --- a/gradle/httpurlconnection-asynctask/build.gradle +++ b/gradle/httpurlconnection-asynctask/build.gradle @@ -1,12 +1,16 @@ // Top-level build file where you can add configuration options common to all sub-projects/modules. buildscript { + + ext.kotlin_version = '1.1.2' + repositories { jcenter() } - dependencies { - classpath 'com.android.tools.build:gradle:1.1.0' + dependencies { + classpath 'com.android.tools.build:gradle:2.3.3' + classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files } diff --git a/gradle/httpurlconnection-asynctask/gradle/wrapper/gradle-wrapper.properties b/gradle/httpurlconnection-asynctask/gradle/wrapper/gradle-wrapper.properties index 0c71e760dc..5eb7593ab8 100644 --- a/gradle/httpurlconnection-asynctask/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/httpurlconnection-asynctask/gradle/wrapper/gradle-wrapper.properties @@ -1,6 +1,6 @@ -#Wed Apr 10 15:27:10 PDT 2013 +#Thu Jun 15 08:54:58 CEST 2017 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-2.2.1-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip diff --git a/gradle/httpurlconnection-asynctask/httpurlconnection-asynctask.iml b/gradle/httpurlconnection-asynctask/httpurlconnection-asynctask.iml new file mode 100644 index 0000000000..7693cd4805 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/httpurlconnection-asynctask.iml @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.DS_Store b/gradle/listview-baseadapter-data-object/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..680fa738039560829fadfe23f9c7c5145673e521 GIT binary patch literal 6148 zcmeHK(QeZ)6un-%EoHzu32E?_2atH^rfvf&gpf)p50gM36^#c#U9v=5P!?BBx@eT5 zzVHtSzJOoh2lx;^0M2y`Bv}VMAq2jXeeCOdeSMGXxF#ae8F?E-bt1A*7^`Pc%@7{v zazf^`<~&gF9CFVMrHdXwM5 zn&;>24@+97eHwyQ4}N~pPpp>w7Jg#;rewR4w?&izqDa&}Fu^K)ic8Txmu6Tj%#aqX ziTC_%ZqJvB)`;jLtEA+`Oys>TBkO=-tmsIsDWx^#7h`?Q3IEy>wdOU|OQ2ap9xlCr zb`N9g@H?ci7)LN0#W?qMoE;sfPaVv~aqbl2^r;Iy$LZ61BQVj1C^{>=llQO>F@udlj#`- z3oN-I*+pStyJ?2X1(m*zRfDhMizrGkW^)7B);P@&8i@HL NplC3aVc?H4@D=F34!r;X literal 0 HcmV?d00001 diff --git a/gradle/listview-baseadapter-data-object/.idea/compiler.xml b/gradle/listview-baseadapter-data-object/.idea/compiler.xml new file mode 100644 index 0000000000..96cc43efa6 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/compiler.xml @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/copyright/profiles_settings.xml b/gradle/listview-baseadapter-data-object/.idea/copyright/profiles_settings.xml new file mode 100644 index 0000000000..e7bedf3377 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/copyright/profiles_settings.xml @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/gradle.xml b/gradle/listview-baseadapter-data-object/.idea/gradle.xml new file mode 100644 index 0000000000..7ac24c777f --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/gradle.xml @@ -0,0 +1,18 @@ + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/animated_vector_drawable_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/animated_vector_drawable_25_3_1.xml new file mode 100644 index 0000000000..986b1cda5a --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/libraries/animated_vector_drawable_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/annotations_13_0.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/annotations_13_0.xml new file mode 100644 index 0000000000..24c0dcb114 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/libraries/annotations_13_0.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/appcompat_v7_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/appcompat_v7_25_3_1.xml new file mode 100644 index 0000000000..9e612993e4 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/libraries/appcompat_v7_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/kotlin_stdlib_1_1_2.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/kotlin_stdlib_1_1_2.xml new file mode 100644 index 0000000000..c0993f57d5 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/libraries/kotlin_stdlib_1_1_2.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/support_annotations_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/support_annotations_25_3_1.xml new file mode 100644 index 0000000000..42adfc6edf --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/libraries/support_annotations_25_3_1.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/support_compat_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/support_compat_25_3_1.xml new file mode 100644 index 0000000000..1dff866919 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/libraries/support_compat_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/support_core_ui_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/support_core_ui_25_3_1.xml new file mode 100644 index 0000000000..c0bd9753a2 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/libraries/support_core_ui_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/support_core_utils_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/support_core_utils_25_3_1.xml new file mode 100644 index 0000000000..406ceb21a7 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/libraries/support_core_utils_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/support_fragment_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/support_fragment_25_3_1.xml new file mode 100644 index 0000000000..a356b6caab --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/libraries/support_fragment_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/support_media_compat_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/support_media_compat_25_3_1.xml new file mode 100644 index 0000000000..543c69e48e --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/libraries/support_media_compat_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/support_v4_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/support_v4_25_3_1.xml new file mode 100644 index 0000000000..8eab02bac5 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/libraries/support_v4_25_3_1.xml @@ -0,0 +1,10 @@ + + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/support_vector_drawable_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/support_vector_drawable_25_3_1.xml new file mode 100644 index 0000000000..91427afa49 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/libraries/support_vector_drawable_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/misc.xml b/gradle/listview-baseadapter-data-object/.idea/misc.xml new file mode 100644 index 0000000000..5403283c7d --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/misc.xml @@ -0,0 +1,62 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Android API 25 Platform + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/modules.xml b/gradle/listview-baseadapter-data-object/.idea/modules.xml new file mode 100644 index 0000000000..3580ff2493 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/modules.xml @@ -0,0 +1,9 @@ + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/runConfigurations.xml b/gradle/listview-baseadapter-data-object/.idea/runConfigurations.xml new file mode 100644 index 0000000000..7f68460d8b --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/runConfigurations.xml @@ -0,0 +1,12 @@ + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/workspace.xml b/gradle/listview-baseadapter-data-object/.idea/workspace.xml new file mode 100644 index 0000000000..25b3a44930 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/.idea/workspace.xml @@ -0,0 +1,2421 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 1497970544901 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/ListView_BaseAdapter_Data_Object.iml b/gradle/listview-baseadapter-data-object/ListView_BaseAdapter_Data_Object.iml new file mode 100644 index 0000000000..fde7cffa04 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/ListView_BaseAdapter_Data_Object.iml @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/app/.DS_Store b/gradle/listview-baseadapter-data-object/app/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..3b2e0efa7305c6e7705b833574ad18c738884030 GIT binary patch literal 6148 zcmeHK-A)rh82zR#b{jD^h6KHv8xt>zDIhe2m~1LsaA#5@7eHW_ZD5mSr`aDHtTlV% zOXw5$D!u>@;sfZJpH{jBE{&1-nwc~E%{eojv+d3f5wUI_tP(Ye$U%`g3S?pOK< z)!rJn_^8uqxA^+z#(3;F%g - + @@ -9,12 +9,11 @@ + + + + + + + + + - + - + + - + + - + - + + + + + + + + - + + + + + + + + - - - + + - - - - - - - - + - - - - + - + - - - - - + + + + + + + + + + + + - - + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/app/build.gradle b/gradle/listview-baseadapter-data-object/app/build.gradle index 5c2ef7ba5f..f09567afc3 100644 --- a/gradle/listview-baseadapter-data-object/app/build.gradle +++ b/gradle/listview-baseadapter-data-object/app/build.gradle @@ -1,14 +1,15 @@ apply plugin: 'com.android.application' apply plugin: 'kotlin-android' +apply plugin: 'kotlin-android-extensions' android { - compileSdkVersion 22 - buildToolsVersion "22.0.1" + compileSdkVersion 25 + buildToolsVersion "25.0.3" defaultConfig { - applicationId "com.irontec.kotlintest" + applicationId "org.example.kotlin" minSdkVersion 16 - targetSdkVersion 22 + targetSdkVersion 25 versionCode 1 versionName "1.0" } @@ -25,18 +26,10 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:22.0.0' + compile 'com.android.support:appcompat-v7:25.3.1' compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" } -buildscript { - ext.kotlin_version = '0.11.91.2' - repositories { - mavenCentral() - } - dependencies { - classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" - } -} + repositories { mavenCentral() } diff --git a/gradle/listview-baseadapter-data-object/app/src/.DS_Store b/gradle/listview-baseadapter-data-object/app/src/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..7fc4e7c0d22ff93a67d2257c8abe2ad3793efb82 GIT binary patch literal 6148 zcmeHK%}T>S5Z-O8CWzRBpx$y3JoJ#ZY7r4at%u%(iXK#IVu}r<+0vv2jgdTuzL78B zFDWkQGs%CVrs@P+Vsu2WJ_o+2RSYqWiK z<@n5jXTBiH-)DgDU5N~cO*|5O+P^)R+k6!w3d!S~I2@{des+ew7e=P}LJP&x-28&3 z>zcl#U3B^^?nHJp4x9GqOgwpR&r$Xa|f<@F?~)oYE4v1RV26(eah%!*Op*-leUTivMcw=V~`cgcPF@F+Kf z!j~#!S>Xhpz{o4S>5KxO1=rx4#82W7kpW}?8JK+r)XAnT&VDIa0WyFL{4fLjd@w*c zS_(6X;^=@uv;cr5a0>xj{Q3hL+yQ7Q%p`&bgvwMvnMzfQK~?8KWjf4TDn64a(+L%C zhIQ1Nsp?RuYCNbR!U?q`;)o0&10NaSy&p)K-~Wf-_x~aY2V?*l_@4~WQmfNyLT&19 zovM=GwFc-VC>I`=Nz7Bg5LYq8@~e0aR0#MDZU9;eGl}2$?4HnDoL59$8b8074yi*K<@A!y=$Ml2L>+{Q3X!2d zmo?~%A4XsiRp=|u{gi^=;=bP(7xuFgH{VTolEhiwXxxfYxia%;)~i;%>YTURK2rU5 z9^}2O6?8wFUL18oXMa#C8QDSjG4AyDYEL&*ng?;(>5hf(e2UXZ^;@c!MwyxCeUKj^ z*DSPGTO16QSC*S~x!QO$tjj^O*{I8v*RO^{&s%uDw7$K6e10*w99~_Uy^_H9Ze-r! zFZc#y#KdX4nY805kBw47fYYd;Gxb@bt_8Gw|;* zpzj9>)#y7cESjqWjd=n9D{vcut$z-6j&$fdEG%LKB5W$qrV97O5H=lt>Ee8cg+-fA z!aY8OTUodliZH8Verdu<_!hZk2AF|K2FkWu)AfJr{`dc668D$^X5hbKKvXu{n=Nd~ z)z+!a=~^qH`%o=9uCO>tfniE9Vs$Bg1~me|)CSOZSXhJy!ao9r25y*vKgz&Q({Xl- literal 0 HcmV?d00001 diff --git a/gradle/listview-baseadapter-data-object/app/src/main/AndroidManifest.xml b/gradle/listview-baseadapter-data-object/app/src/main/AndroidManifest.xml index e609988df0..7eac755c74 100644 --- a/gradle/listview-baseadapter-data-object/app/src/main/AndroidManifest.xml +++ b/gradle/listview-baseadapter-data-object/app/src/main/AndroidManifest.xml @@ -1,6 +1,6 @@ + package="org.example.kotlin" > diff --git a/gradle/listview-baseadapter-data-object/app/src/main/java/.DS_Store b/gradle/listview-baseadapter-data-object/app/src/main/java/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..9bf1062c9bdabc1cf291973ce54e9ee5e3be108a GIT binary patch literal 6148 zcmeHK%}T>S5Z-O8CWx4Wpx$y3JoL~XwTK9z)`%PwNHq5tSH^Ug?)nU8Hn8g?~KqY2O7`_oXFLh2b=*a?dxrVs) z0^z}vT#n>FFd+9X%LE&+ZatXUzayC0{ZOI`!6+|@`nbz)UO(`oxKMcKnQU%pdBreI z!(20N8aINmwwn5NmUHP zcBIxhbK@T5suwk_?a`=IE>-gOUg2<@w?~yqA#axt_Qzwx*xV@|*IRcFkE5sY^NZdJ z4qvH~b;Jq0f`RqjHwIxK!Y+6w(UT}bVt^PR1{Q?@Jl~AfMJb5tAO?tmUt>U?4>qVo z2Qk&Cjt&@93jmk{w-T_`&p)6o9e@sEsu4UOT&Du+RE{kM$KHYKbeMNAKGmqx8CP$H zb@0s`I~0zs2e(x?(90, {i -> CustomPojo(name = i.toString())}) - - val adapter = CustomListAdapter(data = listdata, context = this) - - mListView.setAdapter(adapter) - } - - - override fun onCreateOptionsMenu(menu: Menu): Boolean { - getMenuInflater().inflate(R.menu.menu_main, menu) - return true - } - - override fun onOptionsItemSelected(item: MenuItem): Boolean { - val id = item.getItemId() - if (id == R.id.action_settings) { - return true - } - return super.onOptionsItemSelected(item) - } - - fun getLastNumber(dataset: Array) : Int { - return dataset.last(); - } -} diff --git a/gradle/listview-baseadapter-data-object/app/src/main/java/org/.DS_Store b/gradle/listview-baseadapter-data-object/app/src/main/java/org/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..97188593ebd5a627a78df0794d0a21e274e6ff02 GIT binary patch literal 6148 zcmeHK%}N6?5T4X(w}{w-px$y3JoM1|S44!R)`K^pq6d|_YZqNuH>KTLwN~~y^o@K0 zA4eyXRMhHGQJI0sH#?b0HeZ%x2LMF1+bjbV0Kh@jn8{=FiRgZ<|D zCsL<=G!o5@-^hU8yBq{?1s+_$oBdNh_UO-I19kD41g(*1zt?H`5k)`xttjjyrP7ng zjAh3sa!x+)YbLZsZ z`lf$7xVxv7fWWVoWZL2o9?h@|Mu7QKLv5a3@`)#lL3*f z)oWE;o4s2{R;lk=iF$&nMaQKEUsKSas~BVTRXm4Ef_|wDMAu?!5IrdTBS188!wmc= F11~soUt|CP literal 0 HcmV?d00001 diff --git a/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/.DS_Store b/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..58482d5adebe3668d7b91cf243fdb3f83498ed6b GIT binary patch literal 6148 zcmeHKF-`+P474Fak!VsUWY4b8 zvzwdZ9GjW1-yUzwR%W(@6Yan-H$JD&?5r{lgyW1Sd)W=+!+sd|v+C0caxd)JMtim4 z8=pVw7JmH^cKQHirGONW0#ZNnS z3P^!t1Zn@E;1?b*9v?BfO{LY literal 0 HcmV?d00001 diff --git a/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/MainActivity.kt b/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/MainActivity.kt new file mode 100644 index 0000000000..0922c3b260 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/MainActivity.kt @@ -0,0 +1,41 @@ +package org.example.kotlin + +import android.os.Bundle +import android.support.v7.app.AppCompatActivity +import android.view.Menu +import android.view.MenuItem +import kotlinx.android.synthetic.main.activity_main.* +import org.example.kotlin.adapters.CustomListAdapter +import org.example.kotlin.models.CustomPojo + +class MainActivity : AppCompatActivity() { + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + setContentView(R.layout.activity_main) + + val listdata = Array(90, {i -> CustomPojo(name = i.toString()) }) + + val adapter = CustomListAdapter(data = listdata, context = this) + + this.list.adapter = adapter + } + + + override fun onCreateOptionsMenu(menu: Menu): Boolean { + menuInflater.inflate(R.menu.menu_main, menu) + return true + } + + override fun onOptionsItemSelected(item: MenuItem): Boolean { + val id = item.itemId + if (id == R.id.action_settings) { + return true + } + return super.onOptionsItemSelected(item) + } + + fun getLastNumber(dataset: Array) : Int { + return dataset.last() + } +} diff --git a/gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/adapters/CustomListAdapter.kt b/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/adapters/CustomListAdapter.kt similarity index 60% rename from gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/adapters/CustomListAdapter.kt rename to gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/adapters/CustomListAdapter.kt index 7f6c4d0e33..ef1fe5fddd 100644 --- a/gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/adapters/CustomListAdapter.kt +++ b/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/adapters/CustomListAdapter.kt @@ -1,4 +1,4 @@ -package com.irontec.kotlintest.adapters +package org.example.kotlin.adapters import android.content.Context import android.view.LayoutInflater @@ -6,52 +6,54 @@ import android.view.View import android.view.ViewGroup import android.widget.BaseAdapter import android.widget.TextView -import com.irontec.kotlintest.R -import com.irontec.kotlintest.models.CustomPojo +import org.example.kotlin.R +import org.example.kotlin.models.CustomPojo /** * Created by axier on 22/4/15. */ open class CustomListAdapter(data: Array, context: Context) : BaseAdapter() { - var localData = data; + val mInflater: LayoutInflater + var localData = data + + init { + mInflater = LayoutInflater.from(context); + } override fun getCount(): Int { - return localData.size() + return localData.size } override fun getItem(position: Int): Any { - return localData.get(position) + return localData[position] } override fun getItemId(position: Int): Long { return position.toLong() } - private val mInflater: LayoutInflater? - { - mInflater = LayoutInflater.from(context) - } - override fun getView(position: Int, convertView: View?, parent: ViewGroup): View? { val view: View? val vh: ListRowHolder if (convertView == null) { - view = mInflater?.inflate(R.layout.row_item, parent, false) + view = mInflater.inflate(R.layout.row_item, parent, false) vh = ListRowHolder(view) - view?.setTag(vh) + view?.tag = vh } else { view = convertView - vh = view.getTag() as ListRowHolder + vh = view.tag as ListRowHolder } - vh.label.setText(localData.get(index = position).toString()) - return view; + vh.label.text = localData.get(index = position).toString() + return view } private class ListRowHolder(row: View?) { - public val label: TextView - { + + val label: TextView + + init { this.label = row?.findViewById(R.id.label) as TextView } } diff --git a/gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/models/CustomPojo.kt b/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/models/CustomPojo.kt similarity index 84% rename from gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/models/CustomPojo.kt rename to gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/models/CustomPojo.kt index dbbd0a4ad4..a066cebe09 100644 --- a/gradle/listview-baseadapter-data-object/app/src/main/java/com/irontec/kotlintest/models/CustomPojo.kt +++ b/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/models/CustomPojo.kt @@ -1,4 +1,4 @@ -package com.irontec.kotlintest.models +package org.example.kotlin.models /** * Created by axier on 21/4/15. diff --git a/gradle/listview-baseadapter-data-object/build.gradle b/gradle/listview-baseadapter-data-object/build.gradle index d3ff69d6e7..e6c80a40c6 100644 --- a/gradle/listview-baseadapter-data-object/build.gradle +++ b/gradle/listview-baseadapter-data-object/build.gradle @@ -1,12 +1,16 @@ // Top-level build file where you can add configuration options common to all sub-projects/modules. buildscript { + + ext.kotlin_version = '1.1.2' + repositories { jcenter() } - dependencies { - classpath 'com.android.tools.build:gradle:1.1.0' + dependencies { + classpath 'com.android.tools.build:gradle:2.3.3' + classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files } diff --git a/gradle/listview-baseadapter-data-object/gradle/wrapper/gradle-wrapper.properties b/gradle/listview-baseadapter-data-object/gradle/wrapper/gradle-wrapper.properties index 0c71e760dc..4cbbe3a25e 100644 --- a/gradle/listview-baseadapter-data-object/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/listview-baseadapter-data-object/gradle/wrapper/gradle-wrapper.properties @@ -1,6 +1,6 @@ -#Wed Apr 10 15:27:10 PDT 2013 +#Thu Jun 15 09:00:23 CEST 2017 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-2.2.1-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip diff --git a/gradle/listview-baseadapter-data-object/listview-baseadapter-data-object.iml b/gradle/listview-baseadapter-data-object/listview-baseadapter-data-object.iml new file mode 100644 index 0000000000..c4dc745411 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/listview-baseadapter-data-object.iml @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.DS_Store b/gradle/okhttp-asynctask/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..356ecd1a6b672e73de837395ff650a1e77d80dce GIT binary patch literal 6148 zcmeHKO>Wab6n@jBtwVvPQl!Gp8zdG1r7aL4gcL%N=mLS13KoD;yS5Umt|y8eq7s6# z;SLB+z*V>a2jKwlz3~)mw?u4;0L_zTzWI6Yn|YsOPlkv@d*p2pRf)(#VJx3Rb&Byk zmlL+2M=k;dbI5%+lrDNqXUr&I6!_Z};CHt~4h?9q6XxFEJD9opO_@qUd%5Fypx^S( z?jQ`}q|x{y7E0yCrDdy9u__m=mz};GcM>NV#cgN!T=fFacXfML%J4_qai0eMxLd8= zmr>#bkw471zjzizo*cL3DDq;(^TbK|h*b-9tCuH}&8^L5-M-PdJ+0f5X0uVZw{G2> zPAzNw%EsNDy~Cr|lQ+}1AJWGl@Rd@ws__^;qM`G9)fq;ijCvSh??rNHL;;2574-Rp z*{nY2e|pk&>d_FYdWiG$abmp?w=~E1UBP!P>x)$eSVf}tfeCi$Q(Rc>Yk^@o$1u)& z6F>9!nPt(*zFAvFpZ1^#6P`1@d^Ft#+#QdFM~RO$)< zEMr(1+Un0g(B=VPOXDm>jKD-13QR+VzG4V{cMxef=3Cl-mSP%CLahuQy|U0Z6rryk z!dC7iS}B^^C}0%GD^NCQYfKlMTQb3fqJKJrfq|eq9$?;ihqwJxu qvEM936@p41$Ev|c@g)>xn6tS7Y-yaOh!L3iBcNn3l~Lf2D)1eYTmq8- literal 0 HcmV?d00001 diff --git a/gradle/okhttp-asynctask/.idea/compiler.xml b/gradle/okhttp-asynctask/.idea/compiler.xml new file mode 100644 index 0000000000..96cc43efa6 --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/compiler.xml @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/copyright/profiles_settings.xml b/gradle/okhttp-asynctask/.idea/copyright/profiles_settings.xml new file mode 100644 index 0000000000..e7bedf3377 --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/copyright/profiles_settings.xml @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/gradle.xml b/gradle/okhttp-asynctask/.idea/gradle.xml new file mode 100644 index 0000000000..7ac24c777f --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/gradle.xml @@ -0,0 +1,18 @@ + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml new file mode 100644 index 0000000000..986b1cda5a --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/annotations_13_0.xml b/gradle/okhttp-asynctask/.idea/libraries/annotations_13_0.xml new file mode 100644 index 0000000000..24c0dcb114 --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/libraries/annotations_13_0.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml new file mode 100644 index 0000000000..9e612993e4 --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml b/gradle/okhttp-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml new file mode 100644 index 0000000000..c0993f57d5 --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/okhttp_2_3_0.xml b/gradle/okhttp-asynctask/.idea/libraries/okhttp_2_3_0.xml new file mode 100644 index 0000000000..e0ed48aea3 --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/libraries/okhttp_2_3_0.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/okio_1_3_0.xml b/gradle/okhttp-asynctask/.idea/libraries/okio_1_3_0.xml new file mode 100644 index 0000000000..93a99cb20a --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/libraries/okio_1_3_0.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/support_annotations_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/support_annotations_25_3_1.xml new file mode 100644 index 0000000000..42adfc6edf --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/libraries/support_annotations_25_3_1.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/support_compat_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/support_compat_25_3_1.xml new file mode 100644 index 0000000000..1dff866919 --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/libraries/support_compat_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/support_core_ui_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/support_core_ui_25_3_1.xml new file mode 100644 index 0000000000..c0bd9753a2 --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/libraries/support_core_ui_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/support_core_utils_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/support_core_utils_25_3_1.xml new file mode 100644 index 0000000000..406ceb21a7 --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/libraries/support_core_utils_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/support_fragment_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/support_fragment_25_3_1.xml new file mode 100644 index 0000000000..a356b6caab --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/libraries/support_fragment_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/support_media_compat_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/support_media_compat_25_3_1.xml new file mode 100644 index 0000000000..543c69e48e --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/libraries/support_media_compat_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/support_v4_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/support_v4_25_3_1.xml new file mode 100644 index 0000000000..8eab02bac5 --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/libraries/support_v4_25_3_1.xml @@ -0,0 +1,10 @@ + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml new file mode 100644 index 0000000000..91427afa49 --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml @@ -0,0 +1,12 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/misc.xml b/gradle/okhttp-asynctask/.idea/misc.xml new file mode 100644 index 0000000000..5403283c7d --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/misc.xml @@ -0,0 +1,62 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Android API 25 Platform + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/modules.xml b/gradle/okhttp-asynctask/.idea/modules.xml new file mode 100644 index 0000000000..3187d3db9f --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/modules.xml @@ -0,0 +1,9 @@ + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/runConfigurations.xml b/gradle/okhttp-asynctask/.idea/runConfigurations.xml new file mode 100644 index 0000000000..7f68460d8b --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/runConfigurations.xml @@ -0,0 +1,12 @@ + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/workspace.xml b/gradle/okhttp-asynctask/.idea/workspace.xml new file mode 100644 index 0000000000..c451ee913f --- /dev/null +++ b/gradle/okhttp-asynctask/.idea/workspace.xml @@ -0,0 +1,2398 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + 1497970657926 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/OkHttp_AsyncTask.iml b/gradle/okhttp-asynctask/OkHttp_AsyncTask.iml new file mode 100644 index 0000000000..ae0ca80f61 --- /dev/null +++ b/gradle/okhttp-asynctask/OkHttp_AsyncTask.iml @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/app/.DS_Store b/gradle/okhttp-asynctask/app/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..3b2e0efa7305c6e7705b833574ad18c738884030 GIT binary patch literal 6148 zcmeHK-A)rh82zR#b{jD^h6KHv8xt>zDIhe2m~1LsaA#5@7eHW_ZD5mSr`aDHtTlV% zOXw5$D!u>@;sfZJpH{jBE{&1-nwc~E%{eojv+d3f5wUI_tP(Ye$U%`g3S?pOK< z)!rJn_^8uqxA^+z#(3;F%g - + @@ -9,12 +9,11 @@ + + + + + + + + + - + - + + - + + - + - + + + + + + + + - + + + + + + + + - + - + - - - - - - - - + + - - + + + - + - - - - - + - + + + + + + + + + + + + - - + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/app/build.gradle b/gradle/okhttp-asynctask/app/build.gradle index 475b2fb948..087fc6d83a 100644 --- a/gradle/okhttp-asynctask/app/build.gradle +++ b/gradle/okhttp-asynctask/app/build.gradle @@ -1,14 +1,15 @@ apply plugin: 'com.android.application' apply plugin: 'kotlin-android' +apply plugin: 'kotlin-android-extensions' android { - compileSdkVersion 22 - buildToolsVersion "22.0.1" + compileSdkVersion 25 + buildToolsVersion "25.0.3" defaultConfig { - applicationId "com.irontec.kotlintest" + applicationId "org.example.kotlin" minSdkVersion 16 - targetSdkVersion 22 + targetSdkVersion 25 versionCode 1 versionName "1.0" } @@ -25,19 +26,11 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:22.0.0' + compile 'com.android.support:appcompat-v7:25.3.1' compile 'com.squareup.okhttp:okhttp:2.3.0' compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" } -buildscript { - ext.kotlin_version = '0.11.91.2' - repositories { - mavenCentral() - } - dependencies { - classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" - } -} + repositories { mavenCentral() } diff --git a/gradle/okhttp-asynctask/app/src/.DS_Store b/gradle/okhttp-asynctask/app/src/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..7fc4e7c0d22ff93a67d2257c8abe2ad3793efb82 GIT binary patch literal 6148 zcmeHK%}T>S5Z-O8CWzRBpx$y3JoJ#ZY7r4at%u%(iXK#IVu}r<+0vv2jgdTuzL78B zFDWkQGs%CVrs@P+Vsu2WJ_o+2RSYqWiK z<@n5jXTBiH-)DgDU5N~cO*|5O+P^)R+k6!w3d!S~I2@{des+ew7e=P}LJP&x-28&3 z>zcl#U3B^^?nHJp4x9GqOgwpR&r$Xa|f<@F?~)oYE4v1RV26(eah%!*Op*-leUTivMcw=V~`cgcPF@F+Kf z!j~#!S>Xhpz{o4S>5KxO1=rx4#82W7kpW}?8JK+r)XAnT&VDIa0WyFL{4fLjd@w*c zS_(6X;^=@uv;cr5a0>xj{Q3hL+yQ7Q%p`&bgvwMvnMzfQK~?8KWjf4TDn64a(+L%C zhIQ1Nsp?RuYCNbR!U?q`;)o0&10NaSy&p)K-~Wf-_x~aY2V?*l_@4~WQmfNyLT&19 zovM=GwFc-VC>I`=Nz7Bg5LYq8@~e0aR0#MDZU9;eGl}2$?4HnDoL59$8b8074yi*K<@A!y=$Ml2L>+{Q3X!2d zmo?~%A4XsiRp=|u{gi^=;=bP(7xuFgH{VTolEhiwXxxfYxia%;)~i;%>YTURK2rU5 z9^}2O6?8wFUL18oXMa#C8QDSjG4AyDYEL&*ng?;(>5hf(e2UXZ^;@c!MwyxCeUKj^ z*DSPGTO16QSC*S~x!QO$tjj^O*{I8v*RO^{&s%uDw7$K6e10*w99~_Uy^_H9Ze-r! zFZc#y#KdX4nY805kBw47fYYd;Gxb@bt_8Gw|;* zpzj9>)#y7cESjqWjd=n9D{vcut$z-6j&$fdEG%LKB5W$qrV97O5H=lt>Ee8cg+-fA z!aY8OTUodliZH8Verdu<_!hZk2AF|K2FkWu)AfJr{`dc668D$^X5hbKKvXu{n=Nd~ z)z+!a=~^qH`%o=9uCO>tfniE9Vs$Bg1~me|)CSOZSXhJy!ao9r25y*vKgz&Q({Xl- literal 0 HcmV?d00001 diff --git a/gradle/okhttp-asynctask/app/src/main/AndroidManifest.xml b/gradle/okhttp-asynctask/app/src/main/AndroidManifest.xml index e609988df0..7eac755c74 100644 --- a/gradle/okhttp-asynctask/app/src/main/AndroidManifest.xml +++ b/gradle/okhttp-asynctask/app/src/main/AndroidManifest.xml @@ -1,6 +1,6 @@ + package="org.example.kotlin" > diff --git a/gradle/okhttp-asynctask/app/src/main/java/.DS_Store b/gradle/okhttp-asynctask/app/src/main/java/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..9bf1062c9bdabc1cf291973ce54e9ee5e3be108a GIT binary patch literal 6148 zcmeHK%}T>S5Z-O8CWx4Wpx$y3JoL~XwTK9z)`%PwNHq5tSH^Ug?)nU8Hn8g?~KqY2O7`_oXFLh2b=*a?dxrVs) z0^z}vT#n>FFd+9X%LE&+ZatXUzayC0{ZOI`!6+|@`nbz)UO(`oxKMcKnQU%pdBreI z!(20N8aINmwwn5NmUHP zcBIxhbK@T5suwk_?a`=IE>-gOUg2<@w?~yqA#axt_Qzwx*xV@|*IRcFkE5sY^NZdJ z4qvH~b;Jq0f`RqjHwIxK!Y+6w(UT}bVt^PR1{Q?@Jl~AfMJb5tAO?tmUt>U?4>qVo z2Qk&Cjt&@93jmk{w-T_`&p)6o9e@sEsu4UOT&Du+RE{kM$KHYKbeMNAKGmqx8CP$H zb@0s`I~0zs2e(x?KTLwN~~y^o@K0 zA4eyXRMhHGQJI0sH#?b0HeZ%x2LMF1+bjbV0Kh@jn8{=FiRgZ<|D zCsL<=G!o5@-^hU8yBq{?1s+_$oBdNh_UO-I19kD41g(*1zt?H`5k)`xttjjyrP7ng zjAh3sa!x+)YbLZsZ z`lf$7xVxv7fWWVoWZL2o9?h@|Mu7QKLv5a3@`)#lL3*f z)oWE;o4s2{R;lk=iF$&nMaQKEUsKSas~BVTRXm4Ef_|wDMAu?!5IrdTBS188!wmc= F11~soUt|CP literal 0 HcmV?d00001 diff --git a/gradle/okhttp-asynctask/app/src/main/java/org/example/.DS_Store b/gradle/okhttp-asynctask/app/src/main/java/org/example/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..58482d5adebe3668d7b91cf243fdb3f83498ed6b GIT binary patch literal 6148 zcmeHKF-`+P474Fak!VsUWY4b8 zvzwdZ9GjW1-yUzwR%W(@6Yan-H$JD&?5r{lgyW1Sd)W=+!+sd|v+C0caxd)JMtim4 z8=pVw7JmH^cKQHirGONW0#ZNnS z3P^!t1Zn@E;1?b*9v?BfO{LY literal 0 HcmV?d00001 diff --git a/gradle/okhttp-asynctask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt b/gradle/okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt similarity index 63% rename from gradle/okhttp-asynctask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt rename to gradle/okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt index 92739aa0b9..c5bba3d08d 100644 --- a/gradle/okhttp-asynctask/app/src/main/java/com/irontec/kotlintest/MainActivity.kt +++ b/gradle/okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt @@ -1,70 +1,60 @@ -package com.irontec.kotlintest +package org.example.kotlin import android.os.AsyncTask -import android.support.v7.app.ActionBarActivity import android.os.Bundle -import android.util.Log +import android.support.v7.app.AppCompatActivity import android.view.Menu import android.view.MenuItem import android.widget.TextView -import com.irontec.kotlintest.networking.NetworkClient -import org.json.JSONObject +import kotlinx.android.synthetic.main.activity_main.* +import org.example.kotlin.networking.NetworkClient import java.io.BufferedInputStream import java.io.BufferedReader import java.io.InputStreamReader -import java.net.HttpURLConnection -import java.net.URL - - -public class MainActivity : ActionBarActivity() { - - open val mTextView: TextView - get() { - return findViewById(R.id.text) as TextView - } +class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) - GetJsonWithOkHttpClient(mTextView).execute() + GetJsonWithOkHttpClient(this.text).execute() } - open class GetJsonWithOkHttpClient(textView: TextView) : AsyncTask() { + open class GetJsonWithOkHttpClient(textView: TextView) : AsyncTask() { val mInnerTextView = textView - override fun doInBackground(vararg params: Void?): String? { + override fun doInBackground(vararg params: Unit?): String? { val networkClient = NetworkClient() val stream = BufferedInputStream( networkClient.get("https://raw.githubusercontent.com/irontec/android-kotlin-samples/master/common-data/bilbao.json")) - return readStream(stream); + return readStream(stream) } override fun onPostExecute(result: String?) { super.onPostExecute(result) - mInnerTextView.setText(result) + mInnerTextView.text = result } fun readStream(inputStream: BufferedInputStream): String { - val bufferedReader = BufferedReader(InputStreamReader(inputStream)); - val stringBuilder = StringBuilder(); + val bufferedReader = BufferedReader(InputStreamReader(inputStream)) + val stringBuilder = StringBuilder() bufferedReader.forEachLine { stringBuilder.append(it) } return stringBuilder.toString() } } override fun onCreateOptionsMenu(menu: Menu): Boolean { - getMenuInflater().inflate(R.menu.menu_main, menu) + menuInflater.inflate(R.menu.menu_main, menu) return true } override fun onOptionsItemSelected(item: MenuItem): Boolean { - val id = item.getItemId() + val id = item.itemId if (id == R.id.action_settings) { return true } diff --git a/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt b/gradle/okhttp-asynctask/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt similarity index 93% rename from gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt rename to gradle/okhttp-asynctask/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt index 87830ead49..469d8df3d9 100644 --- a/gradle/anko-simple-ui/app/src/main/java/com/irontec/kotlintest/networking/NetworkClient.kt +++ b/gradle/okhttp-asynctask/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt @@ -1,4 +1,4 @@ -package com.irontec.kotlintest.networking +package org.example.kotlin.networking import com.squareup.okhttp.OkHttpClient import com.squareup.okhttp.Request diff --git a/gradle/okhttp-asynctask/build.gradle b/gradle/okhttp-asynctask/build.gradle index d3ff69d6e7..e6c80a40c6 100644 --- a/gradle/okhttp-asynctask/build.gradle +++ b/gradle/okhttp-asynctask/build.gradle @@ -1,12 +1,16 @@ // Top-level build file where you can add configuration options common to all sub-projects/modules. buildscript { + + ext.kotlin_version = '1.1.2' + repositories { jcenter() } - dependencies { - classpath 'com.android.tools.build:gradle:1.1.0' + dependencies { + classpath 'com.android.tools.build:gradle:2.3.3' + classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files } diff --git a/gradle/okhttp-asynctask/gradle/wrapper/gradle-wrapper.properties b/gradle/okhttp-asynctask/gradle/wrapper/gradle-wrapper.properties index 0c71e760dc..7dba5460c2 100644 --- a/gradle/okhttp-asynctask/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/okhttp-asynctask/gradle/wrapper/gradle-wrapper.properties @@ -1,6 +1,6 @@ -#Wed Apr 10 15:27:10 PDT 2013 +#Thu Jun 15 09:09:03 CEST 2017 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-2.2.1-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip diff --git a/gradle/okhttp-asynctask/okhttp-asynctask.iml b/gradle/okhttp-asynctask/okhttp-asynctask.iml new file mode 100644 index 0000000000..6df630a4bb --- /dev/null +++ b/gradle/okhttp-asynctask/okhttp-asynctask.iml @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file From 862e0da0cdaae46f830764673ba1dbac606f33bd Mon Sep 17 00:00:00 2001 From: Axier Fernandez Date: Tue, 20 Jun 2017 17:03:33 +0200 Subject: [PATCH 3/9] .iml removal --- .../Anko_asynchronous_tasks.iml | 36 ------------------- .../anko-asynchronous-tasks.iml | 36 ------------------- gradle/anko-simple-ui/Anko_simple_ui.iml | 36 ------------------- gradle/anko-simple-ui/MyApplication.iml | 19 ---------- gradle/anko-simple-ui/anko-simple-ui.iml | 36 ------------------- .../MyApplication.iml | 19 ---------- .../Gson_deserializers_OkHttp_AsyncTask.iml | 36 ------------------- .../gson-deserializers-okhttp-asynctask.iml | 36 ------------------- .../HttpUrlConnection_AsyncTask.iml | 36 ------------------- .../MyApplication.iml | 19 ---------- .../httpurlconnection-asynctask.iml | 36 ------------------- .../ListView_BaseAdapter_Data_Object.iml | 36 ------------------- .../MyApplication.iml | 19 ---------- .../listview-baseadapter-data-object.iml | 36 ------------------- gradle/okhttp-asynctask/MyApplication.iml | 19 ---------- gradle/okhttp-asynctask/OkHttp_AsyncTask.iml | 36 ------------------- gradle/okhttp-asynctask/okhttp-asynctask.iml | 36 ------------------- 17 files changed, 527 deletions(-) delete mode 100644 gradle/anko-asynchronous-tasks/Anko_asynchronous_tasks.iml delete mode 100644 gradle/anko-asynchronous-tasks/anko-asynchronous-tasks.iml delete mode 100644 gradle/anko-simple-ui/Anko_simple_ui.iml delete mode 100644 gradle/anko-simple-ui/MyApplication.iml delete mode 100644 gradle/anko-simple-ui/anko-simple-ui.iml delete mode 100644 gradle/gson-deserializers-okhttp-asyncTask/MyApplication.iml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/Gson_deserializers_OkHttp_AsyncTask.iml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/gson-deserializers-okhttp-asynctask.iml delete mode 100644 gradle/httpurlconnection-asynctask/HttpUrlConnection_AsyncTask.iml delete mode 100644 gradle/httpurlconnection-asynctask/MyApplication.iml delete mode 100644 gradle/httpurlconnection-asynctask/httpurlconnection-asynctask.iml delete mode 100644 gradle/listview-baseadapter-data-object/ListView_BaseAdapter_Data_Object.iml delete mode 100644 gradle/listview-baseadapter-data-object/MyApplication.iml delete mode 100644 gradle/listview-baseadapter-data-object/listview-baseadapter-data-object.iml delete mode 100644 gradle/okhttp-asynctask/MyApplication.iml delete mode 100644 gradle/okhttp-asynctask/OkHttp_AsyncTask.iml delete mode 100644 gradle/okhttp-asynctask/okhttp-asynctask.iml diff --git a/gradle/anko-asynchronous-tasks/Anko_asynchronous_tasks.iml b/gradle/anko-asynchronous-tasks/Anko_asynchronous_tasks.iml deleted file mode 100644 index d476d69463..0000000000 --- a/gradle/anko-asynchronous-tasks/Anko_asynchronous_tasks.iml +++ /dev/null @@ -1,36 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/anko-asynchronous-tasks.iml b/gradle/anko-asynchronous-tasks/anko-asynchronous-tasks.iml deleted file mode 100644 index b18040896f..0000000000 --- a/gradle/anko-asynchronous-tasks/anko-asynchronous-tasks.iml +++ /dev/null @@ -1,36 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/Anko_simple_ui.iml b/gradle/anko-simple-ui/Anko_simple_ui.iml deleted file mode 100644 index c38d04ae80..0000000000 --- a/gradle/anko-simple-ui/Anko_simple_ui.iml +++ /dev/null @@ -1,36 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/MyApplication.iml b/gradle/anko-simple-ui/MyApplication.iml deleted file mode 100644 index 960784f551..0000000000 --- a/gradle/anko-simple-ui/MyApplication.iml +++ /dev/null @@ -1,19 +0,0 @@ - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/anko-simple-ui.iml b/gradle/anko-simple-ui/anko-simple-ui.iml deleted file mode 100644 index b08184cf5c..0000000000 --- a/gradle/anko-simple-ui/anko-simple-ui.iml +++ /dev/null @@ -1,36 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asyncTask/MyApplication.iml b/gradle/gson-deserializers-okhttp-asyncTask/MyApplication.iml deleted file mode 100644 index 0bb6048ae0..0000000000 --- a/gradle/gson-deserializers-okhttp-asyncTask/MyApplication.iml +++ /dev/null @@ -1,19 +0,0 @@ - - - - - - - - - - - - - - - - - - diff --git a/gradle/gson-deserializers-okhttp-asynctask/Gson_deserializers_OkHttp_AsyncTask.iml b/gradle/gson-deserializers-okhttp-asynctask/Gson_deserializers_OkHttp_AsyncTask.iml deleted file mode 100644 index c5d3524d90..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/Gson_deserializers_OkHttp_AsyncTask.iml +++ /dev/null @@ -1,36 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/gson-deserializers-okhttp-asynctask.iml b/gradle/gson-deserializers-okhttp-asynctask/gson-deserializers-okhttp-asynctask.iml deleted file mode 100644 index d609cdb283..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/gson-deserializers-okhttp-asynctask.iml +++ /dev/null @@ -1,36 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/HttpUrlConnection_AsyncTask.iml b/gradle/httpurlconnection-asynctask/HttpUrlConnection_AsyncTask.iml deleted file mode 100644 index 0c0d564962..0000000000 --- a/gradle/httpurlconnection-asynctask/HttpUrlConnection_AsyncTask.iml +++ /dev/null @@ -1,36 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/MyApplication.iml b/gradle/httpurlconnection-asynctask/MyApplication.iml deleted file mode 100644 index 0bb6048ae0..0000000000 --- a/gradle/httpurlconnection-asynctask/MyApplication.iml +++ /dev/null @@ -1,19 +0,0 @@ - - - - - - - - - - - - - - - - - - diff --git a/gradle/httpurlconnection-asynctask/httpurlconnection-asynctask.iml b/gradle/httpurlconnection-asynctask/httpurlconnection-asynctask.iml deleted file mode 100644 index 7693cd4805..0000000000 --- a/gradle/httpurlconnection-asynctask/httpurlconnection-asynctask.iml +++ /dev/null @@ -1,36 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/ListView_BaseAdapter_Data_Object.iml b/gradle/listview-baseadapter-data-object/ListView_BaseAdapter_Data_Object.iml deleted file mode 100644 index fde7cffa04..0000000000 --- a/gradle/listview-baseadapter-data-object/ListView_BaseAdapter_Data_Object.iml +++ /dev/null @@ -1,36 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/MyApplication.iml b/gradle/listview-baseadapter-data-object/MyApplication.iml deleted file mode 100644 index 0bb6048ae0..0000000000 --- a/gradle/listview-baseadapter-data-object/MyApplication.iml +++ /dev/null @@ -1,19 +0,0 @@ - - - - - - - - - - - - - - - - - - diff --git a/gradle/listview-baseadapter-data-object/listview-baseadapter-data-object.iml b/gradle/listview-baseadapter-data-object/listview-baseadapter-data-object.iml deleted file mode 100644 index c4dc745411..0000000000 --- a/gradle/listview-baseadapter-data-object/listview-baseadapter-data-object.iml +++ /dev/null @@ -1,36 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/MyApplication.iml b/gradle/okhttp-asynctask/MyApplication.iml deleted file mode 100644 index 0bb6048ae0..0000000000 --- a/gradle/okhttp-asynctask/MyApplication.iml +++ /dev/null @@ -1,19 +0,0 @@ - - - - - - - - - - - - - - - - - - diff --git a/gradle/okhttp-asynctask/OkHttp_AsyncTask.iml b/gradle/okhttp-asynctask/OkHttp_AsyncTask.iml deleted file mode 100644 index ae0ca80f61..0000000000 --- a/gradle/okhttp-asynctask/OkHttp_AsyncTask.iml +++ /dev/null @@ -1,36 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/okhttp-asynctask.iml b/gradle/okhttp-asynctask/okhttp-asynctask.iml deleted file mode 100644 index 6df630a4bb..0000000000 --- a/gradle/okhttp-asynctask/okhttp-asynctask.iml +++ /dev/null @@ -1,36 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file From 7586d4f011b0409a4a8a1a7983cdb67386e515e6 Mon Sep 17 00:00:00 2001 From: Axier Fernandez Date: Tue, 20 Jun 2017 17:10:11 +0200 Subject: [PATCH 4/9] Changed the common data url to JetBrains/kotlin-examples --- gradle/anko-asynchronous-tasks/.idea/misc.xml | 2 +- .../.idea/workspace.xml | 98 ++++++++++----- .../anko-asynchronous-tasks.iml | 35 ++++++ gradle/anko-asynchronous-tasks/app/app.iml | 14 +-- .../java/org/example/kotlin/MainActivity.kt | 2 +- gradle/anko-simple-ui/.idea/misc.xml | 2 +- gradle/anko-simple-ui/.idea/workspace.xml | 89 +++++++------ gradle/anko-simple-ui/anko-simple-ui.iml | 35 ++++++ .../java/org/example/kotlin/MainActivity.kt | 2 +- .../app/app.iml | 14 +-- .../.idea/misc.xml | 2 +- .../.idea/workspace.xml | 118 +++++++++++++----- .../java/org/example/kotlin/MainActivity.kt | 2 +- .../gson-deserializers-okhttp-asynctask.iml | 35 ++++++ .../.idea/misc.xml | 2 +- .../.idea/workspace.xml | 78 +++++++----- .../httpurlconnection-asynctask/app/app.iml | 1 - .../java/org/example/kotlin/MainActivity.kt | 2 +- .../httpurlconnection-asynctask.iml | 35 ++++++ .../.idea/misc.xml | 2 +- .../.idea/workspace.xml | 84 +++++++++---- .../app/app.iml | 14 +-- .../listview-baseadapter-data-object.iml | 35 ++++++ gradle/okhttp-asynctask/.idea/misc.xml | 2 +- gradle/okhttp-asynctask/.idea/workspace.xml | 98 ++++++++++----- gradle/okhttp-asynctask/app/app.iml | 6 - .../java/org/example/kotlin/MainActivity.kt | 2 +- gradle/okhttp-asynctask/okhttp-asynctask.iml | 35 ++++++ 28 files changed, 621 insertions(+), 225 deletions(-) create mode 100644 gradle/anko-asynchronous-tasks/anko-asynchronous-tasks.iml create mode 100644 gradle/anko-simple-ui/anko-simple-ui.iml create mode 100644 gradle/gson-deserializers-okhttp-asynctask/gson-deserializers-okhttp-asynctask.iml create mode 100644 gradle/httpurlconnection-asynctask/httpurlconnection-asynctask.iml create mode 100644 gradle/listview-baseadapter-data-object/listview-baseadapter-data-object.iml create mode 100644 gradle/okhttp-asynctask/okhttp-asynctask.iml diff --git a/gradle/anko-asynchronous-tasks/.idea/misc.xml b/gradle/anko-asynchronous-tasks/.idea/misc.xml index 5403283c7d..7c32224c17 100644 --- a/gradle/anko-asynchronous-tasks/.idea/misc.xml +++ b/gradle/anko-asynchronous-tasks/.idea/misc.xml @@ -37,7 +37,7 @@ - + diff --git a/gradle/anko-asynchronous-tasks/.idea/workspace.xml b/gradle/anko-asynchronous-tasks/.idea/workspace.xml index f3e52772f1..5aaa861892 100644 --- a/gradle/anko-asynchronous-tasks/.idea/workspace.xml +++ b/gradle/anko-asynchronous-tasks/.idea/workspace.xml @@ -31,7 +31,7 @@ - + @@ -42,17 +42,19 @@ - + - - - + + + + + - + @@ -2002,7 +2004,8 @@ - + + @@ -2125,8 +2128,7 @@ - - + @@ -2349,32 +2351,32 @@ - - - - - - + + + + + + - - + + - - + + - + - + + - - + - - + + @@ -2393,16 +2395,42 @@ - + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -2436,19 +2464,21 @@ - + - + - + - - - + + + + + diff --git a/gradle/anko-asynchronous-tasks/anko-asynchronous-tasks.iml b/gradle/anko-asynchronous-tasks/anko-asynchronous-tasks.iml new file mode 100644 index 0000000000..5a6ba2d41b --- /dev/null +++ b/gradle/anko-asynchronous-tasks/anko-asynchronous-tasks.iml @@ -0,0 +1,35 @@ + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/app/app.iml b/gradle/anko-asynchronous-tasks/app/app.iml index 4dae90b53e..f9b1c8b780 100644 --- a/gradle/anko-asynchronous-tasks/app/app.iml +++ b/gradle/anko-asynchronous-tasks/app/app.iml @@ -80,13 +80,6 @@ - - - - - - - @@ -94,6 +87,13 @@ + + + + + + + diff --git a/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/MainActivity.kt b/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/MainActivity.kt index db22a238de..6dc0fe5461 100644 --- a/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/MainActivity.kt +++ b/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/MainActivity.kt @@ -38,7 +38,7 @@ class MainActivity : AppCompatActivity() { // Heavy duty work made on the background val networkClient = NetworkClient() val stream = BufferedInputStream( - networkClient.get("https://raw.githubusercontent.com/irontec/android-kotlin-samples/master/common-data/bilbao.json")) + networkClient.get("https://raw.githubusercontent.com/JetBrains/kotlin-examples/master/common-data/bilbao.json")) val bufferedReader = BufferedReader(InputStreamReader(stream)); val stringBuilder = StringBuilder() bufferedReader.forEachLine { stringBuilder.append(it) } diff --git a/gradle/anko-simple-ui/.idea/misc.xml b/gradle/anko-simple-ui/.idea/misc.xml index 5403283c7d..7c32224c17 100644 --- a/gradle/anko-simple-ui/.idea/misc.xml +++ b/gradle/anko-simple-ui/.idea/misc.xml @@ -37,7 +37,7 @@ - + diff --git a/gradle/anko-simple-ui/.idea/workspace.xml b/gradle/anko-simple-ui/.idea/workspace.xml index 18095bcee5..6e21e4c722 100644 --- a/gradle/anko-simple-ui/.idea/workspace.xml +++ b/gradle/anko-simple-ui/.idea/workspace.xml @@ -31,7 +31,7 @@ - + @@ -42,17 +42,16 @@ - - + + - - - + + + + + - - - @@ -1994,6 +1993,9 @@ + + + @@ -2116,9 +2118,6 @@ - - - @@ -2342,32 +2341,32 @@ - - - - - - + + + + + + - - + + - - + + - + - + + - - + - - + + @@ -2394,6 +2393,14 @@ + + + + + + + + @@ -2430,23 +2437,33 @@ - + + + + - - + + - + - - + + - - + + + + + + + + + diff --git a/gradle/anko-simple-ui/anko-simple-ui.iml b/gradle/anko-simple-ui/anko-simple-ui.iml new file mode 100644 index 0000000000..b1b487d617 --- /dev/null +++ b/gradle/anko-simple-ui/anko-simple-ui.iml @@ -0,0 +1,35 @@ + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/MainActivity.kt b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/MainActivity.kt index 96dd03e651..f287b1dd24 100644 --- a/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/MainActivity.kt +++ b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/MainActivity.kt @@ -47,7 +47,7 @@ class MainActivity : AppCompatActivity() { override fun doInBackground(vararg params: Unit?): String? { val networkClient = NetworkClient() val stream = BufferedInputStream( - networkClient.get("https://raw.githubusercontent.com/irontec/android-kotlin-samples/master/common-data/bilbao.json")) + networkClient.get("https://raw.githubusercontent.com/JetBrains/kotlin-examples/master/common-data/bilbao.json")) return readStream(stream) } diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/app.iml b/gradle/gson-deserializers-okhttp-asyncTask/app/app.iml index 52dc392329..0bd117584e 100644 --- a/gradle/gson-deserializers-okhttp-asyncTask/app/app.iml +++ b/gradle/gson-deserializers-okhttp-asyncTask/app/app.iml @@ -80,13 +80,6 @@ - - - - - - - @@ -94,6 +87,13 @@ + + + + + + + diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/misc.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/misc.xml index 5403283c7d..7c32224c17 100644 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/misc.xml +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/misc.xml @@ -37,7 +37,7 @@ - + diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/workspace.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/workspace.xml index 699ec47081..a67a075914 100644 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/workspace.xml +++ b/gradle/gson-deserializers-okhttp-asynctask/.idea/workspace.xml @@ -36,7 +36,7 @@ - + @@ -50,9 +50,11 @@ - - - + + + + + @@ -80,7 +82,7 @@ - + @@ -2038,10 +2040,8 @@ - - - + @@ -2164,6 +2164,8 @@ + + @@ -2386,32 +2388,32 @@ - - - - - - + + + + + + - - + + - - + + - + - + + - - + - - + + @@ -2430,16 +2432,68 @@ - + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -2475,7 +2529,7 @@ - + @@ -2485,9 +2539,11 @@ - - - + + + + + diff --git a/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt index 30855b56e6..56cfb05cb3 100644 --- a/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt +++ b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt @@ -34,7 +34,7 @@ class MainActivity : AppCompatActivity() { override fun doInBackground(vararg params: Unit?): String? { val networkClient = NetworkClient() val stream = BufferedInputStream( - networkClient.get("https://raw.githubusercontent.com/irontec/android-kotlin-samples/master/common-data/bilbao.json")) + networkClient.get("https://raw.githubusercontent.com/JetBrains/kotlin-examples/master/common-data/bilbao.json")) return readStream(stream) } diff --git a/gradle/gson-deserializers-okhttp-asynctask/gson-deserializers-okhttp-asynctask.iml b/gradle/gson-deserializers-okhttp-asynctask/gson-deserializers-okhttp-asynctask.iml new file mode 100644 index 0000000000..670c5b9d04 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/gson-deserializers-okhttp-asynctask.iml @@ -0,0 +1,35 @@ + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/misc.xml b/gradle/httpurlconnection-asynctask/.idea/misc.xml index 5403283c7d..7c32224c17 100644 --- a/gradle/httpurlconnection-asynctask/.idea/misc.xml +++ b/gradle/httpurlconnection-asynctask/.idea/misc.xml @@ -37,7 +37,7 @@ - + diff --git a/gradle/httpurlconnection-asynctask/.idea/workspace.xml b/gradle/httpurlconnection-asynctask/.idea/workspace.xml index 579d30554c..78d837bea3 100644 --- a/gradle/httpurlconnection-asynctask/.idea/workspace.xml +++ b/gradle/httpurlconnection-asynctask/.idea/workspace.xml @@ -31,7 +31,7 @@ - + @@ -45,9 +45,11 @@ - - - + + + + + @@ -1987,10 +1989,9 @@ - - + @@ -2047,6 +2048,7 @@ + @@ -2269,32 +2271,32 @@ - - - - - - + + + + + + - - + + - - + + - + - + + - - + - - + + @@ -2313,16 +2315,34 @@ - + - - + + + + + + + + + + + + + + + + + + + + @@ -2334,9 +2354,11 @@ - - - + + + + + diff --git a/gradle/httpurlconnection-asynctask/app/app.iml b/gradle/httpurlconnection-asynctask/app/app.iml index 2b64af71fd..0bd305ab8c 100644 --- a/gradle/httpurlconnection-asynctask/app/app.iml +++ b/gradle/httpurlconnection-asynctask/app/app.iml @@ -100,7 +100,6 @@ - diff --git a/gradle/httpurlconnection-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt b/gradle/httpurlconnection-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt index 970cfec0c1..0513f27f46 100644 --- a/gradle/httpurlconnection-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt +++ b/gradle/httpurlconnection-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt @@ -29,7 +29,7 @@ class MainActivity : AppCompatActivity() { val innerTextView: TextView? = textView override fun doInBackground(vararg params: Unit?): String? { - val url = URL("https://raw.githubusercontent.com/irontec/android-kotlin-samples/master/common-data/bilbao.json") + val url = URL("https://raw.githubusercontent.com/JetBrains/kotlin-examples/master/common-data/bilbao.json") val httpClient = url.openConnection() as HttpURLConnection if (httpClient.responseCode == HttpURLConnection.HTTP_OK) { try { diff --git a/gradle/httpurlconnection-asynctask/httpurlconnection-asynctask.iml b/gradle/httpurlconnection-asynctask/httpurlconnection-asynctask.iml new file mode 100644 index 0000000000..2caa7e91a5 --- /dev/null +++ b/gradle/httpurlconnection-asynctask/httpurlconnection-asynctask.iml @@ -0,0 +1,35 @@ + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/misc.xml b/gradle/listview-baseadapter-data-object/.idea/misc.xml index 5403283c7d..7c32224c17 100644 --- a/gradle/listview-baseadapter-data-object/.idea/misc.xml +++ b/gradle/listview-baseadapter-data-object/.idea/misc.xml @@ -37,7 +37,7 @@ - + diff --git a/gradle/listview-baseadapter-data-object/.idea/workspace.xml b/gradle/listview-baseadapter-data-object/.idea/workspace.xml index 25b3a44930..3b1e0b0a4b 100644 --- a/gradle/listview-baseadapter-data-object/.idea/workspace.xml +++ b/gradle/listview-baseadapter-data-object/.idea/workspace.xml @@ -36,13 +36,15 @@ - + - - - + + + + + @@ -2004,6 +2006,7 @@ + @@ -2107,7 +2110,6 @@ - @@ -2330,32 +2332,32 @@ - - - - - - + + + + + + - - + + - - + + - + - + + - - + - - + + @@ -2374,16 +2376,42 @@ - + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -2411,9 +2439,11 @@ - - - + + + + + diff --git a/gradle/listview-baseadapter-data-object/app/app.iml b/gradle/listview-baseadapter-data-object/app/app.iml index 944f6c92bf..0bd305ab8c 100644 --- a/gradle/listview-baseadapter-data-object/app/app.iml +++ b/gradle/listview-baseadapter-data-object/app/app.iml @@ -80,13 +80,6 @@ - - - - - - - @@ -94,6 +87,13 @@ + + + + + + + diff --git a/gradle/listview-baseadapter-data-object/listview-baseadapter-data-object.iml b/gradle/listview-baseadapter-data-object/listview-baseadapter-data-object.iml new file mode 100644 index 0000000000..676e8ec4b9 --- /dev/null +++ b/gradle/listview-baseadapter-data-object/listview-baseadapter-data-object.iml @@ -0,0 +1,35 @@ + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/misc.xml b/gradle/okhttp-asynctask/.idea/misc.xml index 5403283c7d..7c32224c17 100644 --- a/gradle/okhttp-asynctask/.idea/misc.xml +++ b/gradle/okhttp-asynctask/.idea/misc.xml @@ -37,7 +37,7 @@ - + diff --git a/gradle/okhttp-asynctask/.idea/workspace.xml b/gradle/okhttp-asynctask/.idea/workspace.xml index c451ee913f..486c74dfb7 100644 --- a/gradle/okhttp-asynctask/.idea/workspace.xml +++ b/gradle/okhttp-asynctask/.idea/workspace.xml @@ -31,7 +31,7 @@ - + @@ -44,23 +44,25 @@ + + + - - - - - - + + + + + @@ -2011,6 +2013,10 @@ + + + + @@ -2089,10 +2095,6 @@ - - - - @@ -2315,32 +2317,32 @@ - - - - - - + + + + + + - - + + - - + + - + - + + - - + - - + + @@ -2374,9 +2376,43 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -2388,9 +2424,11 @@ - - - + + + + + diff --git a/gradle/okhttp-asynctask/app/app.iml b/gradle/okhttp-asynctask/app/app.iml index 5688c99b6a..7521bee476 100644 --- a/gradle/okhttp-asynctask/app/app.iml +++ b/gradle/okhttp-asynctask/app/app.iml @@ -94,19 +94,13 @@ - - - - - - diff --git a/gradle/okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt b/gradle/okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt index c5bba3d08d..0ef69e69b0 100644 --- a/gradle/okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt +++ b/gradle/okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt @@ -29,7 +29,7 @@ class MainActivity : AppCompatActivity() { override fun doInBackground(vararg params: Unit?): String? { val networkClient = NetworkClient() val stream = BufferedInputStream( - networkClient.get("https://raw.githubusercontent.com/irontec/android-kotlin-samples/master/common-data/bilbao.json")) + networkClient.get("https://raw.githubusercontent.com/JetBrains/kotlin-examples/master/common-data/bilbao.json")) return readStream(stream) } diff --git a/gradle/okhttp-asynctask/okhttp-asynctask.iml b/gradle/okhttp-asynctask/okhttp-asynctask.iml new file mode 100644 index 0000000000..3191790291 --- /dev/null +++ b/gradle/okhttp-asynctask/okhttp-asynctask.iml @@ -0,0 +1,35 @@ + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file From 653eb6eb554740a41eefdac359d550a23a9d0d1e Mon Sep 17 00:00:00 2001 From: Axier Fernandez Date: Tue, 20 Jun 2017 17:19:40 +0200 Subject: [PATCH 5/9] gitignore for Android, AndroidStudio and macOS --- gradle/anko-asynchronous-tasks/.DS_Store | Bin 6148 -> 0 bytes gradle/anko-asynchronous-tasks/.gitignore | 174 +- .../.idea/compiler.xml | 22 - .../.idea/copyright/profiles_settings.xml | 3 - .../anko-asynchronous-tasks/.idea/gradle.xml | 18 - .../animated_vector_drawable_25_3_1.xml | 12 - .../libraries/anko_appcompat_v7_0_9_1.xml | 11 - .../.idea/libraries/anko_common_0_9_1.xml | 11 - .../.idea/libraries/anko_sdk15_0_9_1.xml | 11 - .../.idea/libraries/anko_support_v4_0_9_1.xml | 11 - .../.idea/libraries/annotations_13_0.xml | 11 - .../.idea/libraries/appcompat_v7_25_3_1.xml | 12 - .../.idea/libraries/gson_2_7.xml | 11 - .../.idea/libraries/kotlin_stdlib_1_1_2.xml | 11 - .../.idea/libraries/okhttp_2_3_0.xml | 11 - .../.idea/libraries/okio_1_3_0.xml | 11 - .../libraries/support_annotations_25_3_1.xml | 11 - .../.idea/libraries/support_compat_25_3_1.xml | 12 - .../libraries/support_core_ui_25_3_1.xml | 12 - .../libraries/support_core_utils_25_3_1.xml | 12 - .../libraries/support_fragment_25_3_1.xml | 12 - .../libraries/support_media_compat_25_3_1.xml | 12 - .../.idea/libraries/support_v4_25_3_1.xml | 10 - .../support_vector_drawable_25_3_1.xml | 12 - gradle/anko-asynchronous-tasks/.idea/misc.xml | 62 - .../anko-asynchronous-tasks/.idea/modules.xml | 9 - .../.idea/workspace.xml | 2486 ---------------- .../anko-asynchronous-tasks/MyApplication.iml | 19 - .../anko-asynchronous-tasks.iml | 35 - gradle/anko-asynchronous-tasks/app/.DS_Store | Bin 6148 -> 0 bytes gradle/anko-asynchronous-tasks/app/app.iml | 131 - .../anko-asynchronous-tasks/app/src/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/java/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/java/org/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/java/org/example/.DS_Store | Bin 6148 -> 0 bytes gradle/anko-simple-ui/.DS_Store | Bin 6148 -> 0 bytes gradle/anko-simple-ui/.gitignore | 174 +- gradle/anko-simple-ui/.idea/compiler.xml | 22 - .../.idea/copyright/profiles_settings.xml | 3 - gradle/anko-simple-ui/.idea/gradle.xml | 18 - .../animated_vector_drawable_25_3_1.xml | 12 - .../libraries/anko_appcompat_v7_0_9_1.xml | 11 - .../.idea/libraries/anko_common_0_9_1.xml | 11 - .../.idea/libraries/anko_sdk15_0_9_1.xml | 11 - .../.idea/libraries/anko_support_v4_0_9_1.xml | 11 - .../.idea/libraries/annotations_13_0.xml | 11 - .../.idea/libraries/appcompat_v7_25_3_1.xml | 12 - .../.idea/libraries/gson_2_7.xml | 11 - .../.idea/libraries/kotlin_stdlib_1_1_2.xml | 11 - .../.idea/libraries/okhttp_2_3_0.xml | 11 - .../.idea/libraries/okio_1_3_0.xml | 11 - .../libraries/support_annotations_25_3_1.xml | 11 - .../.idea/libraries/support_compat_25_3_1.xml | 12 - .../libraries/support_core_ui_25_3_1.xml | 12 - .../libraries/support_core_utils_25_3_1.xml | 12 - .../libraries/support_fragment_25_3_1.xml | 12 - .../libraries/support_media_compat_25_3_1.xml | 12 - .../.idea/libraries/support_v4_25_3_1.xml | 10 - .../support_vector_drawable_25_3_1.xml | 12 - gradle/anko-simple-ui/.idea/misc.xml | 62 - gradle/anko-simple-ui/.idea/modules.xml | 9 - gradle/anko-simple-ui/.idea/workspace.xml | 2470 ---------------- gradle/anko-simple-ui/anko-simple-ui.iml | 35 - gradle/anko-simple-ui/app/.DS_Store | Bin 6148 -> 0 bytes gradle/anko-simple-ui/app/app.iml | 131 - gradle/anko-simple-ui/app/src/.DS_Store | Bin 6148 -> 0 bytes gradle/anko-simple-ui/app/src/main/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/java/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/java/org/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/java/org/example/.DS_Store | Bin 6148 -> 0 bytes .../.gitignore | 27 - .../app/app.iml | 127 - .../.DS_Store | Bin 6148 -> 0 bytes .../.gitignore | 197 ++ .../.idea/compiler.xml | 22 - .../.idea/copyright/profiles_settings.xml | 3 - .../.idea/gradle.xml | 18 - .../animated_vector_drawable_25_3_1.xml | 12 - .../.idea/libraries/annotations_13_0.xml | 11 - .../.idea/libraries/appcompat_v7_25_3_1.xml | 12 - .../.idea/libraries/gson_2_7.xml | 11 - .../.idea/libraries/kotlin_stdlib_1_1_2.xml | 11 - .../.idea/libraries/okhttp_2_3_0.xml | 11 - .../.idea/libraries/okio_1_3_0.xml | 11 - .../libraries/support_annotations_25_3_1.xml | 11 - .../.idea/libraries/support_compat_25_3_1.xml | 12 - .../libraries/support_core_ui_25_3_1.xml | 12 - .../libraries/support_core_utils_25_3_1.xml | 12 - .../libraries/support_fragment_25_3_1.xml | 12 - .../libraries/support_media_compat_25_3_1.xml | 12 - .../.idea/libraries/support_v4_25_3_1.xml | 10 - .../support_vector_drawable_25_3_1.xml | 12 - .../.idea/misc.xml | 62 - .../.idea/modules.xml | 9 - .../.idea/workspace.xml | 2551 ----------------- .../app/.DS_Store | Bin 6148 -> 0 bytes .../app/.gitignore | 0 .../app/build.gradle | 0 .../app/proguard-rules.pro | 0 .../app/src/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/AndroidManifest.xml | 0 .../app/src/main/java/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/java/org/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/java/org/example/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/res/layout/activity_main.xml | 0 .../app/src/main/res/menu/menu_main.xml | 0 .../src/main/res/mipmap-hdpi/ic_launcher.png | Bin .../src/main/res/mipmap-mdpi/ic_launcher.png | Bin .../src/main/res/mipmap-xhdpi/ic_launcher.png | Bin .../main/res/mipmap-xxhdpi/ic_launcher.png | Bin .../app/src/main/res/values-w820dp/dimens.xml | 0 .../app/src/main/res/values/dimens.xml | 0 .../app/src/main/res/values/strings.xml | 0 .../app/src/main/res/values/styles.xml | 0 .../build.gradle | 0 .../gradle.properties | 0 .../gradle/wrapper/gradle-wrapper.jar | Bin .../gradle/wrapper/gradle-wrapper.properties | 0 .../gradlew | 0 .../gradlew.bat | 0 .../gson-deserializers-okhttp-asynctask.iml | 35 - .../settings.gradle | 0 gradle/httpurlconnection-asynctask/.DS_Store | Bin 6148 -> 0 bytes gradle/httpurlconnection-asynctask/.gitignore | 174 +- .../.idea/compiler.xml | 22 - .../.idea/copyright/profiles_settings.xml | 3 - .../.idea/gradle.xml | 18 - .../animated_vector_drawable_25_3_1.xml | 12 - .../.idea/libraries/annotations_13_0.xml | 11 - .../.idea/libraries/appcompat_v7_25_3_1.xml | 12 - .../.idea/libraries/kotlin_stdlib_1_1_2.xml | 11 - .../libraries/support_annotations_25_3_1.xml | 11 - .../.idea/libraries/support_compat_25_3_1.xml | 12 - .../libraries/support_core_ui_25_3_1.xml | 12 - .../libraries/support_core_utils_25_3_1.xml | 12 - .../libraries/support_fragment_25_3_1.xml | 12 - .../libraries/support_media_compat_25_3_1.xml | 12 - .../.idea/libraries/support_v4_25_3_1.xml | 10 - .../support_vector_drawable_25_3_1.xml | 12 - .../.idea/misc.xml | 62 - .../.idea/modules.xml | 9 - .../.idea/workspace.xml | 2366 --------------- .../httpurlconnection-asynctask/app/.DS_Store | Bin 6148 -> 0 bytes .../httpurlconnection-asynctask/app/app.iml | 123 - .../app/src/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/java/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/java/org/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/java/org/example/.DS_Store | Bin 6148 -> 0 bytes .../httpurlconnection-asynctask.iml | 35 - .../.DS_Store | Bin 6148 -> 0 bytes .../.gitignore | 174 +- .../.idea/compiler.xml | 22 - .../.idea/copyright/profiles_settings.xml | 3 - .../.idea/gradle.xml | 18 - .../animated_vector_drawable_25_3_1.xml | 12 - .../.idea/libraries/annotations_13_0.xml | 11 - .../.idea/libraries/appcompat_v7_25_3_1.xml | 12 - .../.idea/libraries/kotlin_stdlib_1_1_2.xml | 11 - .../libraries/support_annotations_25_3_1.xml | 11 - .../.idea/libraries/support_compat_25_3_1.xml | 12 - .../libraries/support_core_ui_25_3_1.xml | 12 - .../libraries/support_core_utils_25_3_1.xml | 12 - .../libraries/support_fragment_25_3_1.xml | 12 - .../libraries/support_media_compat_25_3_1.xml | 12 - .../.idea/libraries/support_v4_25_3_1.xml | 10 - .../support_vector_drawable_25_3_1.xml | 12 - .../.idea/misc.xml | 62 - .../.idea/modules.xml | 9 - .../.idea/workspace.xml | 2451 ---------------- .../app/.DS_Store | Bin 6148 -> 0 bytes .../app/app.iml | 123 - .../app/src/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/java/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/java/org/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/java/org/example/.DS_Store | Bin 6148 -> 0 bytes .../listview-baseadapter-data-object.iml | 35 - gradle/okhttp-asynctask/.DS_Store | Bin 6148 -> 0 bytes gradle/okhttp-asynctask/.gitignore | 174 +- gradle/okhttp-asynctask/.idea/compiler.xml | 22 - .../.idea/copyright/profiles_settings.xml | 3 - gradle/okhttp-asynctask/.idea/gradle.xml | 18 - .../animated_vector_drawable_25_3_1.xml | 12 - .../.idea/libraries/annotations_13_0.xml | 11 - .../.idea/libraries/appcompat_v7_25_3_1.xml | 12 - .../.idea/libraries/kotlin_stdlib_1_1_2.xml | 11 - .../.idea/libraries/okhttp_2_3_0.xml | 11 - .../.idea/libraries/okio_1_3_0.xml | 11 - .../libraries/support_annotations_25_3_1.xml | 11 - .../.idea/libraries/support_compat_25_3_1.xml | 12 - .../libraries/support_core_ui_25_3_1.xml | 12 - .../libraries/support_core_utils_25_3_1.xml | 12 - .../libraries/support_fragment_25_3_1.xml | 12 - .../libraries/support_media_compat_25_3_1.xml | 12 - .../.idea/libraries/support_v4_25_3_1.xml | 10 - .../support_vector_drawable_25_3_1.xml | 12 - gradle/okhttp-asynctask/.idea/misc.xml | 62 - gradle/okhttp-asynctask/.idea/modules.xml | 9 - gradle/okhttp-asynctask/.idea/workspace.xml | 2436 ---------------- gradle/okhttp-asynctask/app/.DS_Store | Bin 6148 -> 0 bytes gradle/okhttp-asynctask/app/app.iml | 125 - gradle/okhttp-asynctask/app/src/.DS_Store | Bin 6148 -> 0 bytes .../okhttp-asynctask/app/src/main/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/java/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/java/org/.DS_Store | Bin 6148 -> 0 bytes .../app/src/main/java/org/example/.DS_Store | Bin 6148 -> 0 bytes gradle/okhttp-asynctask/okhttp-asynctask.iml | 35 - 210 files changed, 1057 insertions(+), 17513 deletions(-) delete mode 100644 gradle/anko-asynchronous-tasks/.DS_Store delete mode 100644 gradle/anko-asynchronous-tasks/.idea/compiler.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/copyright/profiles_settings.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/gradle.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/animated_vector_drawable_25_3_1.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/anko_appcompat_v7_0_9_1.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/anko_common_0_9_1.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/anko_sdk15_0_9_1.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/anko_support_v4_0_9_1.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/annotations_13_0.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/appcompat_v7_25_3_1.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/gson_2_7.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/kotlin_stdlib_1_1_2.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/okhttp_2_3_0.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/okio_1_3_0.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/support_annotations_25_3_1.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/support_compat_25_3_1.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/support_core_ui_25_3_1.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/support_core_utils_25_3_1.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/support_fragment_25_3_1.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/support_media_compat_25_3_1.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/support_v4_25_3_1.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/libraries/support_vector_drawable_25_3_1.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/misc.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/modules.xml delete mode 100644 gradle/anko-asynchronous-tasks/.idea/workspace.xml delete mode 100644 gradle/anko-asynchronous-tasks/MyApplication.iml delete mode 100644 gradle/anko-asynchronous-tasks/anko-asynchronous-tasks.iml delete mode 100644 gradle/anko-asynchronous-tasks/app/.DS_Store delete mode 100644 gradle/anko-asynchronous-tasks/app/app.iml delete mode 100644 gradle/anko-asynchronous-tasks/app/src/.DS_Store delete mode 100644 gradle/anko-asynchronous-tasks/app/src/main/.DS_Store delete mode 100644 gradle/anko-asynchronous-tasks/app/src/main/java/.DS_Store delete mode 100644 gradle/anko-asynchronous-tasks/app/src/main/java/org/.DS_Store delete mode 100644 gradle/anko-asynchronous-tasks/app/src/main/java/org/example/.DS_Store delete mode 100644 gradle/anko-simple-ui/.DS_Store delete mode 100644 gradle/anko-simple-ui/.idea/compiler.xml delete mode 100644 gradle/anko-simple-ui/.idea/copyright/profiles_settings.xml delete mode 100644 gradle/anko-simple-ui/.idea/gradle.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/animated_vector_drawable_25_3_1.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/anko_appcompat_v7_0_9_1.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/anko_common_0_9_1.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/anko_sdk15_0_9_1.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/anko_support_v4_0_9_1.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/annotations_13_0.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/appcompat_v7_25_3_1.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/gson_2_7.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/kotlin_stdlib_1_1_2.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/okhttp_2_3_0.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/okio_1_3_0.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/support_annotations_25_3_1.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/support_compat_25_3_1.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/support_core_ui_25_3_1.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/support_core_utils_25_3_1.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/support_fragment_25_3_1.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/support_media_compat_25_3_1.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/support_v4_25_3_1.xml delete mode 100644 gradle/anko-simple-ui/.idea/libraries/support_vector_drawable_25_3_1.xml delete mode 100644 gradle/anko-simple-ui/.idea/misc.xml delete mode 100644 gradle/anko-simple-ui/.idea/modules.xml delete mode 100644 gradle/anko-simple-ui/.idea/workspace.xml delete mode 100644 gradle/anko-simple-ui/anko-simple-ui.iml delete mode 100644 gradle/anko-simple-ui/app/.DS_Store delete mode 100644 gradle/anko-simple-ui/app/app.iml delete mode 100644 gradle/anko-simple-ui/app/src/.DS_Store delete mode 100644 gradle/anko-simple-ui/app/src/main/.DS_Store delete mode 100644 gradle/anko-simple-ui/app/src/main/java/.DS_Store delete mode 100644 gradle/anko-simple-ui/app/src/main/java/org/.DS_Store delete mode 100644 gradle/anko-simple-ui/app/src/main/java/org/example/.DS_Store delete mode 100644 gradle/gson-deserializers-okhttp-asyncTask/.gitignore delete mode 100644 gradle/gson-deserializers-okhttp-asyncTask/app/app.iml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.DS_Store create mode 100644 gradle/gson-deserializers-okhttp-asynctask/.gitignore delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/compiler.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/copyright/profiles_settings.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/gradle.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/annotations_13_0.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/gson_2_7.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/okhttp_2_3_0.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/okio_1_3_0.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_annotations_25_3_1.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_compat_25_3_1.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_core_ui_25_3_1.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_core_utils_25_3_1.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_fragment_25_3_1.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_media_compat_25_3_1.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_v4_25_3_1.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/misc.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/modules.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/.idea/workspace.xml delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/app/.DS_Store rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/app/.gitignore (100%) rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/app/build.gradle (100%) rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/app/proguard-rules.pro (100%) delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/app/src/.DS_Store delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/app/src/main/.DS_Store rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/app/src/main/AndroidManifest.xml (100%) delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/.DS_Store delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/.DS_Store delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/.DS_Store rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/app/src/main/res/layout/activity_main.xml (100%) rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/app/src/main/res/menu/menu_main.xml (100%) rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/app/src/main/res/mipmap-hdpi/ic_launcher.png (100%) rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/app/src/main/res/mipmap-mdpi/ic_launcher.png (100%) rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/app/src/main/res/mipmap-xhdpi/ic_launcher.png (100%) rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/app/src/main/res/mipmap-xxhdpi/ic_launcher.png (100%) rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/app/src/main/res/values-w820dp/dimens.xml (100%) rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/app/src/main/res/values/dimens.xml (100%) rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/app/src/main/res/values/strings.xml (100%) rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/app/src/main/res/values/styles.xml (100%) rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/build.gradle (100%) rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/gradle.properties (100%) rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/gradle/wrapper/gradle-wrapper.jar (100%) rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/gradle/wrapper/gradle-wrapper.properties (100%) rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/gradlew (100%) rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/gradlew.bat (100%) delete mode 100644 gradle/gson-deserializers-okhttp-asynctask/gson-deserializers-okhttp-asynctask.iml rename gradle/{gson-deserializers-okhttp-asyncTask => gson-deserializers-okhttp-asynctask}/settings.gradle (100%) delete mode 100644 gradle/httpurlconnection-asynctask/.DS_Store delete mode 100644 gradle/httpurlconnection-asynctask/.idea/compiler.xml delete mode 100644 gradle/httpurlconnection-asynctask/.idea/copyright/profiles_settings.xml delete mode 100644 gradle/httpurlconnection-asynctask/.idea/gradle.xml delete mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml delete mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/annotations_13_0.xml delete mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml delete mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml delete mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/support_annotations_25_3_1.xml delete mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/support_compat_25_3_1.xml delete mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/support_core_ui_25_3_1.xml delete mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/support_core_utils_25_3_1.xml delete mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/support_fragment_25_3_1.xml delete mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/support_media_compat_25_3_1.xml delete mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/support_v4_25_3_1.xml delete mode 100644 gradle/httpurlconnection-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml delete mode 100644 gradle/httpurlconnection-asynctask/.idea/misc.xml delete mode 100644 gradle/httpurlconnection-asynctask/.idea/modules.xml delete mode 100644 gradle/httpurlconnection-asynctask/.idea/workspace.xml delete mode 100644 gradle/httpurlconnection-asynctask/app/.DS_Store delete mode 100644 gradle/httpurlconnection-asynctask/app/app.iml delete mode 100644 gradle/httpurlconnection-asynctask/app/src/.DS_Store delete mode 100644 gradle/httpurlconnection-asynctask/app/src/main/.DS_Store delete mode 100644 gradle/httpurlconnection-asynctask/app/src/main/java/.DS_Store delete mode 100644 gradle/httpurlconnection-asynctask/app/src/main/java/org/.DS_Store delete mode 100644 gradle/httpurlconnection-asynctask/app/src/main/java/org/example/.DS_Store delete mode 100644 gradle/httpurlconnection-asynctask/httpurlconnection-asynctask.iml delete mode 100644 gradle/listview-baseadapter-data-object/.DS_Store delete mode 100644 gradle/listview-baseadapter-data-object/.idea/compiler.xml delete mode 100644 gradle/listview-baseadapter-data-object/.idea/copyright/profiles_settings.xml delete mode 100644 gradle/listview-baseadapter-data-object/.idea/gradle.xml delete mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/animated_vector_drawable_25_3_1.xml delete mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/annotations_13_0.xml delete mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/appcompat_v7_25_3_1.xml delete mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/kotlin_stdlib_1_1_2.xml delete mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/support_annotations_25_3_1.xml delete mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/support_compat_25_3_1.xml delete mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/support_core_ui_25_3_1.xml delete mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/support_core_utils_25_3_1.xml delete mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/support_fragment_25_3_1.xml delete mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/support_media_compat_25_3_1.xml delete mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/support_v4_25_3_1.xml delete mode 100644 gradle/listview-baseadapter-data-object/.idea/libraries/support_vector_drawable_25_3_1.xml delete mode 100644 gradle/listview-baseadapter-data-object/.idea/misc.xml delete mode 100644 gradle/listview-baseadapter-data-object/.idea/modules.xml delete mode 100644 gradle/listview-baseadapter-data-object/.idea/workspace.xml delete mode 100644 gradle/listview-baseadapter-data-object/app/.DS_Store delete mode 100644 gradle/listview-baseadapter-data-object/app/app.iml delete mode 100644 gradle/listview-baseadapter-data-object/app/src/.DS_Store delete mode 100644 gradle/listview-baseadapter-data-object/app/src/main/.DS_Store delete mode 100644 gradle/listview-baseadapter-data-object/app/src/main/java/.DS_Store delete mode 100644 gradle/listview-baseadapter-data-object/app/src/main/java/org/.DS_Store delete mode 100644 gradle/listview-baseadapter-data-object/app/src/main/java/org/example/.DS_Store delete mode 100644 gradle/listview-baseadapter-data-object/listview-baseadapter-data-object.iml delete mode 100644 gradle/okhttp-asynctask/.DS_Store delete mode 100644 gradle/okhttp-asynctask/.idea/compiler.xml delete mode 100644 gradle/okhttp-asynctask/.idea/copyright/profiles_settings.xml delete mode 100644 gradle/okhttp-asynctask/.idea/gradle.xml delete mode 100644 gradle/okhttp-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml delete mode 100644 gradle/okhttp-asynctask/.idea/libraries/annotations_13_0.xml delete mode 100644 gradle/okhttp-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml delete mode 100644 gradle/okhttp-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml delete mode 100644 gradle/okhttp-asynctask/.idea/libraries/okhttp_2_3_0.xml delete mode 100644 gradle/okhttp-asynctask/.idea/libraries/okio_1_3_0.xml delete mode 100644 gradle/okhttp-asynctask/.idea/libraries/support_annotations_25_3_1.xml delete mode 100644 gradle/okhttp-asynctask/.idea/libraries/support_compat_25_3_1.xml delete mode 100644 gradle/okhttp-asynctask/.idea/libraries/support_core_ui_25_3_1.xml delete mode 100644 gradle/okhttp-asynctask/.idea/libraries/support_core_utils_25_3_1.xml delete mode 100644 gradle/okhttp-asynctask/.idea/libraries/support_fragment_25_3_1.xml delete mode 100644 gradle/okhttp-asynctask/.idea/libraries/support_media_compat_25_3_1.xml delete mode 100644 gradle/okhttp-asynctask/.idea/libraries/support_v4_25_3_1.xml delete mode 100644 gradle/okhttp-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml delete mode 100644 gradle/okhttp-asynctask/.idea/misc.xml delete mode 100644 gradle/okhttp-asynctask/.idea/modules.xml delete mode 100644 gradle/okhttp-asynctask/.idea/workspace.xml delete mode 100644 gradle/okhttp-asynctask/app/.DS_Store delete mode 100644 gradle/okhttp-asynctask/app/app.iml delete mode 100644 gradle/okhttp-asynctask/app/src/.DS_Store delete mode 100644 gradle/okhttp-asynctask/app/src/main/.DS_Store delete mode 100644 gradle/okhttp-asynctask/app/src/main/java/.DS_Store delete mode 100644 gradle/okhttp-asynctask/app/src/main/java/org/.DS_Store delete mode 100644 gradle/okhttp-asynctask/app/src/main/java/org/example/.DS_Store delete mode 100644 gradle/okhttp-asynctask/okhttp-asynctask.iml diff --git a/gradle/anko-asynchronous-tasks/.DS_Store b/gradle/anko-asynchronous-tasks/.DS_Store deleted file mode 100644 index aaceada73d98280034e3a8241daba9e46ffc63e5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK-EPw`6h2l-k?mz z_6f>&D4O*k)oTyqD070y@8#5AJ`W-<9<<_q-WU$IwznEJ`)++_RI`VT zM!jZl-@i8+S=Rck%?AgEr)O`5Z%6MwGI=;qaiU6D)%X)Wp`clK-R?zU937*EwHL|7 zS_Kr6H^I+)wC305@^4M7<}p^XG36a%8X-`;Ow zO8Rb{njGJ?Hqs#y3+s&)N)u%II+g{#imxL{L7UA5U{m8*A!;DzM?lhGGQ+?>W#9*R C)(Ce1 diff --git a/gradle/anko-asynchronous-tasks/.gitignore b/gradle/anko-asynchronous-tasks/.gitignore index ccf2efe026..93deb134e3 100644 --- a/gradle/anko-asynchronous-tasks/.gitignore +++ b/gradle/anko-asynchronous-tasks/.gitignore @@ -1,8 +1,12 @@ + +# Created by https://www.gitignore.io/api/android,androidstudio,macos + +### Android ### # Built application files *.apk *.ap_ -# Files for the Dalvik VM +# Files for the ART/Dalvik VM *.dex # Java class files @@ -11,11 +15,11 @@ # Generated files bin/ gen/ +out/ # Gradle files .gradle/ build/ -/*/build/ # Local configuration file (sdk path, etc) local.properties @@ -25,3 +29,169 @@ proguard/ # Log Files *.log + +# Android Studio Navigation editor temp files +.navigation/ + +# Android Studio captures folder +captures/ + +# Intellij +*.iml +.idea/workspace.xml +.idea/tasks.xml +.idea/gradle.xml +.idea/dictionaries +.idea/libraries + +# Keystore files +*.jks + +# External native build folder generated in Android Studio 2.2 and later +.externalNativeBuild + +# Google Services (e.g. APIs or Firebase) +google-services.json + +# Freeline +freeline.py +freeline/ +freeline_project_description.json + +### Android Patch ### +gen-external-apklibs + +### AndroidStudio ### +# Covers files to be ignored for android development using Android Studio. + +# Built application files + +# Files for the ART/Dalvik VM + +# Java class files + +# Generated files + +# Gradle files +.gradle + +# Signing files +.signing/ + +# Local configuration file (sdk path, etc) + +# Proguard folder generated by Eclipse + +# Log Files + +# Android Studio +/*/build/ +/*/local.properties +/*/out +/*/*/build +/*/*/production +*.ipr +*~ +*.swp + +# Android Patch + +# External native build folder generated in Android Studio 2.2 and later + +# NDK +obj/ + +# IntelliJ IDEA +*.iws +/out/ + +# User-specific configurations +.idea/libraries/ +.idea/.name +.idea/compiler.xml +.idea/copyright/profiles_settings.xml +.idea/encodings.xml +.idea/misc.xml +.idea/modules.xml +.idea/scopes/scope_settings.xml +.idea/vcs.xml +.idea/jsLibraryMappings.xml +.idea/datasources.xml +.idea/dataSources.ids +.idea/sqlDataSources.xml +.idea/dynamic.xml +.idea/uiDesigner.xml + +# Keystore files + +# OS-specific files +.DS_Store +.DS_Store? +._* +.Spotlight-V100 +.Trashes +ehthumbs.db +Thumbs.db + +# Legacy Eclipse project files +.classpath +.project + +# Mobile Tools for Java (J2ME) +.mtj.tmp/ + +# Package Files # +*.jar +*.war +*.ear + +# virtual machine crash logs (Reference: http://www.java.com/en/download/help/error_hotspot.xml) +hs_err_pid* + +## Plugin-specific files: + +# mpeltonen/sbt-idea plugin +.idea_modules/ + +# JIRA plugin +atlassian-ide-plugin.xml + +# Mongo Explorer plugin +.idea/mongoSettings.xml + +# Crashlytics plugin (for Android Studio and IntelliJ) +com_crashlytics_export_strings.xml +crashlytics.properties +crashlytics-build.properties +fabric.properties + +### AndroidStudio Patch ### +# Google Services plugin + +!/gradle/wrapper/gradle-wrapper.jar + +### macOS ### +*.DS_Store +.AppleDouble +.LSOverride + +# Icon must end with two \r +Icon + +# Thumbnails + +# Files that might appear in the root of a volume +.DocumentRevisions-V100 +.fseventsd +.TemporaryItems +.VolumeIcon.icns +.com.apple.timemachine.donotpresent + +# Directories potentially created on remote AFP share +.AppleDB +.AppleDesktop +Network Trash Folder +Temporary Items +.apdisk + +# End of https://www.gitignore.io/api/android,androidstudio,macos diff --git a/gradle/anko-asynchronous-tasks/.idea/compiler.xml b/gradle/anko-asynchronous-tasks/.idea/compiler.xml deleted file mode 100644 index 96cc43efa6..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/compiler.xml +++ /dev/null @@ -1,22 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/copyright/profiles_settings.xml b/gradle/anko-asynchronous-tasks/.idea/copyright/profiles_settings.xml deleted file mode 100644 index e7bedf3377..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/copyright/profiles_settings.xml +++ /dev/null @@ -1,3 +0,0 @@ - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/gradle.xml b/gradle/anko-asynchronous-tasks/.idea/gradle.xml deleted file mode 100644 index 7ac24c777f..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/gradle.xml +++ /dev/null @@ -1,18 +0,0 @@ - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/animated_vector_drawable_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/animated_vector_drawable_25_3_1.xml deleted file mode 100644 index 986b1cda5a..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/animated_vector_drawable_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/anko_appcompat_v7_0_9_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/anko_appcompat_v7_0_9_1.xml deleted file mode 100644 index 8563a7f435..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/anko_appcompat_v7_0_9_1.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/anko_common_0_9_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/anko_common_0_9_1.xml deleted file mode 100644 index 89174fc128..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/anko_common_0_9_1.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/anko_sdk15_0_9_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/anko_sdk15_0_9_1.xml deleted file mode 100644 index 044ee0ce95..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/anko_sdk15_0_9_1.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/anko_support_v4_0_9_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/anko_support_v4_0_9_1.xml deleted file mode 100644 index ec9c330215..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/anko_support_v4_0_9_1.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/annotations_13_0.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/annotations_13_0.xml deleted file mode 100644 index 24c0dcb114..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/annotations_13_0.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/appcompat_v7_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/appcompat_v7_25_3_1.xml deleted file mode 100644 index 9e612993e4..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/appcompat_v7_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/gson_2_7.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/gson_2_7.xml deleted file mode 100644 index 22607550e1..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/gson_2_7.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/kotlin_stdlib_1_1_2.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/kotlin_stdlib_1_1_2.xml deleted file mode 100644 index c0993f57d5..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/kotlin_stdlib_1_1_2.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/okhttp_2_3_0.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/okhttp_2_3_0.xml deleted file mode 100644 index e0ed48aea3..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/okhttp_2_3_0.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/okio_1_3_0.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/okio_1_3_0.xml deleted file mode 100644 index 93a99cb20a..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/okio_1_3_0.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/support_annotations_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/support_annotations_25_3_1.xml deleted file mode 100644 index 42adfc6edf..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/support_annotations_25_3_1.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/support_compat_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/support_compat_25_3_1.xml deleted file mode 100644 index 1dff866919..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/support_compat_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/support_core_ui_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/support_core_ui_25_3_1.xml deleted file mode 100644 index c0bd9753a2..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/support_core_ui_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/support_core_utils_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/support_core_utils_25_3_1.xml deleted file mode 100644 index 406ceb21a7..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/support_core_utils_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/support_fragment_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/support_fragment_25_3_1.xml deleted file mode 100644 index a356b6caab..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/support_fragment_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/support_media_compat_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/support_media_compat_25_3_1.xml deleted file mode 100644 index 543c69e48e..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/support_media_compat_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/support_v4_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/support_v4_25_3_1.xml deleted file mode 100644 index 8eab02bac5..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/support_v4_25_3_1.xml +++ /dev/null @@ -1,10 +0,0 @@ - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/libraries/support_vector_drawable_25_3_1.xml b/gradle/anko-asynchronous-tasks/.idea/libraries/support_vector_drawable_25_3_1.xml deleted file mode 100644 index 91427afa49..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/libraries/support_vector_drawable_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/misc.xml b/gradle/anko-asynchronous-tasks/.idea/misc.xml deleted file mode 100644 index 7c32224c17..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/misc.xml +++ /dev/null @@ -1,62 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Android API 25 Platform - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/modules.xml b/gradle/anko-asynchronous-tasks/.idea/modules.xml deleted file mode 100644 index 57f5055c7e..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/modules.xml +++ /dev/null @@ -1,9 +0,0 @@ - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/.idea/workspace.xml b/gradle/anko-asynchronous-tasks/.idea/workspace.xml deleted file mode 100644 index 5aaa861892..0000000000 --- a/gradle/anko-asynchronous-tasks/.idea/workspace.xml +++ /dev/null @@ -1,2486 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 1497970037697 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/MyApplication.iml b/gradle/anko-asynchronous-tasks/MyApplication.iml deleted file mode 100644 index 960784f551..0000000000 --- a/gradle/anko-asynchronous-tasks/MyApplication.iml +++ /dev/null @@ -1,19 +0,0 @@ - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/anko-asynchronous-tasks.iml b/gradle/anko-asynchronous-tasks/anko-asynchronous-tasks.iml deleted file mode 100644 index 5a6ba2d41b..0000000000 --- a/gradle/anko-asynchronous-tasks/anko-asynchronous-tasks.iml +++ /dev/null @@ -1,35 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/app/.DS_Store b/gradle/anko-asynchronous-tasks/app/.DS_Store deleted file mode 100644 index 3b2e0efa7305c6e7705b833574ad18c738884030..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK-A)rh82zR#b{jD^h6KHv8xt>zDIhe2m~1LsaA#5@7eHW_ZD5mSr`aDHtTlV% zOXw5$D!u>@;sfZJpH{jBE{&1-nwc~E%{eojv+d3f5wUI_tP(Ye$U%`g3S?pOK< z)!rJn_^8uqxA^+z#(3;F%g - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/app/src/.DS_Store b/gradle/anko-asynchronous-tasks/app/src/.DS_Store deleted file mode 100644 index 7fc4e7c0d22ff93a67d2257c8abe2ad3793efb82..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK%}T>S5Z-O8CWzRBpx$y3JoJ#ZY7r4at%u%(iXK#IVu}r<+0vv2jgdTuzL78B zFDWkQGs%CVrs@P+Vsu2WJ_o+2RSYqWiK z<@n5jXTBiH-)DgDU5N~cO*|5O+P^)R+k6!w3d!S~I2@{des+ew7e=P}LJP&x-28&3 z>zcl#U3B^^?nHJp4x9GqOgwpR&r$Xa|f<@F?~)oYE4v1RV26(eah%!*Op*-leUTivMcw=V~`cgcPF@F+Kf z!j~#!S>Xhpz{o4S>5KxO1=rx4#82W7kpW}?8JK+r)XAnT&VDIa0WyFL{4fLjd@w*c zS_(6X;^=@uv;cr5a0>xj{Q3hL+yQ7Q%p`&bgvwMvnMzfQK~?8KWjf4TDn64a(+L%C zhIQ1Nsp?RuYCNbR!U?q`;)o0&10NaSy&p)K-~Wf-_x~aY2V?*l_@4~WQmfNyLT&19 zovM=GwFc-VC>I`=Nz7Bg5LYq8@~e0aR0#MDZU9;eGl}2$?4HnDoL59$8b8074yi*K<@A!y=$Ml2L>+{Q3X!2d zmo?~%A4XsiRp=|u{gi^=;=bP(7xuFgH{VTolEhiwXxxfYxia%;)~i;%>YTURK2rU5 z9^}2O6?8wFUL18oXMa#C8QDSjG4AyDYEL&*ng?;(>5hf(e2UXZ^;@c!MwyxCeUKj^ z*DSPGTO16QSC*S~x!QO$tjj^O*{I8v*RO^{&s%uDw7$K6e10*w99~_Uy^_H9Ze-r! zFZc#y#KdX4nY805kBw47fYYd;Gxb@bt_8Gw|;* zpzj9>)#y7cESjqWjd=n9D{vcut$z-6j&$fdEG%LKB5W$qrV97O5H=lt>Ee8cg+-fA z!aY8OTUodliZH8Verdu<_!hZk2AF|K2FkWu)AfJr{`dc668D$^X5hbKKvXu{n=Nd~ z)z+!a=~^qH`%o=9uCO>tfniE9Vs$Bg1~me|)CSOZSXhJy!ao9r25y*vKgz&Q({Xl- diff --git a/gradle/anko-asynchronous-tasks/app/src/main/java/.DS_Store b/gradle/anko-asynchronous-tasks/app/src/main/java/.DS_Store deleted file mode 100644 index 9bf1062c9bdabc1cf291973ce54e9ee5e3be108a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK%}T>S5Z-O8CWx4Wpx$y3JoL~XwTK9z)`%PwNHq5tSH^Ug?)nU8Hn8g?~KqY2O7`_oXFLh2b=*a?dxrVs) z0^z}vT#n>FFd+9X%LE&+ZatXUzayC0{ZOI`!6+|@`nbz)UO(`oxKMcKnQU%pdBreI z!(20N8aINmwwn5NmUHP zcBIxhbK@T5suwk_?a`=IE>-gOUg2<@w?~yqA#axt_Qzwx*xV@|*IRcFkE5sY^NZdJ z4qvH~b;Jq0f`RqjHwIxK!Y+6w(UT}bVt^PR1{Q?@Jl~AfMJb5tAO?tmUt>U?4>qVo z2Qk&Cjt&@93jmk{w-T_`&p)6o9e@sEsu4UOT&Du+RE{kM$KHYKbeMNAKGmqx8CP$H zb@0s`I~0zs2e(x?KTLwN~~y^o@K0 zA4eyXRMhHGQJI0sH#?b0HeZ%x2LMF1+bjbV0Kh@jn8{=FiRgZ<|D zCsL<=G!o5@-^hU8yBq{?1s+_$oBdNh_UO-I19kD41g(*1zt?H`5k)`xttjjyrP7ng zjAh3sa!x+)YbLZsZ z`lf$7xVxv7fWWVoWZL2o9?h@|Mu7QKLv5a3@`)#lL3*f z)oWE;o4s2{R;lk=iF$&nMaQKEUsKSas~BVTRXm4Ef_|wDMAu?!5IrdTBS188!wmc= F11~soUt|CP diff --git a/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/.DS_Store b/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/.DS_Store deleted file mode 100644 index 49dad4bec286fdd25284bcd6eed692077da5bcef..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK%}T>S5T0$Trij>spx*W(c<7<^uZRet)z7vPIk^Yt6iyXE%xG0yX>`2=qYG4eQO^o6%K9BKMI=NdTwD)MX?t|&DN*z)8im& zsBT$xqDGtgIq>2u%%y?qx#eDOZGEkjmm7uceqQ!Ur9xh=Z*BJbj4T>8b?{)Y+)kM;~!IndDxSgndK( z`O_!~(bi|0R_#%%Wgl3WwMVN)?OrEF&R@Z#m`%`nlo|srzYlZ zpZZ`mz`WRI{WyMUGR&|V8(jGM9-|3@ZMojxPdPv7u*I1MA5GhYQI*FA&e^-Df;TSxv zVlRYXgsl>cA%oqCGr}B|tkIoQ6}<|bl~avkom&Ph1OFled_K5HjBSmR0@cxhOg#aB zRa7fMnST%1#?{!?I4KY<5K)){3sa$=7@{yoy{q-w8Ycx7<|OpvL+HptzfgpV4*#xF zC($m@=9U4=K$(F`@mc5l|G~-c|FV(&vJ6-T{woGVb-TOW!I1RbIx{%FYh9#WBo@}2 o6sSy)>FZb(_$t1Hqy%j)7l3VzlLAo#u|EQe2Af$1{wM?A06Z@Mm;e9( diff --git a/gradle/anko-simple-ui/.gitignore b/gradle/anko-simple-ui/.gitignore index ccf2efe026..93deb134e3 100644 --- a/gradle/anko-simple-ui/.gitignore +++ b/gradle/anko-simple-ui/.gitignore @@ -1,8 +1,12 @@ + +# Created by https://www.gitignore.io/api/android,androidstudio,macos + +### Android ### # Built application files *.apk *.ap_ -# Files for the Dalvik VM +# Files for the ART/Dalvik VM *.dex # Java class files @@ -11,11 +15,11 @@ # Generated files bin/ gen/ +out/ # Gradle files .gradle/ build/ -/*/build/ # Local configuration file (sdk path, etc) local.properties @@ -25,3 +29,169 @@ proguard/ # Log Files *.log + +# Android Studio Navigation editor temp files +.navigation/ + +# Android Studio captures folder +captures/ + +# Intellij +*.iml +.idea/workspace.xml +.idea/tasks.xml +.idea/gradle.xml +.idea/dictionaries +.idea/libraries + +# Keystore files +*.jks + +# External native build folder generated in Android Studio 2.2 and later +.externalNativeBuild + +# Google Services (e.g. APIs or Firebase) +google-services.json + +# Freeline +freeline.py +freeline/ +freeline_project_description.json + +### Android Patch ### +gen-external-apklibs + +### AndroidStudio ### +# Covers files to be ignored for android development using Android Studio. + +# Built application files + +# Files for the ART/Dalvik VM + +# Java class files + +# Generated files + +# Gradle files +.gradle + +# Signing files +.signing/ + +# Local configuration file (sdk path, etc) + +# Proguard folder generated by Eclipse + +# Log Files + +# Android Studio +/*/build/ +/*/local.properties +/*/out +/*/*/build +/*/*/production +*.ipr +*~ +*.swp + +# Android Patch + +# External native build folder generated in Android Studio 2.2 and later + +# NDK +obj/ + +# IntelliJ IDEA +*.iws +/out/ + +# User-specific configurations +.idea/libraries/ +.idea/.name +.idea/compiler.xml +.idea/copyright/profiles_settings.xml +.idea/encodings.xml +.idea/misc.xml +.idea/modules.xml +.idea/scopes/scope_settings.xml +.idea/vcs.xml +.idea/jsLibraryMappings.xml +.idea/datasources.xml +.idea/dataSources.ids +.idea/sqlDataSources.xml +.idea/dynamic.xml +.idea/uiDesigner.xml + +# Keystore files + +# OS-specific files +.DS_Store +.DS_Store? +._* +.Spotlight-V100 +.Trashes +ehthumbs.db +Thumbs.db + +# Legacy Eclipse project files +.classpath +.project + +# Mobile Tools for Java (J2ME) +.mtj.tmp/ + +# Package Files # +*.jar +*.war +*.ear + +# virtual machine crash logs (Reference: http://www.java.com/en/download/help/error_hotspot.xml) +hs_err_pid* + +## Plugin-specific files: + +# mpeltonen/sbt-idea plugin +.idea_modules/ + +# JIRA plugin +atlassian-ide-plugin.xml + +# Mongo Explorer plugin +.idea/mongoSettings.xml + +# Crashlytics plugin (for Android Studio and IntelliJ) +com_crashlytics_export_strings.xml +crashlytics.properties +crashlytics-build.properties +fabric.properties + +### AndroidStudio Patch ### +# Google Services plugin + +!/gradle/wrapper/gradle-wrapper.jar + +### macOS ### +*.DS_Store +.AppleDouble +.LSOverride + +# Icon must end with two \r +Icon + +# Thumbnails + +# Files that might appear in the root of a volume +.DocumentRevisions-V100 +.fseventsd +.TemporaryItems +.VolumeIcon.icns +.com.apple.timemachine.donotpresent + +# Directories potentially created on remote AFP share +.AppleDB +.AppleDesktop +Network Trash Folder +Temporary Items +.apdisk + +# End of https://www.gitignore.io/api/android,androidstudio,macos diff --git a/gradle/anko-simple-ui/.idea/compiler.xml b/gradle/anko-simple-ui/.idea/compiler.xml deleted file mode 100644 index 96cc43efa6..0000000000 --- a/gradle/anko-simple-ui/.idea/compiler.xml +++ /dev/null @@ -1,22 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/copyright/profiles_settings.xml b/gradle/anko-simple-ui/.idea/copyright/profiles_settings.xml deleted file mode 100644 index e7bedf3377..0000000000 --- a/gradle/anko-simple-ui/.idea/copyright/profiles_settings.xml +++ /dev/null @@ -1,3 +0,0 @@ - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/gradle.xml b/gradle/anko-simple-ui/.idea/gradle.xml deleted file mode 100644 index 7ac24c777f..0000000000 --- a/gradle/anko-simple-ui/.idea/gradle.xml +++ /dev/null @@ -1,18 +0,0 @@ - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/animated_vector_drawable_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/animated_vector_drawable_25_3_1.xml deleted file mode 100644 index 986b1cda5a..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/animated_vector_drawable_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/anko_appcompat_v7_0_9_1.xml b/gradle/anko-simple-ui/.idea/libraries/anko_appcompat_v7_0_9_1.xml deleted file mode 100644 index 8563a7f435..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/anko_appcompat_v7_0_9_1.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/anko_common_0_9_1.xml b/gradle/anko-simple-ui/.idea/libraries/anko_common_0_9_1.xml deleted file mode 100644 index 89174fc128..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/anko_common_0_9_1.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/anko_sdk15_0_9_1.xml b/gradle/anko-simple-ui/.idea/libraries/anko_sdk15_0_9_1.xml deleted file mode 100644 index 044ee0ce95..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/anko_sdk15_0_9_1.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/anko_support_v4_0_9_1.xml b/gradle/anko-simple-ui/.idea/libraries/anko_support_v4_0_9_1.xml deleted file mode 100644 index ec9c330215..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/anko_support_v4_0_9_1.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/annotations_13_0.xml b/gradle/anko-simple-ui/.idea/libraries/annotations_13_0.xml deleted file mode 100644 index 24c0dcb114..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/annotations_13_0.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/appcompat_v7_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/appcompat_v7_25_3_1.xml deleted file mode 100644 index 9e612993e4..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/appcompat_v7_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/gson_2_7.xml b/gradle/anko-simple-ui/.idea/libraries/gson_2_7.xml deleted file mode 100644 index 22607550e1..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/gson_2_7.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/kotlin_stdlib_1_1_2.xml b/gradle/anko-simple-ui/.idea/libraries/kotlin_stdlib_1_1_2.xml deleted file mode 100644 index c0993f57d5..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/kotlin_stdlib_1_1_2.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/okhttp_2_3_0.xml b/gradle/anko-simple-ui/.idea/libraries/okhttp_2_3_0.xml deleted file mode 100644 index e0ed48aea3..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/okhttp_2_3_0.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/okio_1_3_0.xml b/gradle/anko-simple-ui/.idea/libraries/okio_1_3_0.xml deleted file mode 100644 index 93a99cb20a..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/okio_1_3_0.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/support_annotations_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/support_annotations_25_3_1.xml deleted file mode 100644 index 42adfc6edf..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/support_annotations_25_3_1.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/support_compat_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/support_compat_25_3_1.xml deleted file mode 100644 index 1dff866919..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/support_compat_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/support_core_ui_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/support_core_ui_25_3_1.xml deleted file mode 100644 index c0bd9753a2..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/support_core_ui_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/support_core_utils_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/support_core_utils_25_3_1.xml deleted file mode 100644 index 406ceb21a7..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/support_core_utils_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/support_fragment_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/support_fragment_25_3_1.xml deleted file mode 100644 index a356b6caab..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/support_fragment_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/support_media_compat_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/support_media_compat_25_3_1.xml deleted file mode 100644 index 543c69e48e..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/support_media_compat_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/support_v4_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/support_v4_25_3_1.xml deleted file mode 100644 index 8eab02bac5..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/support_v4_25_3_1.xml +++ /dev/null @@ -1,10 +0,0 @@ - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/libraries/support_vector_drawable_25_3_1.xml b/gradle/anko-simple-ui/.idea/libraries/support_vector_drawable_25_3_1.xml deleted file mode 100644 index 91427afa49..0000000000 --- a/gradle/anko-simple-ui/.idea/libraries/support_vector_drawable_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/misc.xml b/gradle/anko-simple-ui/.idea/misc.xml deleted file mode 100644 index 7c32224c17..0000000000 --- a/gradle/anko-simple-ui/.idea/misc.xml +++ /dev/null @@ -1,62 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Android API 25 Platform - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/modules.xml b/gradle/anko-simple-ui/.idea/modules.xml deleted file mode 100644 index 8ae538b952..0000000000 --- a/gradle/anko-simple-ui/.idea/modules.xml +++ /dev/null @@ -1,9 +0,0 @@ - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/.idea/workspace.xml b/gradle/anko-simple-ui/.idea/workspace.xml deleted file mode 100644 index 6e21e4c722..0000000000 --- a/gradle/anko-simple-ui/.idea/workspace.xml +++ /dev/null @@ -1,2470 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 1497970301576 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/anko-simple-ui.iml b/gradle/anko-simple-ui/anko-simple-ui.iml deleted file mode 100644 index b1b487d617..0000000000 --- a/gradle/anko-simple-ui/anko-simple-ui.iml +++ /dev/null @@ -1,35 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/app/.DS_Store b/gradle/anko-simple-ui/app/.DS_Store deleted file mode 100644 index 3b2e0efa7305c6e7705b833574ad18c738884030..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK-A)rh82zR#b{jD^h6KHv8xt>zDIhe2m~1LsaA#5@7eHW_ZD5mSr`aDHtTlV% zOXw5$D!u>@;sfZJpH{jBE{&1-nwc~E%{eojv+d3f5wUI_tP(Ye$U%`g3S?pOK< z)!rJn_^8uqxA^+z#(3;F%g - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/anko-simple-ui/app/src/.DS_Store b/gradle/anko-simple-ui/app/src/.DS_Store deleted file mode 100644 index 7fc4e7c0d22ff93a67d2257c8abe2ad3793efb82..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK%}T>S5Z-O8CWzRBpx$y3JoJ#ZY7r4at%u%(iXK#IVu}r<+0vv2jgdTuzL78B zFDWkQGs%CVrs@P+Vsu2WJ_o+2RSYqWiK z<@n5jXTBiH-)DgDU5N~cO*|5O+P^)R+k6!w3d!S~I2@{des+ew7e=P}LJP&x-28&3 z>zcl#U3B^^?nHJp4x9GqOgwpR&r$Xa|f<@F?~)oYE4v1RV26(eah%!*Op*-leUTivMcw=V~`cgcPF@F+Kf z!j~#!S>Xhpz{o4S>5KxO1=rx4#82W7kpW}?8JK+r)XAnT&VDIa0WyFL{4fLjd@w*c zS_(6X;^=@uv;cr5a0>xj{Q3hL+yQ7Q%p`&bgvwMvnMzfQK~?8KWjf4TDn64a(+L%C zhIQ1Nsp?RuYCNbR!U?q`;)o0&10NaSy&p)K-~Wf-_x~aY2V?*l_@4~WQmfNyLT&19 zovM=GwFc-VC>I`=Nz7Bg5LYq8@~e0aR0#MDZU9;eGl}2$?4HnDoL59$8b8074yi*K<@A!y=$Ml2L>+{Q3X!2d zmo?~%A4XsiRp=|u{gi^=;=bP(7xuFgH{VTolEhiwXxxfYxia%;)~i;%>YTURK2rU5 z9^}2O6?8wFUL18oXMa#C8QDSjG4AyDYEL&*ng?;(>5hf(e2UXZ^;@c!MwyxCeUKj^ z*DSPGTO16QSC*S~x!QO$tjj^O*{I8v*RO^{&s%uDw7$K6e10*w99~_Uy^_H9Ze-r! zFZc#y#KdX4nY805kBw47fYYd;Gxb@bt_8Gw|;* zpzj9>)#y7cESjqWjd=n9D{vcut$z-6j&$fdEG%LKB5W$qrV97O5H=lt>Ee8cg+-fA z!aY8OTUodliZH8Verdu<_!hZk2AF|K2FkWu)AfJr{`dc668D$^X5hbKKvXu{n=Nd~ z)z+!a=~^qH`%o=9uCO>tfniE9Vs$Bg1~me|)CSOZSXhJy!ao9r25y*vKgz&Q({Xl- diff --git a/gradle/anko-simple-ui/app/src/main/java/.DS_Store b/gradle/anko-simple-ui/app/src/main/java/.DS_Store deleted file mode 100644 index 9bf1062c9bdabc1cf291973ce54e9ee5e3be108a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK%}T>S5Z-O8CWx4Wpx$y3JoL~XwTK9z)`%PwNHq5tSH^Ug?)nU8Hn8g?~KqY2O7`_oXFLh2b=*a?dxrVs) z0^z}vT#n>FFd+9X%LE&+ZatXUzayC0{ZOI`!6+|@`nbz)UO(`oxKMcKnQU%pdBreI z!(20N8aINmwwn5NmUHP zcBIxhbK@T5suwk_?a`=IE>-gOUg2<@w?~yqA#axt_Qzwx*xV@|*IRcFkE5sY^NZdJ z4qvH~b;Jq0f`RqjHwIxK!Y+6w(UT}bVt^PR1{Q?@Jl~AfMJb5tAO?tmUt>U?4>qVo z2Qk&Cjt&@93jmk{w-T_`&p)6o9e@sEsu4UOT&Du+RE{kM$KHYKbeMNAKGmqx8CP$H zb@0s`I~0zs2e(x?KTLwN~~y^o@K0 zA4eyXRMhHGQJI0sH#?b0HeZ%x2LMF1+bjbV0Kh@jn8{=FiRgZ<|D zCsL<=G!o5@-^hU8yBq{?1s+_$oBdNh_UO-I19kD41g(*1zt?H`5k)`xttjjyrP7ng zjAh3sa!x+)YbLZsZ z`lf$7xVxv7fWWVoWZL2o9?h@|Mu7QKLv5a3@`)#lL3*f z)oWE;o4s2{R;lk=iF$&nMaQKEUsKSas~BVTRXm4Ef_|wDMAu?!5IrdTBS188!wmc= F11~soUt|CP diff --git a/gradle/anko-simple-ui/app/src/main/java/org/example/.DS_Store b/gradle/anko-simple-ui/app/src/main/java/org/example/.DS_Store deleted file mode 100644 index 58482d5adebe3668d7b91cf243fdb3f83498ed6b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHKF-`+P474Fak!VsUWY4b8 zvzwdZ9GjW1-yUzwR%W(@6Yan-H$JD&?5r{lgyW1Sd)W=+!+sd|v+C0caxd)JMtim4 z8=pVw7JmH^cKQHirGONW0#ZNnS z3P^!t1Zn@E;1?b*9v?BfO{LY diff --git a/gradle/gson-deserializers-okhttp-asyncTask/.gitignore b/gradle/gson-deserializers-okhttp-asyncTask/.gitignore deleted file mode 100644 index ccf2efe026..0000000000 --- a/gradle/gson-deserializers-okhttp-asyncTask/.gitignore +++ /dev/null @@ -1,27 +0,0 @@ -# Built application files -*.apk -*.ap_ - -# Files for the Dalvik VM -*.dex - -# Java class files -*.class - -# Generated files -bin/ -gen/ - -# Gradle files -.gradle/ -build/ -/*/build/ - -# Local configuration file (sdk path, etc) -local.properties - -# Proguard folder generated by Eclipse -proguard/ - -# Log Files -*.log diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/app.iml b/gradle/gson-deserializers-okhttp-asyncTask/app/app.iml deleted file mode 100644 index 0bd117584e..0000000000 --- a/gradle/gson-deserializers-okhttp-asyncTask/app/app.iml +++ /dev/null @@ -1,127 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.DS_Store b/gradle/gson-deserializers-okhttp-asynctask/.DS_Store deleted file mode 100644 index 37b42619d92349aa47aa2f929660eda8b4fc2223..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK&2G~`5T0$))}cUC38`@N1;HUj=?_E*A*G=RdO#qhf&-w`uC2zZYe%s|)P|s3 zcn1Vez^m{AJO~c}-|Q~Ic1y$wA+#gye)}`Cv-3^Xnog+NY z<&4bfk;_2AYs3d`7`y24az+dThJk;b0Y1AWa;QhW-7t54?_uWVcPTOmt>q4ro<8MY z++G+YX}$hc%$3UX3yW5zVpT3#uiM>t*iM~vkhGlsOW6xN-_`BCI1Z<6$9*37!%p?e zgE&f^AoBYe^;a)~$cu-qco2DsT<4jSc3~?Wb*k4!qm9jtM$O);-yPTNQKM0>*_(H6 zkH?m^dVT%=?*8$~>FDkF-A9!Mfv=R5WsN`K6B;_cH|>5D#?c{0SbLsa8c;wXc?Etx zV>Zjr#b26qiw>y|Rz2AHc{{OMuv?g+`@W#NlGTNm9=yb;ePD`R`jiyBeJiZ6m|J0( z*Cx*ShfL0w^4jp|BC51t#Y|+aZon$Rz9L!!1K5+?UjWMxdpwoB1amPRQ5XA85y2W} z6FPy-0s7oNg13Ne$84P&FXu#9nVc+R=e~?1fDJP}-KQV-U zI|yZt`KH#NC{*Soq-U(7Jq!Ip5&G#NY^hG7snFDh0mDF^fs*Q0`Tl?S`}cp|$n*>Y zhJpWz0a4y*@3at-zFW@($9JubvX8>TdJ~1x1eLyyWrMHct0+=1XLAGC)HqRy5s3LC NAZaj_Vc@Sa@B>L&5(@wT diff --git a/gradle/gson-deserializers-okhttp-asynctask/.gitignore b/gradle/gson-deserializers-okhttp-asynctask/.gitignore new file mode 100644 index 0000000000..93deb134e3 --- /dev/null +++ b/gradle/gson-deserializers-okhttp-asynctask/.gitignore @@ -0,0 +1,197 @@ + +# Created by https://www.gitignore.io/api/android,androidstudio,macos + +### Android ### +# Built application files +*.apk +*.ap_ + +# Files for the ART/Dalvik VM +*.dex + +# Java class files +*.class + +# Generated files +bin/ +gen/ +out/ + +# Gradle files +.gradle/ +build/ + +# Local configuration file (sdk path, etc) +local.properties + +# Proguard folder generated by Eclipse +proguard/ + +# Log Files +*.log + +# Android Studio Navigation editor temp files +.navigation/ + +# Android Studio captures folder +captures/ + +# Intellij +*.iml +.idea/workspace.xml +.idea/tasks.xml +.idea/gradle.xml +.idea/dictionaries +.idea/libraries + +# Keystore files +*.jks + +# External native build folder generated in Android Studio 2.2 and later +.externalNativeBuild + +# Google Services (e.g. APIs or Firebase) +google-services.json + +# Freeline +freeline.py +freeline/ +freeline_project_description.json + +### Android Patch ### +gen-external-apklibs + +### AndroidStudio ### +# Covers files to be ignored for android development using Android Studio. + +# Built application files + +# Files for the ART/Dalvik VM + +# Java class files + +# Generated files + +# Gradle files +.gradle + +# Signing files +.signing/ + +# Local configuration file (sdk path, etc) + +# Proguard folder generated by Eclipse + +# Log Files + +# Android Studio +/*/build/ +/*/local.properties +/*/out +/*/*/build +/*/*/production +*.ipr +*~ +*.swp + +# Android Patch + +# External native build folder generated in Android Studio 2.2 and later + +# NDK +obj/ + +# IntelliJ IDEA +*.iws +/out/ + +# User-specific configurations +.idea/libraries/ +.idea/.name +.idea/compiler.xml +.idea/copyright/profiles_settings.xml +.idea/encodings.xml +.idea/misc.xml +.idea/modules.xml +.idea/scopes/scope_settings.xml +.idea/vcs.xml +.idea/jsLibraryMappings.xml +.idea/datasources.xml +.idea/dataSources.ids +.idea/sqlDataSources.xml +.idea/dynamic.xml +.idea/uiDesigner.xml + +# Keystore files + +# OS-specific files +.DS_Store +.DS_Store? +._* +.Spotlight-V100 +.Trashes +ehthumbs.db +Thumbs.db + +# Legacy Eclipse project files +.classpath +.project + +# Mobile Tools for Java (J2ME) +.mtj.tmp/ + +# Package Files # +*.jar +*.war +*.ear + +# virtual machine crash logs (Reference: http://www.java.com/en/download/help/error_hotspot.xml) +hs_err_pid* + +## Plugin-specific files: + +# mpeltonen/sbt-idea plugin +.idea_modules/ + +# JIRA plugin +atlassian-ide-plugin.xml + +# Mongo Explorer plugin +.idea/mongoSettings.xml + +# Crashlytics plugin (for Android Studio and IntelliJ) +com_crashlytics_export_strings.xml +crashlytics.properties +crashlytics-build.properties +fabric.properties + +### AndroidStudio Patch ### +# Google Services plugin + +!/gradle/wrapper/gradle-wrapper.jar + +### macOS ### +*.DS_Store +.AppleDouble +.LSOverride + +# Icon must end with two \r +Icon + +# Thumbnails + +# Files that might appear in the root of a volume +.DocumentRevisions-V100 +.fseventsd +.TemporaryItems +.VolumeIcon.icns +.com.apple.timemachine.donotpresent + +# Directories potentially created on remote AFP share +.AppleDB +.AppleDesktop +Network Trash Folder +Temporary Items +.apdisk + +# End of https://www.gitignore.io/api/android,androidstudio,macos diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/compiler.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/compiler.xml deleted file mode 100644 index 96cc43efa6..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/compiler.xml +++ /dev/null @@ -1,22 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/copyright/profiles_settings.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/copyright/profiles_settings.xml deleted file mode 100644 index e7bedf3377..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/copyright/profiles_settings.xml +++ /dev/null @@ -1,3 +0,0 @@ - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/gradle.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/gradle.xml deleted file mode 100644 index 7ac24c777f..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/gradle.xml +++ /dev/null @@ -1,18 +0,0 @@ - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml deleted file mode 100644 index 986b1cda5a..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/annotations_13_0.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/annotations_13_0.xml deleted file mode 100644 index 24c0dcb114..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/annotations_13_0.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml deleted file mode 100644 index 9e612993e4..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/gson_2_7.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/gson_2_7.xml deleted file mode 100644 index 22607550e1..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/gson_2_7.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml deleted file mode 100644 index c0993f57d5..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/okhttp_2_3_0.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/okhttp_2_3_0.xml deleted file mode 100644 index e0ed48aea3..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/okhttp_2_3_0.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/okio_1_3_0.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/okio_1_3_0.xml deleted file mode 100644 index 93a99cb20a..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/okio_1_3_0.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_annotations_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_annotations_25_3_1.xml deleted file mode 100644 index 42adfc6edf..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_annotations_25_3_1.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_compat_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_compat_25_3_1.xml deleted file mode 100644 index 1dff866919..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_compat_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_core_ui_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_core_ui_25_3_1.xml deleted file mode 100644 index c0bd9753a2..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_core_ui_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_core_utils_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_core_utils_25_3_1.xml deleted file mode 100644 index 406ceb21a7..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_core_utils_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_fragment_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_fragment_25_3_1.xml deleted file mode 100644 index a356b6caab..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_fragment_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_media_compat_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_media_compat_25_3_1.xml deleted file mode 100644 index 543c69e48e..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_media_compat_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_v4_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_v4_25_3_1.xml deleted file mode 100644 index 8eab02bac5..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_v4_25_3_1.xml +++ /dev/null @@ -1,10 +0,0 @@ - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml deleted file mode 100644 index 91427afa49..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/misc.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/misc.xml deleted file mode 100644 index 7c32224c17..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/misc.xml +++ /dev/null @@ -1,62 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Android API 25 Platform - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/modules.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/modules.xml deleted file mode 100644 index 8915191f2c..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/modules.xml +++ /dev/null @@ -1,9 +0,0 @@ - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/.idea/workspace.xml b/gradle/gson-deserializers-okhttp-asynctask/.idea/workspace.xml deleted file mode 100644 index a67a075914..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/.idea/workspace.xml +++ /dev/null @@ -1,2551 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 1497970422658 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/app/.DS_Store b/gradle/gson-deserializers-okhttp-asynctask/app/.DS_Store deleted file mode 100644 index 3b2e0efa7305c6e7705b833574ad18c738884030..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK-A)rh82zR#b{jD^h6KHv8xt>zDIhe2m~1LsaA#5@7eHW_ZD5mSr`aDHtTlV% zOXw5$D!u>@;sfZJpH{jBE{&1-nwc~E%{eojv+d3f5wUI_tP(Ye$U%`g3S?pOK< z)!rJn_^8uqxA^+z#(3;F%gS5Z-O8CWzRBpx$y3JoJ#ZY7r4at%u%(iXK#IVu}r<+0vv2jgdTuzL78B zFDWkQGs%CVrs@P+Vsu2WJ_o+2RSYqWiK z<@n5jXTBiH-)DgDU5N~cO*|5O+P^)R+k6!w3d!S~I2@{des+ew7e=P}LJP&x-28&3 z>zcl#U3B^^?nHJp4x9GqOgwpR&r$Xa|f<@F?~)oYE4v1RV26(eah%!*Op*-leUTivMcw=V~`cgcPF@F+Kf z!j~#!S>Xhpz{o4S>5KxO1=rx4#82W7kpW}?8JK+r)XAnT&VDIa0WyFL{4fLjd@w*c zS_(6X;^=@uv;cr5a0>xj{Q3hL+yQ7Q%p`&bgvwMvnMzfQK~?8KWjf4TDn64a(+L%C zhIQ1Nsp?RuYCNbR!U?q`;)o0&10NaSy&p)K-~Wf-_x~aY2V?*l_@4~WQmfNyLT&19 zovM=GwFc-VC>I`=Nz7Bg5LYq8@~e0aR0#MDZU9;eGl}2$?4HnDoL59$8b8074yi*K<@A!y=$Ml2L>+{Q3X!2d zmo?~%A4XsiRp=|u{gi^=;=bP(7xuFgH{VTolEhiwXxxfYxia%;)~i;%>YTURK2rU5 z9^}2O6?8wFUL18oXMa#C8QDSjG4AyDYEL&*ng?;(>5hf(e2UXZ^;@c!MwyxCeUKj^ z*DSPGTO16QSC*S~x!QO$tjj^O*{I8v*RO^{&s%uDw7$K6e10*w99~_Uy^_H9Ze-r! zFZc#y#KdX4nY805kBw47fYYd;Gxb@bt_8Gw|;* zpzj9>)#y7cESjqWjd=n9D{vcut$z-6j&$fdEG%LKB5W$qrV97O5H=lt>Ee8cg+-fA z!aY8OTUodliZH8Verdu<_!hZk2AF|K2FkWu)AfJr{`dc668D$^X5hbKKvXu{n=Nd~ z)z+!a=~^qH`%o=9uCO>tfniE9Vs$Bg1~me|)CSOZSXhJy!ao9r25y*vKgz&Q({Xl- diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/AndroidManifest.xml b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/AndroidManifest.xml similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/app/src/main/AndroidManifest.xml rename to gradle/gson-deserializers-okhttp-asynctask/app/src/main/AndroidManifest.xml diff --git a/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/.DS_Store b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/.DS_Store deleted file mode 100644 index 9bf1062c9bdabc1cf291973ce54e9ee5e3be108a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK%}T>S5Z-O8CWx4Wpx$y3JoL~XwTK9z)`%PwNHq5tSH^Ug?)nU8Hn8g?~KqY2O7`_oXFLh2b=*a?dxrVs) z0^z}vT#n>FFd+9X%LE&+ZatXUzayC0{ZOI`!6+|@`nbz)UO(`oxKMcKnQU%pdBreI z!(20N8aINmwwn5NmUHP zcBIxhbK@T5suwk_?a`=IE>-gOUg2<@w?~yqA#axt_Qzwx*xV@|*IRcFkE5sY^NZdJ z4qvH~b;Jq0f`RqjHwIxK!Y+6w(UT}bVt^PR1{Q?@Jl~AfMJb5tAO?tmUt>U?4>qVo z2Qk&Cjt&@93jmk{w-T_`&p)6o9e@sEsu4UOT&Du+RE{kM$KHYKbeMNAKGmqx8CP$H zb@0s`I~0zs2e(x?KTLwN~~y^o@K0 zA4eyXRMhHGQJI0sH#?b0HeZ%x2LMF1+bjbV0Kh@jn8{=FiRgZ<|D zCsL<=G!o5@-^hU8yBq{?1s+_$oBdNh_UO-I19kD41g(*1zt?H`5k)`xttjjyrP7ng zjAh3sa!x+)YbLZsZ z`lf$7xVxv7fWWVoWZL2o9?h@|Mu7QKLv5a3@`)#lL3*f z)oWE;o4s2{R;lk=iF$&nMaQKEUsKSas~BVTRXm4Ef_|wDMAu?!5IrdTBS188!wmc= F11~soUt|CP diff --git a/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/.DS_Store b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/.DS_Store deleted file mode 100644 index 58482d5adebe3668d7b91cf243fdb3f83498ed6b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHKF-`+P474Fak!VsUWY4b8 zvzwdZ9GjW1-yUzwR%W(@6Yan-H$JD&?5r{lgyW1Sd)W=+!+sd|v+C0caxd)JMtim4 z8=pVw7JmH^cKQHirGONW0#ZNnS z3P^!t1Zn@E;1?b*9v?BfO{LY diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/layout/activity_main.xml b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/layout/activity_main.xml similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/layout/activity_main.xml rename to gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/layout/activity_main.xml diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/menu/menu_main.xml b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/menu/menu_main.xml similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/menu/menu_main.xml rename to gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/menu/menu_main.xml diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-hdpi/ic_launcher.png b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/mipmap-hdpi/ic_launcher.png similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-hdpi/ic_launcher.png rename to gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/mipmap-hdpi/ic_launcher.png diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-mdpi/ic_launcher.png b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/mipmap-mdpi/ic_launcher.png similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-mdpi/ic_launcher.png rename to gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/mipmap-mdpi/ic_launcher.png diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-xhdpi/ic_launcher.png b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/mipmap-xhdpi/ic_launcher.png similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-xhdpi/ic_launcher.png rename to gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/mipmap-xhdpi/ic_launcher.png diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-xxhdpi/ic_launcher.png b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/mipmap-xxhdpi/ic_launcher.png similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/mipmap-xxhdpi/ic_launcher.png rename to gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/mipmap-xxhdpi/ic_launcher.png diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values-w820dp/dimens.xml b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/values-w820dp/dimens.xml similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values-w820dp/dimens.xml rename to gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/values-w820dp/dimens.xml diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/dimens.xml b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/values/dimens.xml similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/dimens.xml rename to gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/values/dimens.xml diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/strings.xml b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/values/strings.xml similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/strings.xml rename to gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/values/strings.xml diff --git a/gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/styles.xml b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/values/styles.xml similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/app/src/main/res/values/styles.xml rename to gradle/gson-deserializers-okhttp-asynctask/app/src/main/res/values/styles.xml diff --git a/gradle/gson-deserializers-okhttp-asyncTask/build.gradle b/gradle/gson-deserializers-okhttp-asynctask/build.gradle similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/build.gradle rename to gradle/gson-deserializers-okhttp-asynctask/build.gradle diff --git a/gradle/gson-deserializers-okhttp-asyncTask/gradle.properties b/gradle/gson-deserializers-okhttp-asynctask/gradle.properties similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/gradle.properties rename to gradle/gson-deserializers-okhttp-asynctask/gradle.properties diff --git a/gradle/gson-deserializers-okhttp-asyncTask/gradle/wrapper/gradle-wrapper.jar b/gradle/gson-deserializers-okhttp-asynctask/gradle/wrapper/gradle-wrapper.jar similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/gradle/wrapper/gradle-wrapper.jar rename to gradle/gson-deserializers-okhttp-asynctask/gradle/wrapper/gradle-wrapper.jar diff --git a/gradle/gson-deserializers-okhttp-asyncTask/gradle/wrapper/gradle-wrapper.properties b/gradle/gson-deserializers-okhttp-asynctask/gradle/wrapper/gradle-wrapper.properties similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/gradle/wrapper/gradle-wrapper.properties rename to gradle/gson-deserializers-okhttp-asynctask/gradle/wrapper/gradle-wrapper.properties diff --git a/gradle/gson-deserializers-okhttp-asyncTask/gradlew b/gradle/gson-deserializers-okhttp-asynctask/gradlew similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/gradlew rename to gradle/gson-deserializers-okhttp-asynctask/gradlew diff --git a/gradle/gson-deserializers-okhttp-asyncTask/gradlew.bat b/gradle/gson-deserializers-okhttp-asynctask/gradlew.bat similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/gradlew.bat rename to gradle/gson-deserializers-okhttp-asynctask/gradlew.bat diff --git a/gradle/gson-deserializers-okhttp-asynctask/gson-deserializers-okhttp-asynctask.iml b/gradle/gson-deserializers-okhttp-asynctask/gson-deserializers-okhttp-asynctask.iml deleted file mode 100644 index 670c5b9d04..0000000000 --- a/gradle/gson-deserializers-okhttp-asynctask/gson-deserializers-okhttp-asynctask.iml +++ /dev/null @@ -1,35 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asyncTask/settings.gradle b/gradle/gson-deserializers-okhttp-asynctask/settings.gradle similarity index 100% rename from gradle/gson-deserializers-okhttp-asyncTask/settings.gradle rename to gradle/gson-deserializers-okhttp-asynctask/settings.gradle diff --git a/gradle/httpurlconnection-asynctask/.DS_Store b/gradle/httpurlconnection-asynctask/.DS_Store deleted file mode 100644 index 4434579fd7a748565782e7ea0ccd182253a9b0df..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK!EVz)5S?w()}cUC38`?x7bFe=r7aL4gp{U5q6Z|T6gU7%?b=GLx^@&hL?r~} z!apGR0)B-b;6wNTc(c1Lb{e9b5Q3d(_s#Ck%`jlQ=*R3;(|g|T=6)fC}z zF6U%H_gn@Fju9WaVeF#C;fxpt3KETM$A5vrz+R7ayUA@b{ zy4^5H(rWdaSSS=1mzJ$k$tqp4UN<}OpqV;pKWR9g9O#(C`%mgI2)w1FtZF=k&ro!JZ<@U*jH5Ps*m{v%>Qg`=c@zA6 z!DyDBi@z-CHnph-Rz3Lnc|Wl};kPuy_QQnjTGke`bTLbe+6SgsrBBJkY~Lp$EaxH& z^47%9{A1>sujH*Uql>K42`^?M>vf$vSWSv`^|7vy4zb1vKOY*el3TYBC!rH)+{gM6 zq6c(LVLrNG4)W0->*&v9^qncuTeN)^eScHTcUp<5^%}LZ1n%Xd67|1hFP|Y%*|Brru|Ia&_mSMm!@J}%yio4C-22#>z z>$&9kthG@NP*~V*tWdh3(#Nq>_$a=LA_ZeME5N$Ou|o7f%!h!a!BmEUKgz&Q7%vOk diff --git a/gradle/httpurlconnection-asynctask/.gitignore b/gradle/httpurlconnection-asynctask/.gitignore index ccf2efe026..93deb134e3 100644 --- a/gradle/httpurlconnection-asynctask/.gitignore +++ b/gradle/httpurlconnection-asynctask/.gitignore @@ -1,8 +1,12 @@ + +# Created by https://www.gitignore.io/api/android,androidstudio,macos + +### Android ### # Built application files *.apk *.ap_ -# Files for the Dalvik VM +# Files for the ART/Dalvik VM *.dex # Java class files @@ -11,11 +15,11 @@ # Generated files bin/ gen/ +out/ # Gradle files .gradle/ build/ -/*/build/ # Local configuration file (sdk path, etc) local.properties @@ -25,3 +29,169 @@ proguard/ # Log Files *.log + +# Android Studio Navigation editor temp files +.navigation/ + +# Android Studio captures folder +captures/ + +# Intellij +*.iml +.idea/workspace.xml +.idea/tasks.xml +.idea/gradle.xml +.idea/dictionaries +.idea/libraries + +# Keystore files +*.jks + +# External native build folder generated in Android Studio 2.2 and later +.externalNativeBuild + +# Google Services (e.g. APIs or Firebase) +google-services.json + +# Freeline +freeline.py +freeline/ +freeline_project_description.json + +### Android Patch ### +gen-external-apklibs + +### AndroidStudio ### +# Covers files to be ignored for android development using Android Studio. + +# Built application files + +# Files for the ART/Dalvik VM + +# Java class files + +# Generated files + +# Gradle files +.gradle + +# Signing files +.signing/ + +# Local configuration file (sdk path, etc) + +# Proguard folder generated by Eclipse + +# Log Files + +# Android Studio +/*/build/ +/*/local.properties +/*/out +/*/*/build +/*/*/production +*.ipr +*~ +*.swp + +# Android Patch + +# External native build folder generated in Android Studio 2.2 and later + +# NDK +obj/ + +# IntelliJ IDEA +*.iws +/out/ + +# User-specific configurations +.idea/libraries/ +.idea/.name +.idea/compiler.xml +.idea/copyright/profiles_settings.xml +.idea/encodings.xml +.idea/misc.xml +.idea/modules.xml +.idea/scopes/scope_settings.xml +.idea/vcs.xml +.idea/jsLibraryMappings.xml +.idea/datasources.xml +.idea/dataSources.ids +.idea/sqlDataSources.xml +.idea/dynamic.xml +.idea/uiDesigner.xml + +# Keystore files + +# OS-specific files +.DS_Store +.DS_Store? +._* +.Spotlight-V100 +.Trashes +ehthumbs.db +Thumbs.db + +# Legacy Eclipse project files +.classpath +.project + +# Mobile Tools for Java (J2ME) +.mtj.tmp/ + +# Package Files # +*.jar +*.war +*.ear + +# virtual machine crash logs (Reference: http://www.java.com/en/download/help/error_hotspot.xml) +hs_err_pid* + +## Plugin-specific files: + +# mpeltonen/sbt-idea plugin +.idea_modules/ + +# JIRA plugin +atlassian-ide-plugin.xml + +# Mongo Explorer plugin +.idea/mongoSettings.xml + +# Crashlytics plugin (for Android Studio and IntelliJ) +com_crashlytics_export_strings.xml +crashlytics.properties +crashlytics-build.properties +fabric.properties + +### AndroidStudio Patch ### +# Google Services plugin + +!/gradle/wrapper/gradle-wrapper.jar + +### macOS ### +*.DS_Store +.AppleDouble +.LSOverride + +# Icon must end with two \r +Icon + +# Thumbnails + +# Files that might appear in the root of a volume +.DocumentRevisions-V100 +.fseventsd +.TemporaryItems +.VolumeIcon.icns +.com.apple.timemachine.donotpresent + +# Directories potentially created on remote AFP share +.AppleDB +.AppleDesktop +Network Trash Folder +Temporary Items +.apdisk + +# End of https://www.gitignore.io/api/android,androidstudio,macos diff --git a/gradle/httpurlconnection-asynctask/.idea/compiler.xml b/gradle/httpurlconnection-asynctask/.idea/compiler.xml deleted file mode 100644 index 96cc43efa6..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/compiler.xml +++ /dev/null @@ -1,22 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/copyright/profiles_settings.xml b/gradle/httpurlconnection-asynctask/.idea/copyright/profiles_settings.xml deleted file mode 100644 index e7bedf3377..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/copyright/profiles_settings.xml +++ /dev/null @@ -1,3 +0,0 @@ - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/gradle.xml b/gradle/httpurlconnection-asynctask/.idea/gradle.xml deleted file mode 100644 index 7ac24c777f..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/gradle.xml +++ /dev/null @@ -1,18 +0,0 @@ - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml deleted file mode 100644 index 986b1cda5a..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/annotations_13_0.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/annotations_13_0.xml deleted file mode 100644 index 24c0dcb114..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/libraries/annotations_13_0.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml deleted file mode 100644 index 9e612993e4..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml deleted file mode 100644 index c0993f57d5..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/support_annotations_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/support_annotations_25_3_1.xml deleted file mode 100644 index 42adfc6edf..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/libraries/support_annotations_25_3_1.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/support_compat_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/support_compat_25_3_1.xml deleted file mode 100644 index 1dff866919..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/libraries/support_compat_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/support_core_ui_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/support_core_ui_25_3_1.xml deleted file mode 100644 index c0bd9753a2..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/libraries/support_core_ui_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/support_core_utils_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/support_core_utils_25_3_1.xml deleted file mode 100644 index 406ceb21a7..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/libraries/support_core_utils_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/support_fragment_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/support_fragment_25_3_1.xml deleted file mode 100644 index a356b6caab..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/libraries/support_fragment_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/support_media_compat_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/support_media_compat_25_3_1.xml deleted file mode 100644 index 543c69e48e..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/libraries/support_media_compat_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/support_v4_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/support_v4_25_3_1.xml deleted file mode 100644 index 8eab02bac5..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/libraries/support_v4_25_3_1.xml +++ /dev/null @@ -1,10 +0,0 @@ - - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml b/gradle/httpurlconnection-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml deleted file mode 100644 index 91427afa49..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/misc.xml b/gradle/httpurlconnection-asynctask/.idea/misc.xml deleted file mode 100644 index 7c32224c17..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/misc.xml +++ /dev/null @@ -1,62 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Android API 25 Platform - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/modules.xml b/gradle/httpurlconnection-asynctask/.idea/modules.xml deleted file mode 100644 index 78f8bc36ce..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/modules.xml +++ /dev/null @@ -1,9 +0,0 @@ - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/.idea/workspace.xml b/gradle/httpurlconnection-asynctask/.idea/workspace.xml deleted file mode 100644 index 78d837bea3..0000000000 --- a/gradle/httpurlconnection-asynctask/.idea/workspace.xml +++ /dev/null @@ -1,2366 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 1497970498549 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/app/.DS_Store b/gradle/httpurlconnection-asynctask/app/.DS_Store deleted file mode 100644 index 3b2e0efa7305c6e7705b833574ad18c738884030..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK-A)rh82zR#b{jD^h6KHv8xt>zDIhe2m~1LsaA#5@7eHW_ZD5mSr`aDHtTlV% zOXw5$D!u>@;sfZJpH{jBE{&1-nwc~E%{eojv+d3f5wUI_tP(Ye$U%`g3S?pOK< z)!rJn_^8uqxA^+z#(3;F%g - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/httpurlconnection-asynctask/app/src/.DS_Store b/gradle/httpurlconnection-asynctask/app/src/.DS_Store deleted file mode 100644 index 7fc4e7c0d22ff93a67d2257c8abe2ad3793efb82..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK%}T>S5Z-O8CWzRBpx$y3JoJ#ZY7r4at%u%(iXK#IVu}r<+0vv2jgdTuzL78B zFDWkQGs%CVrs@P+Vsu2WJ_o+2RSYqWiK z<@n5jXTBiH-)DgDU5N~cO*|5O+P^)R+k6!w3d!S~I2@{des+ew7e=P}LJP&x-28&3 z>zcl#U3B^^?nHJp4x9GqOgwpR&r$Xa|f<@F?~)oYE4v1RV26(eah%!*Op*-leUTivMcw=V~`cgcPF@F+Kf z!j~#!S>Xhpz{o4S>5KxO1=rx4#82W7kpW}?8JK+r)XAnT&VDIa0WyFL{4fLjd@w*c zS_(6X;^=@uv;cr5a0>xj{Q3hL+yQ7Q%p`&bgvwMvnMzfQK~?8KWjf4TDn64a(+L%C zhIQ1Nsp?RuYCNbR!U?q`;)o0&10NaSy&p)K-~Wf-_x~aY2V?*l_@4~WQmfNyLT&19 zovM=GwFc-VC>I`=Nz7Bg5LYq8@~e0aR0#MDZU9;eGl}2$?4HnDoL59$8b8074yi*K<@A!y=$Ml2L>+{Q3X!2d zmo?~%A4XsiRp=|u{gi^=;=bP(7xuFgH{VTolEhiwXxxfYxia%;)~i;%>YTURK2rU5 z9^}2O6?8wFUL18oXMa#C8QDSjG4AyDYEL&*ng?;(>5hf(e2UXZ^;@c!MwyxCeUKj^ z*DSPGTO16QSC*S~x!QO$tjj^O*{I8v*RO^{&s%uDw7$K6e10*w99~_Uy^_H9Ze-r! zFZc#y#KdX4nY805kBw47fYYd;Gxb@bt_8Gw|;* zpzj9>)#y7cESjqWjd=n9D{vcut$z-6j&$fdEG%LKB5W$qrV97O5H=lt>Ee8cg+-fA z!aY8OTUodliZH8Verdu<_!hZk2AF|K2FkWu)AfJr{`dc668D$^X5hbKKvXu{n=Nd~ z)z+!a=~^qH`%o=9uCO>tfniE9Vs$Bg1~me|)CSOZSXhJy!ao9r25y*vKgz&Q({Xl- diff --git a/gradle/httpurlconnection-asynctask/app/src/main/java/.DS_Store b/gradle/httpurlconnection-asynctask/app/src/main/java/.DS_Store deleted file mode 100644 index 9bf1062c9bdabc1cf291973ce54e9ee5e3be108a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK%}T>S5Z-O8CWx4Wpx$y3JoL~XwTK9z)`%PwNHq5tSH^Ug?)nU8Hn8g?~KqY2O7`_oXFLh2b=*a?dxrVs) z0^z}vT#n>FFd+9X%LE&+ZatXUzayC0{ZOI`!6+|@`nbz)UO(`oxKMcKnQU%pdBreI z!(20N8aINmwwn5NmUHP zcBIxhbK@T5suwk_?a`=IE>-gOUg2<@w?~yqA#axt_Qzwx*xV@|*IRcFkE5sY^NZdJ z4qvH~b;Jq0f`RqjHwIxK!Y+6w(UT}bVt^PR1{Q?@Jl~AfMJb5tAO?tmUt>U?4>qVo z2Qk&Cjt&@93jmk{w-T_`&p)6o9e@sEsu4UOT&Du+RE{kM$KHYKbeMNAKGmqx8CP$H zb@0s`I~0zs2e(x?KTLwN~~y^o@K0 zA4eyXRMhHGQJI0sH#?b0HeZ%x2LMF1+bjbV0Kh@jn8{=FiRgZ<|D zCsL<=G!o5@-^hU8yBq{?1s+_$oBdNh_UO-I19kD41g(*1zt?H`5k)`xttjjyrP7ng zjAh3sa!x+)YbLZsZ z`lf$7xVxv7fWWVoWZL2o9?h@|Mu7QKLv5a3@`)#lL3*f z)oWE;o4s2{R;lk=iF$&nMaQKEUsKSas~BVTRXm4Ef_|wDMAu?!5IrdTBS188!wmc= F11~soUt|CP diff --git a/gradle/httpurlconnection-asynctask/app/src/main/java/org/example/.DS_Store b/gradle/httpurlconnection-asynctask/app/src/main/java/org/example/.DS_Store deleted file mode 100644 index 58482d5adebe3668d7b91cf243fdb3f83498ed6b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHKF-`+P474Fak!VsUWY4b8 zvzwdZ9GjW1-yUzwR%W(@6Yan-H$JD&?5r{lgyW1Sd)W=+!+sd|v+C0caxd)JMtim4 z8=pVw7JmH^cKQHirGONW0#ZNnS z3P^!t1Zn@E;1?b*9v?BfO{LY diff --git a/gradle/httpurlconnection-asynctask/httpurlconnection-asynctask.iml b/gradle/httpurlconnection-asynctask/httpurlconnection-asynctask.iml deleted file mode 100644 index 2caa7e91a5..0000000000 --- a/gradle/httpurlconnection-asynctask/httpurlconnection-asynctask.iml +++ /dev/null @@ -1,35 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.DS_Store b/gradle/listview-baseadapter-data-object/.DS_Store deleted file mode 100644 index 680fa738039560829fadfe23f9c7c5145673e521..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK(QeZ)6un-%EoHzu32E?_2atH^rfvf&gpf)p50gM36^#c#U9v=5P!?BBx@eT5 zzVHtSzJOoh2lx;^0M2y`Bv}VMAq2jXeeCOdeSMGXxF#ae8F?E-bt1A*7^`Pc%@7{v zazf^`<~&gF9CFVMrHdXwM5 zn&;>24@+97eHwyQ4}N~pPpp>w7Jg#;rewR4w?&izqDa&}Fu^K)ic8Txmu6Tj%#aqX ziTC_%ZqJvB)`;jLtEA+`Oys>TBkO=-tmsIsDWx^#7h`?Q3IEy>wdOU|OQ2ap9xlCr zb`N9g@H?ci7)LN0#W?qMoE;sfPaVv~aqbl2^r;Iy$LZ61BQVj1C^{>=llQO>F@udlj#`- z3oN-I*+pStyJ?2X1(m*zRfDhMizrGkW^)7B);P@&8i@HL NplC3aVc?H4@D=F34!r;X diff --git a/gradle/listview-baseadapter-data-object/.gitignore b/gradle/listview-baseadapter-data-object/.gitignore index ccf2efe026..93deb134e3 100644 --- a/gradle/listview-baseadapter-data-object/.gitignore +++ b/gradle/listview-baseadapter-data-object/.gitignore @@ -1,8 +1,12 @@ + +# Created by https://www.gitignore.io/api/android,androidstudio,macos + +### Android ### # Built application files *.apk *.ap_ -# Files for the Dalvik VM +# Files for the ART/Dalvik VM *.dex # Java class files @@ -11,11 +15,11 @@ # Generated files bin/ gen/ +out/ # Gradle files .gradle/ build/ -/*/build/ # Local configuration file (sdk path, etc) local.properties @@ -25,3 +29,169 @@ proguard/ # Log Files *.log + +# Android Studio Navigation editor temp files +.navigation/ + +# Android Studio captures folder +captures/ + +# Intellij +*.iml +.idea/workspace.xml +.idea/tasks.xml +.idea/gradle.xml +.idea/dictionaries +.idea/libraries + +# Keystore files +*.jks + +# External native build folder generated in Android Studio 2.2 and later +.externalNativeBuild + +# Google Services (e.g. APIs or Firebase) +google-services.json + +# Freeline +freeline.py +freeline/ +freeline_project_description.json + +### Android Patch ### +gen-external-apklibs + +### AndroidStudio ### +# Covers files to be ignored for android development using Android Studio. + +# Built application files + +# Files for the ART/Dalvik VM + +# Java class files + +# Generated files + +# Gradle files +.gradle + +# Signing files +.signing/ + +# Local configuration file (sdk path, etc) + +# Proguard folder generated by Eclipse + +# Log Files + +# Android Studio +/*/build/ +/*/local.properties +/*/out +/*/*/build +/*/*/production +*.ipr +*~ +*.swp + +# Android Patch + +# External native build folder generated in Android Studio 2.2 and later + +# NDK +obj/ + +# IntelliJ IDEA +*.iws +/out/ + +# User-specific configurations +.idea/libraries/ +.idea/.name +.idea/compiler.xml +.idea/copyright/profiles_settings.xml +.idea/encodings.xml +.idea/misc.xml +.idea/modules.xml +.idea/scopes/scope_settings.xml +.idea/vcs.xml +.idea/jsLibraryMappings.xml +.idea/datasources.xml +.idea/dataSources.ids +.idea/sqlDataSources.xml +.idea/dynamic.xml +.idea/uiDesigner.xml + +# Keystore files + +# OS-specific files +.DS_Store +.DS_Store? +._* +.Spotlight-V100 +.Trashes +ehthumbs.db +Thumbs.db + +# Legacy Eclipse project files +.classpath +.project + +# Mobile Tools for Java (J2ME) +.mtj.tmp/ + +# Package Files # +*.jar +*.war +*.ear + +# virtual machine crash logs (Reference: http://www.java.com/en/download/help/error_hotspot.xml) +hs_err_pid* + +## Plugin-specific files: + +# mpeltonen/sbt-idea plugin +.idea_modules/ + +# JIRA plugin +atlassian-ide-plugin.xml + +# Mongo Explorer plugin +.idea/mongoSettings.xml + +# Crashlytics plugin (for Android Studio and IntelliJ) +com_crashlytics_export_strings.xml +crashlytics.properties +crashlytics-build.properties +fabric.properties + +### AndroidStudio Patch ### +# Google Services plugin + +!/gradle/wrapper/gradle-wrapper.jar + +### macOS ### +*.DS_Store +.AppleDouble +.LSOverride + +# Icon must end with two \r +Icon + +# Thumbnails + +# Files that might appear in the root of a volume +.DocumentRevisions-V100 +.fseventsd +.TemporaryItems +.VolumeIcon.icns +.com.apple.timemachine.donotpresent + +# Directories potentially created on remote AFP share +.AppleDB +.AppleDesktop +Network Trash Folder +Temporary Items +.apdisk + +# End of https://www.gitignore.io/api/android,androidstudio,macos diff --git a/gradle/listview-baseadapter-data-object/.idea/compiler.xml b/gradle/listview-baseadapter-data-object/.idea/compiler.xml deleted file mode 100644 index 96cc43efa6..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/compiler.xml +++ /dev/null @@ -1,22 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/copyright/profiles_settings.xml b/gradle/listview-baseadapter-data-object/.idea/copyright/profiles_settings.xml deleted file mode 100644 index e7bedf3377..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/copyright/profiles_settings.xml +++ /dev/null @@ -1,3 +0,0 @@ - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/gradle.xml b/gradle/listview-baseadapter-data-object/.idea/gradle.xml deleted file mode 100644 index 7ac24c777f..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/gradle.xml +++ /dev/null @@ -1,18 +0,0 @@ - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/animated_vector_drawable_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/animated_vector_drawable_25_3_1.xml deleted file mode 100644 index 986b1cda5a..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/libraries/animated_vector_drawable_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/annotations_13_0.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/annotations_13_0.xml deleted file mode 100644 index 24c0dcb114..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/libraries/annotations_13_0.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/appcompat_v7_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/appcompat_v7_25_3_1.xml deleted file mode 100644 index 9e612993e4..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/libraries/appcompat_v7_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/kotlin_stdlib_1_1_2.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/kotlin_stdlib_1_1_2.xml deleted file mode 100644 index c0993f57d5..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/libraries/kotlin_stdlib_1_1_2.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/support_annotations_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/support_annotations_25_3_1.xml deleted file mode 100644 index 42adfc6edf..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/libraries/support_annotations_25_3_1.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/support_compat_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/support_compat_25_3_1.xml deleted file mode 100644 index 1dff866919..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/libraries/support_compat_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/support_core_ui_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/support_core_ui_25_3_1.xml deleted file mode 100644 index c0bd9753a2..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/libraries/support_core_ui_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/support_core_utils_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/support_core_utils_25_3_1.xml deleted file mode 100644 index 406ceb21a7..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/libraries/support_core_utils_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/support_fragment_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/support_fragment_25_3_1.xml deleted file mode 100644 index a356b6caab..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/libraries/support_fragment_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/support_media_compat_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/support_media_compat_25_3_1.xml deleted file mode 100644 index 543c69e48e..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/libraries/support_media_compat_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/support_v4_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/support_v4_25_3_1.xml deleted file mode 100644 index 8eab02bac5..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/libraries/support_v4_25_3_1.xml +++ /dev/null @@ -1,10 +0,0 @@ - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/libraries/support_vector_drawable_25_3_1.xml b/gradle/listview-baseadapter-data-object/.idea/libraries/support_vector_drawable_25_3_1.xml deleted file mode 100644 index 91427afa49..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/libraries/support_vector_drawable_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/misc.xml b/gradle/listview-baseadapter-data-object/.idea/misc.xml deleted file mode 100644 index 7c32224c17..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/misc.xml +++ /dev/null @@ -1,62 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Android API 25 Platform - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/modules.xml b/gradle/listview-baseadapter-data-object/.idea/modules.xml deleted file mode 100644 index 3580ff2493..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/modules.xml +++ /dev/null @@ -1,9 +0,0 @@ - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/.idea/workspace.xml b/gradle/listview-baseadapter-data-object/.idea/workspace.xml deleted file mode 100644 index 3b1e0b0a4b..0000000000 --- a/gradle/listview-baseadapter-data-object/.idea/workspace.xml +++ /dev/null @@ -1,2451 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 1497970544901 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/app/.DS_Store b/gradle/listview-baseadapter-data-object/app/.DS_Store deleted file mode 100644 index 3b2e0efa7305c6e7705b833574ad18c738884030..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK-A)rh82zR#b{jD^h6KHv8xt>zDIhe2m~1LsaA#5@7eHW_ZD5mSr`aDHtTlV% zOXw5$D!u>@;sfZJpH{jBE{&1-nwc~E%{eojv+d3f5wUI_tP(Ye$U%`g3S?pOK< z)!rJn_^8uqxA^+z#(3;F%g - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/app/src/.DS_Store b/gradle/listview-baseadapter-data-object/app/src/.DS_Store deleted file mode 100644 index 7fc4e7c0d22ff93a67d2257c8abe2ad3793efb82..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK%}T>S5Z-O8CWzRBpx$y3JoJ#ZY7r4at%u%(iXK#IVu}r<+0vv2jgdTuzL78B zFDWkQGs%CVrs@P+Vsu2WJ_o+2RSYqWiK z<@n5jXTBiH-)DgDU5N~cO*|5O+P^)R+k6!w3d!S~I2@{des+ew7e=P}LJP&x-28&3 z>zcl#U3B^^?nHJp4x9GqOgwpR&r$Xa|f<@F?~)oYE4v1RV26(eah%!*Op*-leUTivMcw=V~`cgcPF@F+Kf z!j~#!S>Xhpz{o4S>5KxO1=rx4#82W7kpW}?8JK+r)XAnT&VDIa0WyFL{4fLjd@w*c zS_(6X;^=@uv;cr5a0>xj{Q3hL+yQ7Q%p`&bgvwMvnMzfQK~?8KWjf4TDn64a(+L%C zhIQ1Nsp?RuYCNbR!U?q`;)o0&10NaSy&p)K-~Wf-_x~aY2V?*l_@4~WQmfNyLT&19 zovM=GwFc-VC>I`=Nz7Bg5LYq8@~e0aR0#MDZU9;eGl}2$?4HnDoL59$8b8074yi*K<@A!y=$Ml2L>+{Q3X!2d zmo?~%A4XsiRp=|u{gi^=;=bP(7xuFgH{VTolEhiwXxxfYxia%;)~i;%>YTURK2rU5 z9^}2O6?8wFUL18oXMa#C8QDSjG4AyDYEL&*ng?;(>5hf(e2UXZ^;@c!MwyxCeUKj^ z*DSPGTO16QSC*S~x!QO$tjj^O*{I8v*RO^{&s%uDw7$K6e10*w99~_Uy^_H9Ze-r! zFZc#y#KdX4nY805kBw47fYYd;Gxb@bt_8Gw|;* zpzj9>)#y7cESjqWjd=n9D{vcut$z-6j&$fdEG%LKB5W$qrV97O5H=lt>Ee8cg+-fA z!aY8OTUodliZH8Verdu<_!hZk2AF|K2FkWu)AfJr{`dc668D$^X5hbKKvXu{n=Nd~ z)z+!a=~^qH`%o=9uCO>tfniE9Vs$Bg1~me|)CSOZSXhJy!ao9r25y*vKgz&Q({Xl- diff --git a/gradle/listview-baseadapter-data-object/app/src/main/java/.DS_Store b/gradle/listview-baseadapter-data-object/app/src/main/java/.DS_Store deleted file mode 100644 index 9bf1062c9bdabc1cf291973ce54e9ee5e3be108a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK%}T>S5Z-O8CWx4Wpx$y3JoL~XwTK9z)`%PwNHq5tSH^Ug?)nU8Hn8g?~KqY2O7`_oXFLh2b=*a?dxrVs) z0^z}vT#n>FFd+9X%LE&+ZatXUzayC0{ZOI`!6+|@`nbz)UO(`oxKMcKnQU%pdBreI z!(20N8aINmwwn5NmUHP zcBIxhbK@T5suwk_?a`=IE>-gOUg2<@w?~yqA#axt_Qzwx*xV@|*IRcFkE5sY^NZdJ z4qvH~b;Jq0f`RqjHwIxK!Y+6w(UT}bVt^PR1{Q?@Jl~AfMJb5tAO?tmUt>U?4>qVo z2Qk&Cjt&@93jmk{w-T_`&p)6o9e@sEsu4UOT&Du+RE{kM$KHYKbeMNAKGmqx8CP$H zb@0s`I~0zs2e(x?KTLwN~~y^o@K0 zA4eyXRMhHGQJI0sH#?b0HeZ%x2LMF1+bjbV0Kh@jn8{=FiRgZ<|D zCsL<=G!o5@-^hU8yBq{?1s+_$oBdNh_UO-I19kD41g(*1zt?H`5k)`xttjjyrP7ng zjAh3sa!x+)YbLZsZ z`lf$7xVxv7fWWVoWZL2o9?h@|Mu7QKLv5a3@`)#lL3*f z)oWE;o4s2{R;lk=iF$&nMaQKEUsKSas~BVTRXm4Ef_|wDMAu?!5IrdTBS188!wmc= F11~soUt|CP diff --git a/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/.DS_Store b/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/.DS_Store deleted file mode 100644 index 58482d5adebe3668d7b91cf243fdb3f83498ed6b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHKF-`+P474Fak!VsUWY4b8 zvzwdZ9GjW1-yUzwR%W(@6Yan-H$JD&?5r{lgyW1Sd)W=+!+sd|v+C0caxd)JMtim4 z8=pVw7JmH^cKQHirGONW0#ZNnS z3P^!t1Zn@E;1?b*9v?BfO{LY diff --git a/gradle/listview-baseadapter-data-object/listview-baseadapter-data-object.iml b/gradle/listview-baseadapter-data-object/listview-baseadapter-data-object.iml deleted file mode 100644 index 676e8ec4b9..0000000000 --- a/gradle/listview-baseadapter-data-object/listview-baseadapter-data-object.iml +++ /dev/null @@ -1,35 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.DS_Store b/gradle/okhttp-asynctask/.DS_Store deleted file mode 100644 index 356ecd1a6b672e73de837395ff650a1e77d80dce..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHKO>Wab6n@jBtwVvPQl!Gp8zdG1r7aL4gcL%N=mLS13KoD;yS5Umt|y8eq7s6# z;SLB+z*V>a2jKwlz3~)mw?u4;0L_zTzWI6Yn|YsOPlkv@d*p2pRf)(#VJx3Rb&Byk zmlL+2M=k;dbI5%+lrDNqXUr&I6!_Z};CHt~4h?9q6XxFEJD9opO_@qUd%5Fypx^S( z?jQ`}q|x{y7E0yCrDdy9u__m=mz};GcM>NV#cgN!T=fFacXfML%J4_qai0eMxLd8= zmr>#bkw471zjzizo*cL3DDq;(^TbK|h*b-9tCuH}&8^L5-M-PdJ+0f5X0uVZw{G2> zPAzNw%EsNDy~Cr|lQ+}1AJWGl@Rd@ws__^;qM`G9)fq;ijCvSh??rNHL;;2574-Rp z*{nY2e|pk&>d_FYdWiG$abmp?w=~E1UBP!P>x)$eSVf}tfeCi$Q(Rc>Yk^@o$1u)& z6F>9!nPt(*zFAvFpZ1^#6P`1@d^Ft#+#QdFM~RO$)< zEMr(1+Un0g(B=VPOXDm>jKD-13QR+VzG4V{cMxef=3Cl-mSP%CLahuQy|U0Z6rryk z!dC7iS}B^^C}0%GD^NCQYfKlMTQb3fqJKJrfq|eq9$?;ihqwJxu qvEM936@p41$Ev|c@g)>xn6tS7Y-yaOh!L3iBcNn3l~Lf2D)1eYTmq8- diff --git a/gradle/okhttp-asynctask/.gitignore b/gradle/okhttp-asynctask/.gitignore index ccf2efe026..93deb134e3 100644 --- a/gradle/okhttp-asynctask/.gitignore +++ b/gradle/okhttp-asynctask/.gitignore @@ -1,8 +1,12 @@ + +# Created by https://www.gitignore.io/api/android,androidstudio,macos + +### Android ### # Built application files *.apk *.ap_ -# Files for the Dalvik VM +# Files for the ART/Dalvik VM *.dex # Java class files @@ -11,11 +15,11 @@ # Generated files bin/ gen/ +out/ # Gradle files .gradle/ build/ -/*/build/ # Local configuration file (sdk path, etc) local.properties @@ -25,3 +29,169 @@ proguard/ # Log Files *.log + +# Android Studio Navigation editor temp files +.navigation/ + +# Android Studio captures folder +captures/ + +# Intellij +*.iml +.idea/workspace.xml +.idea/tasks.xml +.idea/gradle.xml +.idea/dictionaries +.idea/libraries + +# Keystore files +*.jks + +# External native build folder generated in Android Studio 2.2 and later +.externalNativeBuild + +# Google Services (e.g. APIs or Firebase) +google-services.json + +# Freeline +freeline.py +freeline/ +freeline_project_description.json + +### Android Patch ### +gen-external-apklibs + +### AndroidStudio ### +# Covers files to be ignored for android development using Android Studio. + +# Built application files + +# Files for the ART/Dalvik VM + +# Java class files + +# Generated files + +# Gradle files +.gradle + +# Signing files +.signing/ + +# Local configuration file (sdk path, etc) + +# Proguard folder generated by Eclipse + +# Log Files + +# Android Studio +/*/build/ +/*/local.properties +/*/out +/*/*/build +/*/*/production +*.ipr +*~ +*.swp + +# Android Patch + +# External native build folder generated in Android Studio 2.2 and later + +# NDK +obj/ + +# IntelliJ IDEA +*.iws +/out/ + +# User-specific configurations +.idea/libraries/ +.idea/.name +.idea/compiler.xml +.idea/copyright/profiles_settings.xml +.idea/encodings.xml +.idea/misc.xml +.idea/modules.xml +.idea/scopes/scope_settings.xml +.idea/vcs.xml +.idea/jsLibraryMappings.xml +.idea/datasources.xml +.idea/dataSources.ids +.idea/sqlDataSources.xml +.idea/dynamic.xml +.idea/uiDesigner.xml + +# Keystore files + +# OS-specific files +.DS_Store +.DS_Store? +._* +.Spotlight-V100 +.Trashes +ehthumbs.db +Thumbs.db + +# Legacy Eclipse project files +.classpath +.project + +# Mobile Tools for Java (J2ME) +.mtj.tmp/ + +# Package Files # +*.jar +*.war +*.ear + +# virtual machine crash logs (Reference: http://www.java.com/en/download/help/error_hotspot.xml) +hs_err_pid* + +## Plugin-specific files: + +# mpeltonen/sbt-idea plugin +.idea_modules/ + +# JIRA plugin +atlassian-ide-plugin.xml + +# Mongo Explorer plugin +.idea/mongoSettings.xml + +# Crashlytics plugin (for Android Studio and IntelliJ) +com_crashlytics_export_strings.xml +crashlytics.properties +crashlytics-build.properties +fabric.properties + +### AndroidStudio Patch ### +# Google Services plugin + +!/gradle/wrapper/gradle-wrapper.jar + +### macOS ### +*.DS_Store +.AppleDouble +.LSOverride + +# Icon must end with two \r +Icon + +# Thumbnails + +# Files that might appear in the root of a volume +.DocumentRevisions-V100 +.fseventsd +.TemporaryItems +.VolumeIcon.icns +.com.apple.timemachine.donotpresent + +# Directories potentially created on remote AFP share +.AppleDB +.AppleDesktop +Network Trash Folder +Temporary Items +.apdisk + +# End of https://www.gitignore.io/api/android,androidstudio,macos diff --git a/gradle/okhttp-asynctask/.idea/compiler.xml b/gradle/okhttp-asynctask/.idea/compiler.xml deleted file mode 100644 index 96cc43efa6..0000000000 --- a/gradle/okhttp-asynctask/.idea/compiler.xml +++ /dev/null @@ -1,22 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/copyright/profiles_settings.xml b/gradle/okhttp-asynctask/.idea/copyright/profiles_settings.xml deleted file mode 100644 index e7bedf3377..0000000000 --- a/gradle/okhttp-asynctask/.idea/copyright/profiles_settings.xml +++ /dev/null @@ -1,3 +0,0 @@ - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/gradle.xml b/gradle/okhttp-asynctask/.idea/gradle.xml deleted file mode 100644 index 7ac24c777f..0000000000 --- a/gradle/okhttp-asynctask/.idea/gradle.xml +++ /dev/null @@ -1,18 +0,0 @@ - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml deleted file mode 100644 index 986b1cda5a..0000000000 --- a/gradle/okhttp-asynctask/.idea/libraries/animated_vector_drawable_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/annotations_13_0.xml b/gradle/okhttp-asynctask/.idea/libraries/annotations_13_0.xml deleted file mode 100644 index 24c0dcb114..0000000000 --- a/gradle/okhttp-asynctask/.idea/libraries/annotations_13_0.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml deleted file mode 100644 index 9e612993e4..0000000000 --- a/gradle/okhttp-asynctask/.idea/libraries/appcompat_v7_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml b/gradle/okhttp-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml deleted file mode 100644 index c0993f57d5..0000000000 --- a/gradle/okhttp-asynctask/.idea/libraries/kotlin_stdlib_1_1_2.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/okhttp_2_3_0.xml b/gradle/okhttp-asynctask/.idea/libraries/okhttp_2_3_0.xml deleted file mode 100644 index e0ed48aea3..0000000000 --- a/gradle/okhttp-asynctask/.idea/libraries/okhttp_2_3_0.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/okio_1_3_0.xml b/gradle/okhttp-asynctask/.idea/libraries/okio_1_3_0.xml deleted file mode 100644 index 93a99cb20a..0000000000 --- a/gradle/okhttp-asynctask/.idea/libraries/okio_1_3_0.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/support_annotations_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/support_annotations_25_3_1.xml deleted file mode 100644 index 42adfc6edf..0000000000 --- a/gradle/okhttp-asynctask/.idea/libraries/support_annotations_25_3_1.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/support_compat_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/support_compat_25_3_1.xml deleted file mode 100644 index 1dff866919..0000000000 --- a/gradle/okhttp-asynctask/.idea/libraries/support_compat_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/support_core_ui_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/support_core_ui_25_3_1.xml deleted file mode 100644 index c0bd9753a2..0000000000 --- a/gradle/okhttp-asynctask/.idea/libraries/support_core_ui_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/support_core_utils_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/support_core_utils_25_3_1.xml deleted file mode 100644 index 406ceb21a7..0000000000 --- a/gradle/okhttp-asynctask/.idea/libraries/support_core_utils_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/support_fragment_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/support_fragment_25_3_1.xml deleted file mode 100644 index a356b6caab..0000000000 --- a/gradle/okhttp-asynctask/.idea/libraries/support_fragment_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/support_media_compat_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/support_media_compat_25_3_1.xml deleted file mode 100644 index 543c69e48e..0000000000 --- a/gradle/okhttp-asynctask/.idea/libraries/support_media_compat_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/support_v4_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/support_v4_25_3_1.xml deleted file mode 100644 index 8eab02bac5..0000000000 --- a/gradle/okhttp-asynctask/.idea/libraries/support_v4_25_3_1.xml +++ /dev/null @@ -1,10 +0,0 @@ - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml b/gradle/okhttp-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml deleted file mode 100644 index 91427afa49..0000000000 --- a/gradle/okhttp-asynctask/.idea/libraries/support_vector_drawable_25_3_1.xml +++ /dev/null @@ -1,12 +0,0 @@ - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/misc.xml b/gradle/okhttp-asynctask/.idea/misc.xml deleted file mode 100644 index 7c32224c17..0000000000 --- a/gradle/okhttp-asynctask/.idea/misc.xml +++ /dev/null @@ -1,62 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Android API 25 Platform - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/modules.xml b/gradle/okhttp-asynctask/.idea/modules.xml deleted file mode 100644 index 3187d3db9f..0000000000 --- a/gradle/okhttp-asynctask/.idea/modules.xml +++ /dev/null @@ -1,9 +0,0 @@ - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/.idea/workspace.xml b/gradle/okhttp-asynctask/.idea/workspace.xml deleted file mode 100644 index 486c74dfb7..0000000000 --- a/gradle/okhttp-asynctask/.idea/workspace.xml +++ /dev/null @@ -1,2436 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 1497970657926 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/app/.DS_Store b/gradle/okhttp-asynctask/app/.DS_Store deleted file mode 100644 index 3b2e0efa7305c6e7705b833574ad18c738884030..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK-A)rh82zR#b{jD^h6KHv8xt>zDIhe2m~1LsaA#5@7eHW_ZD5mSr`aDHtTlV% zOXw5$D!u>@;sfZJpH{jBE{&1-nwc~E%{eojv+d3f5wUI_tP(Ye$U%`g3S?pOK< z)!rJn_^8uqxA^+z#(3;F%g - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/gradle/okhttp-asynctask/app/src/.DS_Store b/gradle/okhttp-asynctask/app/src/.DS_Store deleted file mode 100644 index 7fc4e7c0d22ff93a67d2257c8abe2ad3793efb82..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK%}T>S5Z-O8CWzRBpx$y3JoJ#ZY7r4at%u%(iXK#IVu}r<+0vv2jgdTuzL78B zFDWkQGs%CVrs@P+Vsu2WJ_o+2RSYqWiK z<@n5jXTBiH-)DgDU5N~cO*|5O+P^)R+k6!w3d!S~I2@{des+ew7e=P}LJP&x-28&3 z>zcl#U3B^^?nHJp4x9GqOgwpR&r$Xa|f<@F?~)oYE4v1RV26(eah%!*Op*-leUTivMcw=V~`cgcPF@F+Kf z!j~#!S>Xhpz{o4S>5KxO1=rx4#82W7kpW}?8JK+r)XAnT&VDIa0WyFL{4fLjd@w*c zS_(6X;^=@uv;cr5a0>xj{Q3hL+yQ7Q%p`&bgvwMvnMzfQK~?8KWjf4TDn64a(+L%C zhIQ1Nsp?RuYCNbR!U?q`;)o0&10NaSy&p)K-~Wf-_x~aY2V?*l_@4~WQmfNyLT&19 zovM=GwFc-VC>I`=Nz7Bg5LYq8@~e0aR0#MDZU9;eGl}2$?4HnDoL59$8b8074yi*K<@A!y=$Ml2L>+{Q3X!2d zmo?~%A4XsiRp=|u{gi^=;=bP(7xuFgH{VTolEhiwXxxfYxia%;)~i;%>YTURK2rU5 z9^}2O6?8wFUL18oXMa#C8QDSjG4AyDYEL&*ng?;(>5hf(e2UXZ^;@c!MwyxCeUKj^ z*DSPGTO16QSC*S~x!QO$tjj^O*{I8v*RO^{&s%uDw7$K6e10*w99~_Uy^_H9Ze-r! zFZc#y#KdX4nY805kBw47fYYd;Gxb@bt_8Gw|;* zpzj9>)#y7cESjqWjd=n9D{vcut$z-6j&$fdEG%LKB5W$qrV97O5H=lt>Ee8cg+-fA z!aY8OTUodliZH8Verdu<_!hZk2AF|K2FkWu)AfJr{`dc668D$^X5hbKKvXu{n=Nd~ z)z+!a=~^qH`%o=9uCO>tfniE9Vs$Bg1~me|)CSOZSXhJy!ao9r25y*vKgz&Q({Xl- diff --git a/gradle/okhttp-asynctask/app/src/main/java/.DS_Store b/gradle/okhttp-asynctask/app/src/main/java/.DS_Store deleted file mode 100644 index 9bf1062c9bdabc1cf291973ce54e9ee5e3be108a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK%}T>S5Z-O8CWx4Wpx$y3JoL~XwTK9z)`%PwNHq5tSH^Ug?)nU8Hn8g?~KqY2O7`_oXFLh2b=*a?dxrVs) z0^z}vT#n>FFd+9X%LE&+ZatXUzayC0{ZOI`!6+|@`nbz)UO(`oxKMcKnQU%pdBreI z!(20N8aINmwwn5NmUHP zcBIxhbK@T5suwk_?a`=IE>-gOUg2<@w?~yqA#axt_Qzwx*xV@|*IRcFkE5sY^NZdJ z4qvH~b;Jq0f`RqjHwIxK!Y+6w(UT}bVt^PR1{Q?@Jl~AfMJb5tAO?tmUt>U?4>qVo z2Qk&Cjt&@93jmk{w-T_`&p)6o9e@sEsu4UOT&Du+RE{kM$KHYKbeMNAKGmqx8CP$H zb@0s`I~0zs2e(x?KTLwN~~y^o@K0 zA4eyXRMhHGQJI0sH#?b0HeZ%x2LMF1+bjbV0Kh@jn8{=FiRgZ<|D zCsL<=G!o5@-^hU8yBq{?1s+_$oBdNh_UO-I19kD41g(*1zt?H`5k)`xttjjyrP7ng zjAh3sa!x+)YbLZsZ z`lf$7xVxv7fWWVoWZL2o9?h@|Mu7QKLv5a3@`)#lL3*f z)oWE;o4s2{R;lk=iF$&nMaQKEUsKSas~BVTRXm4Ef_|wDMAu?!5IrdTBS188!wmc= F11~soUt|CP diff --git a/gradle/okhttp-asynctask/app/src/main/java/org/example/.DS_Store b/gradle/okhttp-asynctask/app/src/main/java/org/example/.DS_Store deleted file mode 100644 index 58482d5adebe3668d7b91cf243fdb3f83498ed6b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHKF-`+P474Fak!VsUWY4b8 zvzwdZ9GjW1-yUzwR%W(@6Yan-H$JD&?5r{lgyW1Sd)W=+!+sd|v+C0caxd)JMtim4 z8=pVw7JmH^cKQHirGONW0#ZNnS z3P^!t1Zn@E;1?b*9v?BfO{LY diff --git a/gradle/okhttp-asynctask/okhttp-asynctask.iml b/gradle/okhttp-asynctask/okhttp-asynctask.iml deleted file mode 100644 index 3191790291..0000000000 --- a/gradle/okhttp-asynctask/okhttp-asynctask.iml +++ /dev/null @@ -1,35 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file From 578047c57b5eda1c35507a776a8e76924cfa841f Mon Sep 17 00:00:00 2001 From: Axier Fernandez Date: Mon, 28 Aug 2017 09:10:05 +0200 Subject: [PATCH 6/9] Kotlin, anko, OkHttp and Gson libraries updated --- gradle/anko-asynchronous-tasks/app/build.gradle | 6 +++--- .../app/src/main/java/org/example/kotlin/MainActivity.kt | 3 +-- .../java/org/example/kotlin/networking/NetworkClient.kt | 6 +++--- gradle/anko-asynchronous-tasks/build.gradle | 4 ++-- gradle/anko-simple-ui/app/build.gradle | 6 +++--- .../app/src/main/java/org/example/kotlin/MainActivity.kt | 1 + .../java/org/example/kotlin/networking/NetworkClient.kt | 6 +++--- gradle/anko-simple-ui/build.gradle | 4 ++-- .../gson-deserializers-okhttp-asynctask/app/build.gradle | 4 ++-- .../java/org/example/kotlin/networking/NetworkClient.kt | 7 ++++--- gradle/gson-deserializers-okhttp-asynctask/build.gradle | 2 +- gradle/httpurlconnection-asynctask/build.gradle | 2 +- .../src/main/java/org/example/kotlin/models/CustomPojo.kt | 1 - gradle/listview-baseadapter-data-object/build.gradle | 2 +- gradle/okhttp-asynctask/app/build.gradle | 2 +- .../java/org/example/kotlin/networking/NetworkClient.kt | 7 ++++--- gradle/okhttp-asynctask/build.gradle | 2 +- 17 files changed, 33 insertions(+), 32 deletions(-) diff --git a/gradle/anko-asynchronous-tasks/app/build.gradle b/gradle/anko-asynchronous-tasks/app/build.gradle index f3eb37bbaf..5fba49ac2f 100644 --- a/gradle/anko-asynchronous-tasks/app/build.gradle +++ b/gradle/anko-asynchronous-tasks/app/build.gradle @@ -26,12 +26,12 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) compile 'com.android.support:appcompat-v7:25.3.1' - compile 'com.google.code.gson:gson:2.7' - compile 'com.squareup.okhttp:okhttp:2.3.0' + compile 'com.google.code.gson:gson:2.8.1' + compile 'com.squareup.okhttp3:okhttp:3.8.1' // Kotlin compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" // Anko - compile "org.jetbrains.anko:anko-sdk15:$anko_version" + compile "org.jetbrains.anko:anko:$anko_version" compile "org.jetbrains.anko:anko-support-v4:$anko_version" compile "org.jetbrains.anko:anko-appcompat-v7:$anko_version" } diff --git a/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/MainActivity.kt b/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/MainActivity.kt index 6dc0fe5461..ef43218bd3 100644 --- a/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/MainActivity.kt +++ b/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/MainActivity.kt @@ -8,9 +8,8 @@ import com.google.gson.GsonBuilder import org.example.kotlin.deserializers.WeatherDeserializer import org.example.kotlin.models.WeatherObject import org.example.kotlin.networking.NetworkClient - - import org.jetbrains.anko.* +import org.jetbrains.anko.sdk25.coroutines.onClick import java.io.BufferedInputStream import java.io.BufferedReader import java.io.InputStreamReader diff --git a/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt b/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt index 469d8df3d9..11734ea449 100644 --- a/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt +++ b/gradle/anko-asynchronous-tasks/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt @@ -1,7 +1,7 @@ package org.example.kotlin.networking -import com.squareup.okhttp.OkHttpClient -import com.squareup.okhttp.Request +import okhttp3.OkHttpClient +import okhttp3.Request import java.io.InputStream /** @@ -15,7 +15,7 @@ open class NetworkClient { val body = response.body() // body.toString() returns a string representing the object and not the body itself, probably // kotlins fault when using third party libraries. Use byteStream() and convert it to a String - return body.byteStream() + return body!!.byteStream() } } \ No newline at end of file diff --git a/gradle/anko-asynchronous-tasks/build.gradle b/gradle/anko-asynchronous-tasks/build.gradle index c889cdb581..6b87b1f870 100644 --- a/gradle/anko-asynchronous-tasks/build.gradle +++ b/gradle/anko-asynchronous-tasks/build.gradle @@ -2,8 +2,8 @@ buildscript { - ext.kotlin_version = '1.1.2' - ext.anko_version = '0.9.1' + ext.kotlin_version = '1.1.4-2' + ext.anko_version = '0.10.1' repositories { jcenter() diff --git a/gradle/anko-simple-ui/app/build.gradle b/gradle/anko-simple-ui/app/build.gradle index f3eb37bbaf..5fba49ac2f 100644 --- a/gradle/anko-simple-ui/app/build.gradle +++ b/gradle/anko-simple-ui/app/build.gradle @@ -26,12 +26,12 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) compile 'com.android.support:appcompat-v7:25.3.1' - compile 'com.google.code.gson:gson:2.7' - compile 'com.squareup.okhttp:okhttp:2.3.0' + compile 'com.google.code.gson:gson:2.8.1' + compile 'com.squareup.okhttp3:okhttp:3.8.1' // Kotlin compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" // Anko - compile "org.jetbrains.anko:anko-sdk15:$anko_version" + compile "org.jetbrains.anko:anko:$anko_version" compile "org.jetbrains.anko:anko-support-v4:$anko_version" compile "org.jetbrains.anko:anko-appcompat-v7:$anko_version" } diff --git a/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/MainActivity.kt b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/MainActivity.kt index f287b1dd24..437d4be2d5 100644 --- a/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/MainActivity.kt +++ b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/MainActivity.kt @@ -11,6 +11,7 @@ import org.example.kotlin.deserializers.WeatherDeserializer import org.example.kotlin.models.WeatherObject import org.example.kotlin.networking.NetworkClient import org.jetbrains.anko.* +import org.jetbrains.anko.sdk25.coroutines.onClick import java.io.BufferedInputStream import java.io.BufferedReader import java.io.InputStreamReader diff --git a/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt index 469d8df3d9..11734ea449 100644 --- a/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt +++ b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt @@ -1,7 +1,7 @@ package org.example.kotlin.networking -import com.squareup.okhttp.OkHttpClient -import com.squareup.okhttp.Request +import okhttp3.OkHttpClient +import okhttp3.Request import java.io.InputStream /** @@ -15,7 +15,7 @@ open class NetworkClient { val body = response.body() // body.toString() returns a string representing the object and not the body itself, probably // kotlins fault when using third party libraries. Use byteStream() and convert it to a String - return body.byteStream() + return body!!.byteStream() } } \ No newline at end of file diff --git a/gradle/anko-simple-ui/build.gradle b/gradle/anko-simple-ui/build.gradle index 5ef970de8d..1e9fce122d 100644 --- a/gradle/anko-simple-ui/build.gradle +++ b/gradle/anko-simple-ui/build.gradle @@ -2,8 +2,8 @@ buildscript { - ext.kotlin_version = '1.1.2' - ext.anko_version = '0.9.1' + ext.kotlin_version = '1.1.4-2' + ext.anko_version = '0.10.1' repositories { jcenter() diff --git a/gradle/gson-deserializers-okhttp-asynctask/app/build.gradle b/gradle/gson-deserializers-okhttp-asynctask/app/build.gradle index 65958439c5..1ee6f3afcb 100644 --- a/gradle/gson-deserializers-okhttp-asynctask/app/build.gradle +++ b/gradle/gson-deserializers-okhttp-asynctask/app/build.gradle @@ -27,8 +27,8 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) compile 'com.android.support:appcompat-v7:25.3.1' - compile 'com.google.code.gson:gson:2.7' - compile 'com.squareup.okhttp:okhttp:2.3.0' + compile 'com.google.code.gson:gson:2.8.1' + compile 'com.squareup.okhttp3:okhttp:3.8.1' compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" } diff --git a/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt index 469d8df3d9..70ec8704b1 100644 --- a/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt +++ b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt @@ -1,7 +1,8 @@ package org.example.kotlin.networking -import com.squareup.okhttp.OkHttpClient -import com.squareup.okhttp.Request + +import okhttp3.OkHttpClient +import okhttp3.Request import java.io.InputStream /** @@ -15,7 +16,7 @@ open class NetworkClient { val body = response.body() // body.toString() returns a string representing the object and not the body itself, probably // kotlins fault when using third party libraries. Use byteStream() and convert it to a String - return body.byteStream() + return body!!.byteStream() } } \ No newline at end of file diff --git a/gradle/gson-deserializers-okhttp-asynctask/build.gradle b/gradle/gson-deserializers-okhttp-asynctask/build.gradle index e6c80a40c6..54bbc3a1b0 100644 --- a/gradle/gson-deserializers-okhttp-asynctask/build.gradle +++ b/gradle/gson-deserializers-okhttp-asynctask/build.gradle @@ -2,7 +2,7 @@ buildscript { - ext.kotlin_version = '1.1.2' + ext.kotlin_version = '1.1.4-2' repositories { jcenter() diff --git a/gradle/httpurlconnection-asynctask/build.gradle b/gradle/httpurlconnection-asynctask/build.gradle index e6c80a40c6..54bbc3a1b0 100644 --- a/gradle/httpurlconnection-asynctask/build.gradle +++ b/gradle/httpurlconnection-asynctask/build.gradle @@ -2,7 +2,7 @@ buildscript { - ext.kotlin_version = '1.1.2' + ext.kotlin_version = '1.1.4-2' repositories { jcenter() diff --git a/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/models/CustomPojo.kt b/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/models/CustomPojo.kt index a066cebe09..0a3486c8ce 100644 --- a/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/models/CustomPojo.kt +++ b/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/models/CustomPojo.kt @@ -10,5 +10,4 @@ open class CustomPojo (var name: String) { println("Customer initialized with value ${name}") } - override fun toString() = "$name" } \ No newline at end of file diff --git a/gradle/listview-baseadapter-data-object/build.gradle b/gradle/listview-baseadapter-data-object/build.gradle index e6c80a40c6..54bbc3a1b0 100644 --- a/gradle/listview-baseadapter-data-object/build.gradle +++ b/gradle/listview-baseadapter-data-object/build.gradle @@ -2,7 +2,7 @@ buildscript { - ext.kotlin_version = '1.1.2' + ext.kotlin_version = '1.1.4-2' repositories { jcenter() diff --git a/gradle/okhttp-asynctask/app/build.gradle b/gradle/okhttp-asynctask/app/build.gradle index 087fc6d83a..5225185daa 100644 --- a/gradle/okhttp-asynctask/app/build.gradle +++ b/gradle/okhttp-asynctask/app/build.gradle @@ -27,7 +27,7 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) compile 'com.android.support:appcompat-v7:25.3.1' - compile 'com.squareup.okhttp:okhttp:2.3.0' + compile 'com.squareup.okhttp3:okhttp:3.8.1' compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" } diff --git a/gradle/okhttp-asynctask/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt b/gradle/okhttp-asynctask/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt index 469d8df3d9..70ec8704b1 100644 --- a/gradle/okhttp-asynctask/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt +++ b/gradle/okhttp-asynctask/app/src/main/java/org/example/kotlin/networking/NetworkClient.kt @@ -1,7 +1,8 @@ package org.example.kotlin.networking -import com.squareup.okhttp.OkHttpClient -import com.squareup.okhttp.Request + +import okhttp3.OkHttpClient +import okhttp3.Request import java.io.InputStream /** @@ -15,7 +16,7 @@ open class NetworkClient { val body = response.body() // body.toString() returns a string representing the object and not the body itself, probably // kotlins fault when using third party libraries. Use byteStream() and convert it to a String - return body.byteStream() + return body!!.byteStream() } } \ No newline at end of file diff --git a/gradle/okhttp-asynctask/build.gradle b/gradle/okhttp-asynctask/build.gradle index e6c80a40c6..54bbc3a1b0 100644 --- a/gradle/okhttp-asynctask/build.gradle +++ b/gradle/okhttp-asynctask/build.gradle @@ -2,7 +2,7 @@ buildscript { - ext.kotlin_version = '1.1.2' + ext.kotlin_version = '1.1.4-2' repositories { jcenter() From ba30b76798a7b68efe8b2ae310425269c13c6497 Mon Sep 17 00:00:00 2001 From: Axier Fernandez Date: Tue, 5 Dec 2017 09:51:46 +0100 Subject: [PATCH 7/9] Updated libraries to: Kotlin 1.1.51, Anko 0.10.3, OkHttp 3.9.0, Tools 26.0.2, Compat libraries to 26.1.0 --- gradle/anko-asynchronous-tasks/app/build.gradle | 10 +++++----- gradle/anko-asynchronous-tasks/build.gradle | 8 +++++--- .../gradle/wrapper/gradle-wrapper.properties | 4 ++-- gradle/anko-simple-ui/app/build.gradle | 10 +++++----- gradle/anko-simple-ui/build.gradle | 8 +++++--- .../gradle/wrapper/gradle-wrapper.properties | 4 ++-- .../app/build.gradle | 10 +++++----- .../gson-deserializers-okhttp-asynctask/build.gradle | 6 ++++-- .../gradle/wrapper/gradle-wrapper.properties | 4 ++-- gradle/httpurlconnection-asynctask/app/build.gradle | 8 ++++---- gradle/httpurlconnection-asynctask/build.gradle | 6 ++++-- .../gradle/wrapper/gradle-wrapper.properties | 4 ++-- .../listview-baseadapter-data-object/app/build.gradle | 8 ++++---- .../org/example/kotlin/adapters/CustomListAdapter.kt | 4 ++-- gradle/listview-baseadapter-data-object/build.gradle | 6 ++++-- .../gradle/wrapper/gradle-wrapper.properties | 4 ++-- gradle/okhttp-asynctask/app/build.gradle | 10 +++++----- gradle/okhttp-asynctask/build.gradle | 6 ++++-- .../gradle/wrapper/gradle-wrapper.properties | 4 ++-- 19 files changed, 68 insertions(+), 56 deletions(-) diff --git a/gradle/anko-asynchronous-tasks/app/build.gradle b/gradle/anko-asynchronous-tasks/app/build.gradle index 5fba49ac2f..9ce4272cca 100644 --- a/gradle/anko-asynchronous-tasks/app/build.gradle +++ b/gradle/anko-asynchronous-tasks/app/build.gradle @@ -2,13 +2,13 @@ apply plugin: 'com.android.application' apply plugin: 'kotlin-android' android { - compileSdkVersion 25 - buildToolsVersion "25.0.3" + compileSdkVersion 26 + buildToolsVersion "26.0.2" defaultConfig { applicationId "org.example.kotlin" minSdkVersion 16 - targetSdkVersion 25 + targetSdkVersion 26 versionCode 1 versionName "1.0" } @@ -25,9 +25,9 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:25.3.1' + compile 'com.android.support:appcompat-v7:26.1.0' compile 'com.google.code.gson:gson:2.8.1' - compile 'com.squareup.okhttp3:okhttp:3.8.1' + compile 'com.squareup.okhttp3:okhttp:3.9.0' // Kotlin compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" // Anko diff --git a/gradle/anko-asynchronous-tasks/build.gradle b/gradle/anko-asynchronous-tasks/build.gradle index 6b87b1f870..b6c4590aa8 100644 --- a/gradle/anko-asynchronous-tasks/build.gradle +++ b/gradle/anko-asynchronous-tasks/build.gradle @@ -2,15 +2,16 @@ buildscript { - ext.kotlin_version = '1.1.4-2' - ext.anko_version = '0.10.1' + ext.kotlin_version = '1.1.51' + ext.anko_version = '0.10.3' repositories { jcenter() + google() } dependencies { - classpath 'com.android.tools.build:gradle:2.3.3' + classpath 'com.android.tools.build:gradle:3.0.1' classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files @@ -20,5 +21,6 @@ buildscript { allprojects { repositories { jcenter() + google() } } diff --git a/gradle/anko-asynchronous-tasks/gradle/wrapper/gradle-wrapper.properties b/gradle/anko-asynchronous-tasks/gradle/wrapper/gradle-wrapper.properties index 4ebdf1a85c..2820bb057a 100644 --- a/gradle/anko-asynchronous-tasks/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/anko-asynchronous-tasks/gradle/wrapper/gradle-wrapper.properties @@ -1,6 +1,6 @@ -#Wed Jun 14 17:38:46 CEST 2017 +#Tue Dec 05 09:25:43 CET 2017 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-4.1-all.zip diff --git a/gradle/anko-simple-ui/app/build.gradle b/gradle/anko-simple-ui/app/build.gradle index 5fba49ac2f..9ce4272cca 100644 --- a/gradle/anko-simple-ui/app/build.gradle +++ b/gradle/anko-simple-ui/app/build.gradle @@ -2,13 +2,13 @@ apply plugin: 'com.android.application' apply plugin: 'kotlin-android' android { - compileSdkVersion 25 - buildToolsVersion "25.0.3" + compileSdkVersion 26 + buildToolsVersion "26.0.2" defaultConfig { applicationId "org.example.kotlin" minSdkVersion 16 - targetSdkVersion 25 + targetSdkVersion 26 versionCode 1 versionName "1.0" } @@ -25,9 +25,9 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:25.3.1' + compile 'com.android.support:appcompat-v7:26.1.0' compile 'com.google.code.gson:gson:2.8.1' - compile 'com.squareup.okhttp3:okhttp:3.8.1' + compile 'com.squareup.okhttp3:okhttp:3.9.0' // Kotlin compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" // Anko diff --git a/gradle/anko-simple-ui/build.gradle b/gradle/anko-simple-ui/build.gradle index 1e9fce122d..f45d495dcd 100644 --- a/gradle/anko-simple-ui/build.gradle +++ b/gradle/anko-simple-ui/build.gradle @@ -2,14 +2,15 @@ buildscript { - ext.kotlin_version = '1.1.4-2' - ext.anko_version = '0.10.1' + ext.kotlin_version = '1.1.51' + ext.anko_version = '0.10.3' repositories { jcenter() + google() } dependencies { - classpath 'com.android.tools.build:gradle:2.3.3' + classpath 'com.android.tools.build:gradle:3.0.1' classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" // NOTE: Do not place your application dependencies here; they belong @@ -20,5 +21,6 @@ buildscript { allprojects { repositories { jcenter() + google() } } diff --git a/gradle/anko-simple-ui/gradle/wrapper/gradle-wrapper.properties b/gradle/anko-simple-ui/gradle/wrapper/gradle-wrapper.properties index d241a61eeb..781debcd02 100644 --- a/gradle/anko-simple-ui/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/anko-simple-ui/gradle/wrapper/gradle-wrapper.properties @@ -1,6 +1,6 @@ -#Wed Jun 14 16:55:31 CEST 2017 +#Tue Dec 05 09:33:50 CET 2017 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-4.1-all.zip diff --git a/gradle/gson-deserializers-okhttp-asynctask/app/build.gradle b/gradle/gson-deserializers-okhttp-asynctask/app/build.gradle index 1ee6f3afcb..8702762f62 100644 --- a/gradle/gson-deserializers-okhttp-asynctask/app/build.gradle +++ b/gradle/gson-deserializers-okhttp-asynctask/app/build.gradle @@ -3,13 +3,13 @@ apply plugin: 'kotlin-android' apply plugin: 'kotlin-android-extensions' android { - compileSdkVersion 25 - buildToolsVersion "25.0.3" + compileSdkVersion 26 + buildToolsVersion "26.0.2" defaultConfig { applicationId "org.example.kotlin" minSdkVersion 16 - targetSdkVersion 25 + targetSdkVersion 26 versionCode 1 versionName "1.0" } @@ -26,9 +26,9 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:25.3.1' + compile 'com.android.support:appcompat-v7:26.1.0' compile 'com.google.code.gson:gson:2.8.1' - compile 'com.squareup.okhttp3:okhttp:3.8.1' + compile 'com.squareup.okhttp3:okhttp:3.9.0' compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" } diff --git a/gradle/gson-deserializers-okhttp-asynctask/build.gradle b/gradle/gson-deserializers-okhttp-asynctask/build.gradle index 54bbc3a1b0..a1995ec817 100644 --- a/gradle/gson-deserializers-okhttp-asynctask/build.gradle +++ b/gradle/gson-deserializers-okhttp-asynctask/build.gradle @@ -2,14 +2,15 @@ buildscript { - ext.kotlin_version = '1.1.4-2' + ext.kotlin_version = '1.1.51' repositories { jcenter() + google() } dependencies { - classpath 'com.android.tools.build:gradle:2.3.3' + classpath 'com.android.tools.build:gradle:3.0.1' classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files @@ -19,5 +20,6 @@ buildscript { allprojects { repositories { jcenter() + google() } } diff --git a/gradle/gson-deserializers-okhttp-asynctask/gradle/wrapper/gradle-wrapper.properties b/gradle/gson-deserializers-okhttp-asynctask/gradle/wrapper/gradle-wrapper.properties index f7fc37c8ca..4c81a54a1a 100644 --- a/gradle/gson-deserializers-okhttp-asynctask/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/gson-deserializers-okhttp-asynctask/gradle/wrapper/gradle-wrapper.properties @@ -1,6 +1,6 @@ -#Wed Jun 14 17:49:57 CEST 2017 +#Tue Dec 05 09:35:42 CET 2017 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-4.1-all.zip diff --git a/gradle/httpurlconnection-asynctask/app/build.gradle b/gradle/httpurlconnection-asynctask/app/build.gradle index f09567afc3..f6ce1ad155 100644 --- a/gradle/httpurlconnection-asynctask/app/build.gradle +++ b/gradle/httpurlconnection-asynctask/app/build.gradle @@ -3,13 +3,13 @@ apply plugin: 'kotlin-android' apply plugin: 'kotlin-android-extensions' android { - compileSdkVersion 25 - buildToolsVersion "25.0.3" + compileSdkVersion 26 + buildToolsVersion "26.0.2" defaultConfig { applicationId "org.example.kotlin" minSdkVersion 16 - targetSdkVersion 25 + targetSdkVersion 26 versionCode 1 versionName "1.0" } @@ -26,7 +26,7 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:25.3.1' + compile 'com.android.support:appcompat-v7:26.1.0' compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" } diff --git a/gradle/httpurlconnection-asynctask/build.gradle b/gradle/httpurlconnection-asynctask/build.gradle index 54bbc3a1b0..a1995ec817 100644 --- a/gradle/httpurlconnection-asynctask/build.gradle +++ b/gradle/httpurlconnection-asynctask/build.gradle @@ -2,14 +2,15 @@ buildscript { - ext.kotlin_version = '1.1.4-2' + ext.kotlin_version = '1.1.51' repositories { jcenter() + google() } dependencies { - classpath 'com.android.tools.build:gradle:2.3.3' + classpath 'com.android.tools.build:gradle:3.0.1' classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files @@ -19,5 +20,6 @@ buildscript { allprojects { repositories { jcenter() + google() } } diff --git a/gradle/httpurlconnection-asynctask/gradle/wrapper/gradle-wrapper.properties b/gradle/httpurlconnection-asynctask/gradle/wrapper/gradle-wrapper.properties index 5eb7593ab8..29d8f525bd 100644 --- a/gradle/httpurlconnection-asynctask/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/httpurlconnection-asynctask/gradle/wrapper/gradle-wrapper.properties @@ -1,6 +1,6 @@ -#Thu Jun 15 08:54:58 CEST 2017 +#Tue Dec 05 09:40:00 CET 2017 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-4.1-all.zip diff --git a/gradle/listview-baseadapter-data-object/app/build.gradle b/gradle/listview-baseadapter-data-object/app/build.gradle index f09567afc3..f6ce1ad155 100644 --- a/gradle/listview-baseadapter-data-object/app/build.gradle +++ b/gradle/listview-baseadapter-data-object/app/build.gradle @@ -3,13 +3,13 @@ apply plugin: 'kotlin-android' apply plugin: 'kotlin-android-extensions' android { - compileSdkVersion 25 - buildToolsVersion "25.0.3" + compileSdkVersion 26 + buildToolsVersion "26.0.2" defaultConfig { applicationId "org.example.kotlin" minSdkVersion 16 - targetSdkVersion 25 + targetSdkVersion 26 versionCode 1 versionName "1.0" } @@ -26,7 +26,7 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:25.3.1' + compile 'com.android.support:appcompat-v7:26.1.0' compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" } diff --git a/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/adapters/CustomListAdapter.kt b/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/adapters/CustomListAdapter.kt index ef1fe5fddd..2a9c9e1a19 100644 --- a/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/adapters/CustomListAdapter.kt +++ b/gradle/listview-baseadapter-data-object/app/src/main/java/org/example/kotlin/adapters/CustomListAdapter.kt @@ -45,7 +45,7 @@ open class CustomListAdapter(data: Array, context: Context) : BaseAd view = convertView vh = view.tag as ListRowHolder } - vh.label.text = localData.get(index = position).toString() + vh.label.text = localData.get(index = position).name return view } @@ -54,7 +54,7 @@ open class CustomListAdapter(data: Array, context: Context) : BaseAd val label: TextView init { - this.label = row?.findViewById(R.id.label) as TextView + this.label = row?.findViewById(R.id.label) as TextView } } diff --git a/gradle/listview-baseadapter-data-object/build.gradle b/gradle/listview-baseadapter-data-object/build.gradle index 54bbc3a1b0..a1995ec817 100644 --- a/gradle/listview-baseadapter-data-object/build.gradle +++ b/gradle/listview-baseadapter-data-object/build.gradle @@ -2,14 +2,15 @@ buildscript { - ext.kotlin_version = '1.1.4-2' + ext.kotlin_version = '1.1.51' repositories { jcenter() + google() } dependencies { - classpath 'com.android.tools.build:gradle:2.3.3' + classpath 'com.android.tools.build:gradle:3.0.1' classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files @@ -19,5 +20,6 @@ buildscript { allprojects { repositories { jcenter() + google() } } diff --git a/gradle/listview-baseadapter-data-object/gradle/wrapper/gradle-wrapper.properties b/gradle/listview-baseadapter-data-object/gradle/wrapper/gradle-wrapper.properties index 4cbbe3a25e..418c63b06d 100644 --- a/gradle/listview-baseadapter-data-object/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/listview-baseadapter-data-object/gradle/wrapper/gradle-wrapper.properties @@ -1,6 +1,6 @@ -#Thu Jun 15 09:00:23 CEST 2017 +#Tue Dec 05 09:41:27 CET 2017 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-4.1-all.zip diff --git a/gradle/okhttp-asynctask/app/build.gradle b/gradle/okhttp-asynctask/app/build.gradle index 5225185daa..697072e1bd 100644 --- a/gradle/okhttp-asynctask/app/build.gradle +++ b/gradle/okhttp-asynctask/app/build.gradle @@ -3,13 +3,13 @@ apply plugin: 'kotlin-android' apply plugin: 'kotlin-android-extensions' android { - compileSdkVersion 25 - buildToolsVersion "25.0.3" + compileSdkVersion 26 + buildToolsVersion "26.0.2" defaultConfig { applicationId "org.example.kotlin" minSdkVersion 16 - targetSdkVersion 25 + targetSdkVersion 26 versionCode 1 versionName "1.0" } @@ -26,8 +26,8 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:25.3.1' - compile 'com.squareup.okhttp3:okhttp:3.8.1' + compile 'com.android.support:appcompat-v7:26.1.0' + compile 'com.squareup.okhttp3:okhttp:3.9.0' compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" } diff --git a/gradle/okhttp-asynctask/build.gradle b/gradle/okhttp-asynctask/build.gradle index 54bbc3a1b0..a1995ec817 100644 --- a/gradle/okhttp-asynctask/build.gradle +++ b/gradle/okhttp-asynctask/build.gradle @@ -2,14 +2,15 @@ buildscript { - ext.kotlin_version = '1.1.4-2' + ext.kotlin_version = '1.1.51' repositories { jcenter() + google() } dependencies { - classpath 'com.android.tools.build:gradle:2.3.3' + classpath 'com.android.tools.build:gradle:3.0.1' classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version" // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files @@ -19,5 +20,6 @@ buildscript { allprojects { repositories { jcenter() + google() } } diff --git a/gradle/okhttp-asynctask/gradle/wrapper/gradle-wrapper.properties b/gradle/okhttp-asynctask/gradle/wrapper/gradle-wrapper.properties index 7dba5460c2..9c7644202e 100644 --- a/gradle/okhttp-asynctask/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/okhttp-asynctask/gradle/wrapper/gradle-wrapper.properties @@ -1,6 +1,6 @@ -#Thu Jun 15 09:09:03 CEST 2017 +#Tue Dec 05 09:48:07 CET 2017 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-4.1-all.zip From 85c56da77a8e8f91b7cc5e3bd597b2f51fb81c90 Mon Sep 17 00:00:00 2001 From: Axier Fernandez Date: Tue, 26 Dec 2017 10:26:05 +0100 Subject: [PATCH 8/9] Minor DS_Store removal --- .DS_Store | Bin 6148 -> 0 bytes 1 file changed, 0 insertions(+), 0 deletions(-) delete mode 100644 .DS_Store diff --git a/.DS_Store b/.DS_Store deleted file mode 100644 index c4b0b78bafad3ae99477db03f66ee86e2d386528..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHK%}T>S5Z-O8CWx4WV2`mkLT>Olyx9=r(=J*c#a32h)IB}ok$BY6#dBcH(6 zarURhP`!yrnSt4FGCQ-I{Ze*1gb->?y)GddAw&UX*id2kM%X;l1!+i66Oi&XLgKr5 zI&s6;U5G}fi6(orFP}8O8@~G+QgHYl^BW>V|S_kK^3VoNSs} zPIAqk0?&7)eG$ju+;-f{z|RNT)=3;?P7wLYm++gbAoAkeil>p6@^#LgYz(=4qk+~g zitheVN8d9J%Z^_3dIs3L2W6=!+dJLkv*G>YQ}JBByb5M1{0O;hN}RzP7_~!s>0Ri; zYqEse#DkqgVH}OXKU-|J2qH3o3?Ku`!+^Zul=bB~5}pJZKn8w^0d_y=pbSlkl|X)V zz`$Doz!tcrHqP-lSkejpmF|EE9q|2zl>WB?ghP6lYJZ}%-Yo2;!1r)0HO2OWYk pVR4nfc?uZ36hka4#cfb7;MbV}XiBUEf(Hcu2yhy3KnDJlflsh;SPK9E From 56cf1d53956c547acaf450eab8242f066faa8dae Mon Sep 17 00:00:00 2001 From: Axier Fernandez Date: Tue, 26 Dec 2017 10:37:41 +0100 Subject: [PATCH 9/9] Updated Kotlin, Gradle, OkHttp and Support libraries version. Also some minor changes to some classes --- gradle/anko-asynchronous-tasks/app/build.gradle | 10 +++++----- gradle/anko-asynchronous-tasks/build.gradle | 2 +- gradle/anko-simple-ui/app/build.gradle | 8 ++++---- .../src/main/java/org/example/kotlin/MainActivity.kt | 2 +- gradle/anko-simple-ui/build.gradle | 2 +- .../app/build.gradle | 10 +++++----- .../src/main/java/org/example/kotlin/MainActivity.kt | 2 +- .../gson-deserializers-okhttp-asynctask/build.gradle | 2 +- gradle/httpurlconnection-asynctask/app/build.gradle | 8 ++++---- .../src/main/java/org/example/kotlin/MainActivity.kt | 6 +----- gradle/httpurlconnection-asynctask/build.gradle | 2 +- .../listview-baseadapter-data-object/app/build.gradle | 8 ++++---- gradle/listview-baseadapter-data-object/build.gradle | 2 +- gradle/okhttp-asynctask/app/build.gradle | 10 +++++----- gradle/okhttp-asynctask/build.gradle | 2 +- 15 files changed, 36 insertions(+), 40 deletions(-) diff --git a/gradle/anko-asynchronous-tasks/app/build.gradle b/gradle/anko-asynchronous-tasks/app/build.gradle index 9ce4272cca..09bfae11ab 100644 --- a/gradle/anko-asynchronous-tasks/app/build.gradle +++ b/gradle/anko-asynchronous-tasks/app/build.gradle @@ -2,13 +2,13 @@ apply plugin: 'com.android.application' apply plugin: 'kotlin-android' android { - compileSdkVersion 26 - buildToolsVersion "26.0.2" + compileSdkVersion 27 + buildToolsVersion "27.0.2" defaultConfig { applicationId "org.example.kotlin" minSdkVersion 16 - targetSdkVersion 26 + targetSdkVersion 27 versionCode 1 versionName "1.0" } @@ -25,9 +25,9 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:26.1.0' + compile 'com.android.support:appcompat-v7:27.0.2' compile 'com.google.code.gson:gson:2.8.1' - compile 'com.squareup.okhttp3:okhttp:3.9.0' + compile 'com.squareup.okhttp3:okhttp:3.9.1' // Kotlin compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" // Anko diff --git a/gradle/anko-asynchronous-tasks/build.gradle b/gradle/anko-asynchronous-tasks/build.gradle index b6c4590aa8..ec58f63ed0 100644 --- a/gradle/anko-asynchronous-tasks/build.gradle +++ b/gradle/anko-asynchronous-tasks/build.gradle @@ -2,7 +2,7 @@ buildscript { - ext.kotlin_version = '1.1.51' + ext.kotlin_version = '1.2.0' ext.anko_version = '0.10.3' repositories { diff --git a/gradle/anko-simple-ui/app/build.gradle b/gradle/anko-simple-ui/app/build.gradle index 9ce4272cca..06dfbc923b 100644 --- a/gradle/anko-simple-ui/app/build.gradle +++ b/gradle/anko-simple-ui/app/build.gradle @@ -2,8 +2,8 @@ apply plugin: 'com.android.application' apply plugin: 'kotlin-android' android { - compileSdkVersion 26 - buildToolsVersion "26.0.2" + compileSdkVersion 27 + buildToolsVersion "27.0.2" defaultConfig { applicationId "org.example.kotlin" @@ -25,9 +25,9 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:26.1.0' + compile 'com.android.support:appcompat-v7:27.0.2' compile 'com.google.code.gson:gson:2.8.1' - compile 'com.squareup.okhttp3:okhttp:3.9.0' + compile 'com.squareup.okhttp3:okhttp:3.9.1' // Kotlin compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" // Anko diff --git a/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/MainActivity.kt b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/MainActivity.kt index 437d4be2d5..820644e73f 100644 --- a/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/MainActivity.kt +++ b/gradle/anko-simple-ui/app/src/main/java/org/example/kotlin/MainActivity.kt @@ -65,7 +65,7 @@ class MainActivity : AppCompatActivity() { } - fun readStream(inputStream: BufferedInputStream): String { + private fun readStream(inputStream: BufferedInputStream): String { val bufferedReader = BufferedReader(InputStreamReader(inputStream)) val stringBuilder = StringBuilder() bufferedReader.forEachLine { stringBuilder.append(it) } diff --git a/gradle/anko-simple-ui/build.gradle b/gradle/anko-simple-ui/build.gradle index f45d495dcd..1198b87b23 100644 --- a/gradle/anko-simple-ui/build.gradle +++ b/gradle/anko-simple-ui/build.gradle @@ -2,7 +2,7 @@ buildscript { - ext.kotlin_version = '1.1.51' + ext.kotlin_version = '1.2.0' ext.anko_version = '0.10.3' repositories { diff --git a/gradle/gson-deserializers-okhttp-asynctask/app/build.gradle b/gradle/gson-deserializers-okhttp-asynctask/app/build.gradle index 8702762f62..4ba3a87c7a 100644 --- a/gradle/gson-deserializers-okhttp-asynctask/app/build.gradle +++ b/gradle/gson-deserializers-okhttp-asynctask/app/build.gradle @@ -3,13 +3,13 @@ apply plugin: 'kotlin-android' apply plugin: 'kotlin-android-extensions' android { - compileSdkVersion 26 - buildToolsVersion "26.0.2" + compileSdkVersion 27 + buildToolsVersion "27.0.2" defaultConfig { applicationId "org.example.kotlin" minSdkVersion 16 - targetSdkVersion 26 + targetSdkVersion 27 versionCode 1 versionName "1.0" } @@ -26,9 +26,9 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:26.1.0' + compile 'com.android.support:appcompat-v7:27.0.2' compile 'com.google.code.gson:gson:2.8.1' - compile 'com.squareup.okhttp3:okhttp:3.9.0' + compile 'com.squareup.okhttp3:okhttp:3.9.1' compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" } diff --git a/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt index 56cfb05cb3..24c22a1f6f 100644 --- a/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt +++ b/gradle/gson-deserializers-okhttp-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt @@ -51,7 +51,7 @@ class MainActivity : AppCompatActivity() { } - fun readStream(inputStream: BufferedInputStream): String { + private fun readStream(inputStream: BufferedInputStream): String { val bufferedReader = BufferedReader(InputStreamReader(inputStream)) val stringBuilder = StringBuilder() bufferedReader.forEachLine { stringBuilder.append(it) } diff --git a/gradle/gson-deserializers-okhttp-asynctask/build.gradle b/gradle/gson-deserializers-okhttp-asynctask/build.gradle index a1995ec817..eac1a981da 100644 --- a/gradle/gson-deserializers-okhttp-asynctask/build.gradle +++ b/gradle/gson-deserializers-okhttp-asynctask/build.gradle @@ -2,7 +2,7 @@ buildscript { - ext.kotlin_version = '1.1.51' + ext.kotlin_version = '1.2.0' repositories { jcenter() diff --git a/gradle/httpurlconnection-asynctask/app/build.gradle b/gradle/httpurlconnection-asynctask/app/build.gradle index f6ce1ad155..2a6aa6745f 100644 --- a/gradle/httpurlconnection-asynctask/app/build.gradle +++ b/gradle/httpurlconnection-asynctask/app/build.gradle @@ -3,13 +3,13 @@ apply plugin: 'kotlin-android' apply plugin: 'kotlin-android-extensions' android { - compileSdkVersion 26 - buildToolsVersion "26.0.2" + compileSdkVersion 27 + buildToolsVersion "27.0.2" defaultConfig { applicationId "org.example.kotlin" minSdkVersion 16 - targetSdkVersion 26 + targetSdkVersion 27 versionCode 1 versionName "1.0" } @@ -26,7 +26,7 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:26.1.0' + compile 'com.android.support:appcompat-v7:27.0.2' compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" } diff --git a/gradle/httpurlconnection-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt b/gradle/httpurlconnection-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt index 0513f27f46..c59f11f958 100644 --- a/gradle/httpurlconnection-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt +++ b/gradle/httpurlconnection-asynctask/app/src/main/java/org/example/kotlin/MainActivity.kt @@ -47,17 +47,13 @@ class MainActivity : AppCompatActivity() { return null } - fun readStream(inputStream: BufferedInputStream): String { + private fun readStream(inputStream: BufferedInputStream): String { val bufferedReader = BufferedReader(InputStreamReader(inputStream)) val stringBuilder = StringBuilder() bufferedReader.forEachLine { stringBuilder.append(it) } return stringBuilder.toString() } - override fun onPreExecute() { - super.onPreExecute() - } - override fun onPostExecute(result: String?) { super.onPostExecute(result) diff --git a/gradle/httpurlconnection-asynctask/build.gradle b/gradle/httpurlconnection-asynctask/build.gradle index a1995ec817..eac1a981da 100644 --- a/gradle/httpurlconnection-asynctask/build.gradle +++ b/gradle/httpurlconnection-asynctask/build.gradle @@ -2,7 +2,7 @@ buildscript { - ext.kotlin_version = '1.1.51' + ext.kotlin_version = '1.2.0' repositories { jcenter() diff --git a/gradle/listview-baseadapter-data-object/app/build.gradle b/gradle/listview-baseadapter-data-object/app/build.gradle index f6ce1ad155..2a6aa6745f 100644 --- a/gradle/listview-baseadapter-data-object/app/build.gradle +++ b/gradle/listview-baseadapter-data-object/app/build.gradle @@ -3,13 +3,13 @@ apply plugin: 'kotlin-android' apply plugin: 'kotlin-android-extensions' android { - compileSdkVersion 26 - buildToolsVersion "26.0.2" + compileSdkVersion 27 + buildToolsVersion "27.0.2" defaultConfig { applicationId "org.example.kotlin" minSdkVersion 16 - targetSdkVersion 26 + targetSdkVersion 27 versionCode 1 versionName "1.0" } @@ -26,7 +26,7 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:26.1.0' + compile 'com.android.support:appcompat-v7:27.0.2' compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" } diff --git a/gradle/listview-baseadapter-data-object/build.gradle b/gradle/listview-baseadapter-data-object/build.gradle index a1995ec817..eac1a981da 100644 --- a/gradle/listview-baseadapter-data-object/build.gradle +++ b/gradle/listview-baseadapter-data-object/build.gradle @@ -2,7 +2,7 @@ buildscript { - ext.kotlin_version = '1.1.51' + ext.kotlin_version = '1.2.0' repositories { jcenter() diff --git a/gradle/okhttp-asynctask/app/build.gradle b/gradle/okhttp-asynctask/app/build.gradle index 697072e1bd..b523fd7b80 100644 --- a/gradle/okhttp-asynctask/app/build.gradle +++ b/gradle/okhttp-asynctask/app/build.gradle @@ -3,13 +3,13 @@ apply plugin: 'kotlin-android' apply plugin: 'kotlin-android-extensions' android { - compileSdkVersion 26 - buildToolsVersion "26.0.2" + compileSdkVersion 27 + buildToolsVersion "27.0.2" defaultConfig { applicationId "org.example.kotlin" minSdkVersion 16 - targetSdkVersion 26 + targetSdkVersion 27 versionCode 1 versionName "1.0" } @@ -26,8 +26,8 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:26.1.0' - compile 'com.squareup.okhttp3:okhttp:3.9.0' + compile 'com.android.support:appcompat-v7:27.0.2' + compile 'com.squareup.okhttp3:okhttp:3.9.1' compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version" } diff --git a/gradle/okhttp-asynctask/build.gradle b/gradle/okhttp-asynctask/build.gradle index a1995ec817..eac1a981da 100644 --- a/gradle/okhttp-asynctask/build.gradle +++ b/gradle/okhttp-asynctask/build.gradle @@ -2,7 +2,7 @@ buildscript { - ext.kotlin_version = '1.1.51' + ext.kotlin_version = '1.2.0' repositories { jcenter()