From 6e16aad79caa8d1812445329d0084e964a05e140 Mon Sep 17 00:00:00 2001 From: Joseph Henry Date: Thu, 23 Jun 2016 11:36:08 -0700 Subject: [PATCH] updated android/osx project and example project structure --- docs/android_zt_sdk.md | 2 +- .../UserInterfaceState.xcuserstate | Bin 56023 -> 54600 bytes .../android_jni_lib}/java/README.md | 0 .../android_jni_lib}/java/build.xml | 0 .../android_jni_lib}/java/jni/Android.mk | 4 +- .../android_jni_lib}/java/jni/Application.mk | 10 +- .../java/jni/ZT_jnilookup.cpp | 0 .../android_jni_lib}/java/jni/ZT_jnilookup.h | 0 .../android_jni_lib}/java/jni/ZT_jniutils.cpp | 0 .../android_jni_lib}/java/jni/ZT_jniutils.h | 0 .../java/jni/com_zerotierone_sdk_Node.cpp | 0 .../java/jni/com_zerotierone_sdk_Node.h | 0 .../zerotier/sdk/DataStoreGetListener.java | 0 .../zerotier/sdk/DataStorePutListener.java | 0 .../java/src/com/zerotier/sdk/Event.java | 0 .../src/com/zerotier/sdk/EventListener.java | 0 .../src/com/zerotier/sdk/MulticastGroup.java | 0 .../src/com/zerotier/sdk/NativeUtils.java | 0 .../java/src/com/zerotier/sdk/Node.java | 0 .../src/com/zerotier/sdk/NodeException.java | 0 .../java/src/com/zerotier/sdk/NodeStatus.java | 0 .../src/com/zerotier/sdk/PacketSender.java | 0 .../java/src/com/zerotier/sdk/Peer.java | 0 .../com/zerotier/sdk/PeerPhysicalPath.java | 0 .../java/src/com/zerotier/sdk/PeerRole.java | 0 .../java/src/com/zerotier/sdk/ResultCode.java | 0 .../java/src/com/zerotier/sdk/Version.java | 0 .../zerotier/sdk/VirtualNetworkConfig.java | 0 .../sdk/VirtualNetworkConfigListener.java | 0 .../sdk/VirtualNetworkConfigOperation.java | 0 .../sdk/VirtualNetworkFrameListener.java | 0 .../zerotier/sdk/VirtualNetworkStatus.java | 0 .../com/zerotier/sdk/VirtualNetworkType.java | 0 .../android_jni_lib}/proj/README.md | 0 .../android_jni_lib}/proj/app/app.iml | 0 .../android_jni_lib}/proj/app/build.gradle | 2 +- .../proj/app/google-services.json | 0 .../proj/app/proguard-rules.pro | 0 .../com/zerotier/one/ApplicationTest.java | 0 .../proj/app/src/main/AndroidManifest.xml | 0 .../proj/app/src/main/ic_launcher-web.png | Bin .../src/main/java/Netcon/ZT_SDK_Wrapper.java | 0 .../zerotier/one/AnalyticsApplication.java | 0 .../com/zerotier/one/AnalyticsTrackers.java | 0 .../com/zerotier/one/events/ErrorEvent.java | 0 .../zerotier/one/events/JoinNetworkEvent.java | 0 .../one/events/LeaveNetworkEvent.java | 0 .../one/events/ManualDisconnectEvent.java | 0 .../one/events/NetworkInfoReplyEvent.java | 0 .../one/events/NetworkListReplyEvent.java | 0 .../one/events/NetworkReconfigureEvent.java | 0 .../one/events/NetworkRemovedEvent.java | 0 .../one/events/NodeDestroyedEvent.java | 0 .../com/zerotier/one/events/NodeIDEvent.java | 0 .../zerotier/one/events/NodeStatusEvent.java | 0 .../one/events/RequestNetworkInfoEvent.java | 0 .../one/events/RequestNetworkListEvent.java | 0 .../one/events/RequestNodeStatusEvent.java | 0 .../com/zerotier/one/events/StopEvent.java | 0 .../com/zerotier/one/service/ARPTable.java | 0 .../com/zerotier/one/service/DataStore.java | 0 .../one/service/NetworkStateReceiver.java | 0 .../java/com/zerotier/one/service/Route.java | 0 .../zerotier/one/service/RuntimeService.java | 0 .../zerotier/one/service/StartupReceiver.java | 0 .../zerotier/one/service/TunTapAdapter.java | 0 .../java/com/zerotier/one/service/UdpCom.java | 0 .../one/service/ZeroTierOneService.java | 0 .../java/com/zerotier/one/ui/HexKeyboard.java | 0 .../zerotier/one/ui/JoinNetworkActivity.java | 0 .../zerotier/one/ui/JoinNetworkFragment.java | 0 .../zerotier/one/ui/NetworkListActivity.java | 0 .../zerotier/one/ui/NetworkListFragment.java | 0 .../com/zerotier/one/ui/PrefsActivity.java | 0 .../com/zerotier/one/ui/PrefsFragment.java | 0 .../one/ui/SingleFragmentActivity.java | 0 .../com/zerotier/one/util/IPPacketUtils.java | 0 .../zerotier/one/util/InetAddressUtils.java | 0 .../com/zerotier/one/util/NetworkIdUtils.java | 0 .../src/main/res/drawable/button_style.xml | 0 .../proj/app/src/main/res/drawable/hex.png | Bin .../app/src/main/res/drawable/ic_launcher.png | Bin .../res/drawable/sym_keyboard_allleft.png | Bin .../res/drawable/sym_keyboard_allright.png | Bin .../main/res/drawable/sym_keyboard_delete.png | Bin .../main/res/drawable/sym_keyboard_done.png | Bin .../main/res/drawable/sym_keyboard_left.png | Bin .../main/res/drawable/sym_keyboard_return.png | Bin .../main/res/drawable/sym_keyboard_right.png | Bin .../proj/app/src/main/res/drawable/txt.png | Bin .../src/main/res/layout/activity_fragment.xml | 0 .../main/res/layout/fragment_join_network.xml | 0 .../src/main/res/layout/list_item_network.xml | 0 .../res/layout/list_item_recent_network.xml | 0 .../main/res/layout/network_list_fragment.xml | 0 .../src/main/res/menu/menu_network_list.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 .../main/res/mipmap-xxxhdpi/ic_launcher.png | Bin .../app/src/main/res/values-w820dp/dimens.xml | 0 .../proj/app/src/main/res/values/dimens.xml | 0 .../proj/app/src/main/res/values/strings.xml | 0 .../proj/app/src/main/res/values/styles.xml | 0 .../proj/app/src/main/res/xml/app_tracker.xml | 0 .../app/src/main/res/xml/hex_keyboard.xml | 0 .../proj/app/src/main/res/xml/preferences.xml | 0 .../android_jni_lib}/proj/build.gradle | 0 .../android_jni_lib}/proj/gradle.properties | 0 .../proj/gradle/wrapper/gradle-wrapper.jar | Bin .../gradle/wrapper/gradle-wrapper.properties | 0 .../android_jni_lib}/proj/gradlew | 0 .../android_jni_lib}/proj/gradlew.bat | 0 .../android_jni_lib}/proj/local.properties | 0 .../android_jni_lib}/proj/proj.iml | 0 .../android_jni_lib}/proj/settings.gradle | 0 .../android_jni_lib}/proj/zerotierandroid.iml | 0 integrations/android/example_app/.gitignore | 8 + .../android/example_app/app/.gitignore | 1 + .../android/example_app/app/build.gradle | 30 ++++ .../example_app/app/proguard-rules.pro | 17 ++ .../ExampleInstrumentationTest.java | 29 ++++ .../app/src/main/AndroidManifest.xml | 24 +++ .../ZeroTierSDK/ZeroTierSDK/ZeroTierSDK.java | 5 + .../example_android_app/MainActivity.java | 21 +++ .../app/src/main/res/layout/activity_main.xml | 19 +++ .../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 .../main/res/mipmap-xxxhdpi/ic_launcher.png | Bin 0 -> 10486 bytes .../app/src/main/res/values-w820dp/dimens.xml | 6 + .../app/src/main/res/values/colors.xml | 6 + .../app/src/main/res/values/dimens.xml | 5 + .../app/src/main/res/values/strings.xml | 3 + .../app/src/main/res/values/styles.xml | 11 ++ .../example_android_app/ExampleUnitTest.java | 17 ++ integrations/android/example_app/build.gradle | 23 +++ .../android/example_app/gradle.properties | 20 +++ .../gradle/wrapper/gradle-wrapper.jar | Bin 0 -> 53636 bytes .../gradle/wrapper/gradle-wrapper.properties | 6 + integrations/android/example_app/gradlew | 160 ++++++++++++++++++ integrations/android/example_app/gradlew.bat | 90 ++++++++++ .../android/example_app/settings.gradle | 1 + .../Example_OSX_App.xcodeproj/project.pbxproj | 0 .../contents.xcworkspacedata | 0 .../UserInterfaceState.xcuserstate | Bin .../xcschemes/Example_OSX_App.xcscheme | 0 .../xcschemes/xcschememanagement.plist | 0 .../Example_OSX_App/AppDelegate.swift | 0 .../AppIcon.appiconset/Contents.json | 0 .../Base.lproj/Main.storyboard | 0 .../example_app}/Example_OSX_App/Info.plist | 0 .../Example_OSX_App/ViewController.swift | 0 make-mac.mk | 22 ++- src/SDK_ServiceSetup.cpp | 2 +- src/SDK_ServiceSetup.hpp | 2 +- 158 files changed, 530 insertions(+), 16 deletions(-) rename integrations/{Android => android/android_jni_lib}/java/README.md (100%) rename integrations/{Android => android/android_jni_lib}/java/build.xml (100%) rename integrations/{Android => android/android_jni_lib}/java/jni/Android.mk (98%) rename integrations/{Android => android/android_jni_lib}/java/jni/Application.mk (64%) rename integrations/{Android => android/android_jni_lib}/java/jni/ZT_jnilookup.cpp (100%) rename integrations/{Android => android/android_jni_lib}/java/jni/ZT_jnilookup.h (100%) rename integrations/{Android => android/android_jni_lib}/java/jni/ZT_jniutils.cpp (100%) rename integrations/{Android => android/android_jni_lib}/java/jni/ZT_jniutils.h (100%) rename integrations/{Android => android/android_jni_lib}/java/jni/com_zerotierone_sdk_Node.cpp (100%) rename integrations/{Android => android/android_jni_lib}/java/jni/com_zerotierone_sdk_Node.h (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/DataStoreGetListener.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/DataStorePutListener.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/Event.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/EventListener.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/MulticastGroup.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/NativeUtils.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/Node.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/NodeException.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/NodeStatus.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/PacketSender.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/Peer.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/PeerPhysicalPath.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/PeerRole.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/ResultCode.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/Version.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/VirtualNetworkConfig.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/VirtualNetworkConfigListener.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/VirtualNetworkConfigOperation.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/VirtualNetworkFrameListener.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/VirtualNetworkStatus.java (100%) rename integrations/{Android => android/android_jni_lib}/java/src/com/zerotier/sdk/VirtualNetworkType.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/README.md (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/app.iml (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/build.gradle (96%) rename integrations/{Android => android/android_jni_lib}/proj/app/google-services.json (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/proguard-rules.pro (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/androidTest/java/com/zerotier/one/ApplicationTest.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/AndroidManifest.xml (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/ic_launcher-web.png (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/Netcon/ZT_SDK_Wrapper.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/AnalyticsApplication.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/AnalyticsTrackers.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/events/ErrorEvent.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/events/JoinNetworkEvent.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/events/LeaveNetworkEvent.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/events/ManualDisconnectEvent.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/events/NetworkInfoReplyEvent.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/events/NetworkListReplyEvent.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/events/NetworkReconfigureEvent.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/events/NetworkRemovedEvent.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/events/NodeDestroyedEvent.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/events/NodeIDEvent.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/events/NodeStatusEvent.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/events/RequestNetworkInfoEvent.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/events/RequestNetworkListEvent.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/events/RequestNodeStatusEvent.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/events/StopEvent.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/service/ARPTable.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/service/DataStore.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/service/NetworkStateReceiver.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/service/Route.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/service/RuntimeService.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/service/StartupReceiver.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/service/TunTapAdapter.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/service/UdpCom.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/service/ZeroTierOneService.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/ui/HexKeyboard.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/ui/JoinNetworkActivity.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/ui/JoinNetworkFragment.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/ui/NetworkListActivity.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/ui/NetworkListFragment.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/ui/PrefsActivity.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/ui/PrefsFragment.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/ui/SingleFragmentActivity.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/util/IPPacketUtils.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/util/InetAddressUtils.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/java/com/zerotier/one/util/NetworkIdUtils.java (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/drawable/button_style.xml (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/drawable/hex.png (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/drawable/ic_launcher.png (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/drawable/sym_keyboard_allleft.png (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/drawable/sym_keyboard_allright.png (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/drawable/sym_keyboard_delete.png (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/drawable/sym_keyboard_done.png (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/drawable/sym_keyboard_left.png (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/drawable/sym_keyboard_return.png (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/drawable/sym_keyboard_right.png (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/drawable/txt.png (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/layout/activity_fragment.xml (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/layout/fragment_join_network.xml (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/layout/list_item_network.xml (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/layout/list_item_recent_network.xml (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/layout/network_list_fragment.xml (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/menu/menu_network_list.xml (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/mipmap-hdpi/ic_launcher.png (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/mipmap-mdpi/ic_launcher.png (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/mipmap-xhdpi/ic_launcher.png (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/mipmap-xxhdpi/ic_launcher.png (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/values-w820dp/dimens.xml (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/values/dimens.xml (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/values/strings.xml (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/values/styles.xml (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/xml/app_tracker.xml (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/xml/hex_keyboard.xml (100%) rename integrations/{Android => android/android_jni_lib}/proj/app/src/main/res/xml/preferences.xml (100%) rename integrations/{Android => android/android_jni_lib}/proj/build.gradle (100%) rename integrations/{Android => android/android_jni_lib}/proj/gradle.properties (100%) rename integrations/{Android => android/android_jni_lib}/proj/gradle/wrapper/gradle-wrapper.jar (100%) rename integrations/{Android => android/android_jni_lib}/proj/gradle/wrapper/gradle-wrapper.properties (100%) rename integrations/{Android => android/android_jni_lib}/proj/gradlew (100%) rename integrations/{Android => android/android_jni_lib}/proj/gradlew.bat (100%) rename integrations/{Android => android/android_jni_lib}/proj/local.properties (100%) rename integrations/{Android => android/android_jni_lib}/proj/proj.iml (100%) rename integrations/{Android => android/android_jni_lib}/proj/settings.gradle (100%) rename integrations/{Android => android/android_jni_lib}/proj/zerotierandroid.iml (100%) create mode 100644 integrations/android/example_app/.gitignore create mode 100644 integrations/android/example_app/app/.gitignore create mode 100644 integrations/android/example_app/app/build.gradle create mode 100644 integrations/android/example_app/app/proguard-rules.pro create mode 100644 integrations/android/example_app/app/src/androidTest/java/com/example/joseph/example_android_app/ExampleInstrumentationTest.java create mode 100644 integrations/android/example_app/app/src/main/AndroidManifest.xml create mode 100644 integrations/android/example_app/app/src/main/java/ZeroTierSDK/ZeroTierSDK/ZeroTierSDK.java create mode 100644 integrations/android/example_app/app/src/main/java/com/example/joseph/example_android_app/MainActivity.java create mode 100644 integrations/android/example_app/app/src/main/res/layout/activity_main.xml create mode 100644 integrations/android/example_app/app/src/main/res/mipmap-hdpi/ic_launcher.png create mode 100644 integrations/android/example_app/app/src/main/res/mipmap-mdpi/ic_launcher.png create mode 100644 integrations/android/example_app/app/src/main/res/mipmap-xhdpi/ic_launcher.png create mode 100644 integrations/android/example_app/app/src/main/res/mipmap-xxhdpi/ic_launcher.png create mode 100644 integrations/android/example_app/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png create mode 100644 integrations/android/example_app/app/src/main/res/values-w820dp/dimens.xml create mode 100644 integrations/android/example_app/app/src/main/res/values/colors.xml create mode 100644 integrations/android/example_app/app/src/main/res/values/dimens.xml create mode 100644 integrations/android/example_app/app/src/main/res/values/strings.xml create mode 100644 integrations/android/example_app/app/src/main/res/values/styles.xml create mode 100644 integrations/android/example_app/app/src/test/java/com/example/joseph/example_android_app/ExampleUnitTest.java create mode 100644 integrations/android/example_app/build.gradle create mode 100644 integrations/android/example_app/gradle.properties create mode 100644 integrations/android/example_app/gradle/wrapper/gradle-wrapper.jar create mode 100644 integrations/android/example_app/gradle/wrapper/gradle-wrapper.properties create mode 100755 integrations/android/example_app/gradlew create mode 100644 integrations/android/example_app/gradlew.bat create mode 100644 integrations/android/example_app/settings.gradle rename integrations/{Apple/Example_OSX_App => apple/example_app}/Example_OSX_App.xcodeproj/project.pbxproj (100%) rename integrations/{Apple/Example_OSX_App => apple/example_app}/Example_OSX_App.xcodeproj/project.xcworkspace/contents.xcworkspacedata (100%) rename integrations/{Apple/Example_OSX_App => apple/example_app}/Example_OSX_App.xcodeproj/project.xcworkspace/xcuserdata/Joseph.xcuserdatad/UserInterfaceState.xcuserstate (100%) rename integrations/{Apple/Example_OSX_App => apple/example_app}/Example_OSX_App.xcodeproj/xcuserdata/Joseph.xcuserdatad/xcschemes/Example_OSX_App.xcscheme (100%) rename integrations/{Apple/Example_OSX_App => apple/example_app}/Example_OSX_App.xcodeproj/xcuserdata/Joseph.xcuserdatad/xcschemes/xcschememanagement.plist (100%) rename integrations/{Apple/Example_OSX_App => apple/example_app}/Example_OSX_App/AppDelegate.swift (100%) rename integrations/{Apple/Example_OSX_App => apple/example_app}/Example_OSX_App/Assets.xcassets/AppIcon.appiconset/Contents.json (100%) rename integrations/{Apple/Example_OSX_App => apple/example_app}/Example_OSX_App/Base.lproj/Main.storyboard (100%) rename integrations/{Apple/Example_OSX_App => apple/example_app}/Example_OSX_App/Info.plist (100%) rename integrations/{Apple/Example_OSX_App => apple/example_app}/Example_OSX_App/ViewController.swift (100%) diff --git a/docs/android_zt_sdk.md b/docs/android_zt_sdk.md index 748f185..e19cd3f 100644 --- a/docs/android_zt_sdk.md +++ b/docs/android_zt_sdk.md @@ -16,7 +16,7 @@ In this example we aim to set up a minimal [Android Studio](https://developer.an **Step 2: Build Shared Library** - `make android_jni_lib` - - The resultant `build/android_jni_lib_YOUR_ARCH/libZeroTierOneJNI.so` is what you want to import into your own project to provide the API to your app. Select your architecture and copy the shared library into `YourProject/src/main/jniLibs/YOUR_ARCH/`. Selecting only the architectures you need will *significantly* reduce overall build time. + - The resultant `build/android_jni_lib_YOUR_ARCH/libZeroTierOneJNI.so` is what you want to import into your own project to provide the API to your app. Select your architecture and copy the shared library into your project's JNI directory, possibly `/src/main/jniLibs/YOUR_ARCH/`. Selecting only the architectures you need will *significantly* reduce overall build time. **Step 3: App Code Modifications** - Create new package called `ZeroTierSDK` in your project and add a new file called `ZeroTierSDK.java` containing: diff --git a/integrations/Apple/ZeroTierSDK_Apple/ZeroTierSDK_Apple.xcodeproj/project.xcworkspace/xcuserdata/Joseph.xcuserdatad/UserInterfaceState.xcuserstate b/integrations/Apple/ZeroTierSDK_Apple/ZeroTierSDK_Apple.xcodeproj/project.xcworkspace/xcuserdata/Joseph.xcuserdatad/UserInterfaceState.xcuserstate index 6ac21d7912a7cc202b31967099188952e6e64876..d59d34f088204c5e80aed6898411a1cfa6944968 100644 GIT binary patch delta 25510 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%0ArzG4mK<2lP>BA+reLM<9;w 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 L{mcJn)zbd}3pTf4 diff --git a/integrations/Android/java/README.md b/integrations/android/android_jni_lib/java/README.md similarity index 100% rename from integrations/Android/java/README.md rename to integrations/android/android_jni_lib/java/README.md diff --git a/integrations/Android/java/build.xml b/integrations/android/android_jni_lib/java/build.xml similarity index 100% rename from integrations/Android/java/build.xml rename to integrations/android/android_jni_lib/java/build.xml diff --git a/integrations/Android/java/jni/Android.mk b/integrations/android/android_jni_lib/java/jni/Android.mk similarity index 98% rename from integrations/Android/java/jni/Android.mk rename to integrations/android/android_jni_lib/java/jni/Android.mk index 859cb40..85d3943 100644 --- a/integrations/Android/java/jni/Android.mk +++ b/integrations/android/android_jni_lib/java/jni/Android.mk @@ -2,8 +2,8 @@ LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) -ZTSDK := ../../../../src -ZT := ../../../../zerotierone +ZTSDK := ../../../../../src +ZT := ../../../../../zerotierone LOCAL_MODULE := ZeroTierOneJNI LOCAL_C_INCLUDES := $(ZT1)/include diff --git a/integrations/Android/java/jni/Application.mk b/integrations/android/android_jni_lib/java/jni/Application.mk similarity index 64% rename from integrations/Android/java/jni/Application.mk rename to integrations/android/android_jni_lib/java/jni/Application.mk index bcbb2a0..3da5d95 100644 --- a/integrations/Android/java/jni/Application.mk +++ b/integrations/android/android_jni_lib/java/jni/Application.mk @@ -4,5 +4,11 @@ APP_CPPFLAGS := -O3 -DUSE_SOCKS_PROXY -DZT_SDK -fPIC -fPIE -fvectorize -Wall -fs APP_PLATFORM := android-14 # Architectures -APP_ABI := all -#APP_ABI := armeabi-v7a +# APP_ABI := all +#APP_ABI += arm64-v8a +#APP_ABI += armeabi +APP_ABI += armeabi-v7a +#APP_ABI += mips +#APP_ABI += mips64 +#APP_ABI += x86 +#APP_ABI += x86_64 diff --git a/integrations/Android/java/jni/ZT_jnilookup.cpp b/integrations/android/android_jni_lib/java/jni/ZT_jnilookup.cpp similarity index 100% rename from integrations/Android/java/jni/ZT_jnilookup.cpp rename to integrations/android/android_jni_lib/java/jni/ZT_jnilookup.cpp diff --git a/integrations/Android/java/jni/ZT_jnilookup.h b/integrations/android/android_jni_lib/java/jni/ZT_jnilookup.h similarity index 100% rename from integrations/Android/java/jni/ZT_jnilookup.h rename to integrations/android/android_jni_lib/java/jni/ZT_jnilookup.h diff --git a/integrations/Android/java/jni/ZT_jniutils.cpp b/integrations/android/android_jni_lib/java/jni/ZT_jniutils.cpp similarity index 100% rename from integrations/Android/java/jni/ZT_jniutils.cpp rename to integrations/android/android_jni_lib/java/jni/ZT_jniutils.cpp diff --git a/integrations/Android/java/jni/ZT_jniutils.h b/integrations/android/android_jni_lib/java/jni/ZT_jniutils.h similarity index 100% rename from integrations/Android/java/jni/ZT_jniutils.h rename to integrations/android/android_jni_lib/java/jni/ZT_jniutils.h diff --git a/integrations/Android/java/jni/com_zerotierone_sdk_Node.cpp b/integrations/android/android_jni_lib/java/jni/com_zerotierone_sdk_Node.cpp similarity index 100% rename from integrations/Android/java/jni/com_zerotierone_sdk_Node.cpp rename to integrations/android/android_jni_lib/java/jni/com_zerotierone_sdk_Node.cpp diff --git a/integrations/Android/java/jni/com_zerotierone_sdk_Node.h b/integrations/android/android_jni_lib/java/jni/com_zerotierone_sdk_Node.h similarity index 100% rename from integrations/Android/java/jni/com_zerotierone_sdk_Node.h rename to integrations/android/android_jni_lib/java/jni/com_zerotierone_sdk_Node.h diff --git a/integrations/Android/java/src/com/zerotier/sdk/DataStoreGetListener.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/DataStoreGetListener.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/DataStoreGetListener.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/DataStoreGetListener.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/DataStorePutListener.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/DataStorePutListener.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/DataStorePutListener.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/DataStorePutListener.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/Event.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/Event.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/Event.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/Event.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/EventListener.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/EventListener.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/EventListener.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/EventListener.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/MulticastGroup.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/MulticastGroup.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/MulticastGroup.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/MulticastGroup.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/NativeUtils.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/NativeUtils.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/NativeUtils.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/NativeUtils.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/Node.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/Node.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/Node.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/Node.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/NodeException.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/NodeException.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/NodeException.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/NodeException.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/NodeStatus.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/NodeStatus.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/NodeStatus.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/NodeStatus.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/PacketSender.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/PacketSender.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/PacketSender.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/PacketSender.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/Peer.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/Peer.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/Peer.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/Peer.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/PeerPhysicalPath.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/PeerPhysicalPath.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/PeerPhysicalPath.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/PeerPhysicalPath.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/PeerRole.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/PeerRole.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/PeerRole.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/PeerRole.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/ResultCode.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/ResultCode.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/ResultCode.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/ResultCode.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/Version.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/Version.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/Version.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/Version.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/VirtualNetworkConfig.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/VirtualNetworkConfig.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/VirtualNetworkConfig.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/VirtualNetworkConfig.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/VirtualNetworkConfigListener.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/VirtualNetworkConfigListener.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/VirtualNetworkConfigListener.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/VirtualNetworkConfigListener.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/VirtualNetworkConfigOperation.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/VirtualNetworkConfigOperation.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/VirtualNetworkConfigOperation.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/VirtualNetworkConfigOperation.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/VirtualNetworkFrameListener.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/VirtualNetworkFrameListener.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/VirtualNetworkFrameListener.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/VirtualNetworkFrameListener.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/VirtualNetworkStatus.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/VirtualNetworkStatus.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/VirtualNetworkStatus.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/VirtualNetworkStatus.java diff --git a/integrations/Android/java/src/com/zerotier/sdk/VirtualNetworkType.java b/integrations/android/android_jni_lib/java/src/com/zerotier/sdk/VirtualNetworkType.java similarity index 100% rename from integrations/Android/java/src/com/zerotier/sdk/VirtualNetworkType.java rename to integrations/android/android_jni_lib/java/src/com/zerotier/sdk/VirtualNetworkType.java diff --git a/integrations/Android/proj/README.md b/integrations/android/android_jni_lib/proj/README.md similarity index 100% rename from integrations/Android/proj/README.md rename to integrations/android/android_jni_lib/proj/README.md diff --git a/integrations/Android/proj/app/app.iml b/integrations/android/android_jni_lib/proj/app/app.iml similarity index 100% rename from integrations/Android/proj/app/app.iml rename to integrations/android/android_jni_lib/proj/app/app.iml diff --git a/integrations/Android/proj/app/build.gradle b/integrations/android/android_jni_lib/proj/app/build.gradle similarity index 96% rename from integrations/Android/proj/app/build.gradle rename to integrations/android/android_jni_lib/proj/app/build.gradle index 5f63419..fb6eac1 100644 --- a/integrations/Android/proj/app/build.gradle +++ b/integrations/android/android_jni_lib/proj/app/build.gradle @@ -31,7 +31,7 @@ android { if (Os.isFamily(Os.FAMILY_WINDOWS)) { commandLine "${android.getNdkDirectory().getAbsolutePath()}/ndk-build.cmd", '-j8', '-C', file('../../java').absolutePath, "ZT1=${System.getProperty('user.dir')}/../../../../zerotierone" } else { - commandLine "${android.getNdkDirectory().getAbsolutePath()}/ndk-build", '-j8', '-C', file('../../java').absolutePath, "ZT1=${System.getProperty('user.dir')}/../../../zerotierone" + commandLine "${android.getNdkDirectory().getAbsolutePath()}/ndk-build", '-j8', '-C', file('../../java').absolutePath, "ZT1=${System.getProperty('user.dir')}/../../../../zerotierone" } } tasks.withType(JavaCompile) { diff --git a/integrations/Android/proj/app/google-services.json b/integrations/android/android_jni_lib/proj/app/google-services.json similarity index 100% rename from integrations/Android/proj/app/google-services.json rename to integrations/android/android_jni_lib/proj/app/google-services.json diff --git a/integrations/Android/proj/app/proguard-rules.pro b/integrations/android/android_jni_lib/proj/app/proguard-rules.pro similarity index 100% rename from integrations/Android/proj/app/proguard-rules.pro rename to integrations/android/android_jni_lib/proj/app/proguard-rules.pro diff --git a/integrations/Android/proj/app/src/androidTest/java/com/zerotier/one/ApplicationTest.java b/integrations/android/android_jni_lib/proj/app/src/androidTest/java/com/zerotier/one/ApplicationTest.java similarity index 100% rename from integrations/Android/proj/app/src/androidTest/java/com/zerotier/one/ApplicationTest.java rename to integrations/android/android_jni_lib/proj/app/src/androidTest/java/com/zerotier/one/ApplicationTest.java diff --git a/integrations/Android/proj/app/src/main/AndroidManifest.xml b/integrations/android/android_jni_lib/proj/app/src/main/AndroidManifest.xml similarity index 100% rename from integrations/Android/proj/app/src/main/AndroidManifest.xml rename to integrations/android/android_jni_lib/proj/app/src/main/AndroidManifest.xml diff --git a/integrations/Android/proj/app/src/main/ic_launcher-web.png b/integrations/android/android_jni_lib/proj/app/src/main/ic_launcher-web.png similarity index 100% rename from integrations/Android/proj/app/src/main/ic_launcher-web.png rename to integrations/android/android_jni_lib/proj/app/src/main/ic_launcher-web.png diff --git a/integrations/Android/proj/app/src/main/java/Netcon/ZT_SDK_Wrapper.java b/integrations/android/android_jni_lib/proj/app/src/main/java/Netcon/ZT_SDK_Wrapper.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/Netcon/ZT_SDK_Wrapper.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/Netcon/ZT_SDK_Wrapper.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/AnalyticsApplication.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/AnalyticsApplication.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/AnalyticsApplication.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/AnalyticsApplication.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/AnalyticsTrackers.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/AnalyticsTrackers.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/AnalyticsTrackers.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/AnalyticsTrackers.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/events/ErrorEvent.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/ErrorEvent.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/events/ErrorEvent.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/ErrorEvent.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/events/JoinNetworkEvent.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/JoinNetworkEvent.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/events/JoinNetworkEvent.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/JoinNetworkEvent.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/events/LeaveNetworkEvent.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/LeaveNetworkEvent.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/events/LeaveNetworkEvent.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/LeaveNetworkEvent.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/events/ManualDisconnectEvent.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/ManualDisconnectEvent.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/events/ManualDisconnectEvent.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/ManualDisconnectEvent.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/events/NetworkInfoReplyEvent.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/NetworkInfoReplyEvent.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/events/NetworkInfoReplyEvent.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/NetworkInfoReplyEvent.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/events/NetworkListReplyEvent.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/NetworkListReplyEvent.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/events/NetworkListReplyEvent.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/NetworkListReplyEvent.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/events/NetworkReconfigureEvent.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/NetworkReconfigureEvent.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/events/NetworkReconfigureEvent.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/NetworkReconfigureEvent.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/events/NetworkRemovedEvent.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/NetworkRemovedEvent.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/events/NetworkRemovedEvent.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/NetworkRemovedEvent.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/events/NodeDestroyedEvent.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/NodeDestroyedEvent.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/events/NodeDestroyedEvent.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/NodeDestroyedEvent.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/events/NodeIDEvent.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/NodeIDEvent.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/events/NodeIDEvent.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/NodeIDEvent.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/events/NodeStatusEvent.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/NodeStatusEvent.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/events/NodeStatusEvent.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/NodeStatusEvent.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/events/RequestNetworkInfoEvent.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/RequestNetworkInfoEvent.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/events/RequestNetworkInfoEvent.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/RequestNetworkInfoEvent.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/events/RequestNetworkListEvent.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/RequestNetworkListEvent.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/events/RequestNetworkListEvent.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/RequestNetworkListEvent.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/events/RequestNodeStatusEvent.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/RequestNodeStatusEvent.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/events/RequestNodeStatusEvent.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/RequestNodeStatusEvent.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/events/StopEvent.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/StopEvent.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/events/StopEvent.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/events/StopEvent.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/service/ARPTable.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/ARPTable.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/service/ARPTable.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/ARPTable.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/service/DataStore.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/DataStore.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/service/DataStore.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/DataStore.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/service/NetworkStateReceiver.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/NetworkStateReceiver.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/service/NetworkStateReceiver.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/NetworkStateReceiver.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/service/Route.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/Route.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/service/Route.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/Route.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/service/RuntimeService.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/RuntimeService.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/service/RuntimeService.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/RuntimeService.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/service/StartupReceiver.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/StartupReceiver.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/service/StartupReceiver.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/StartupReceiver.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/service/TunTapAdapter.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/TunTapAdapter.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/service/TunTapAdapter.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/TunTapAdapter.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/service/UdpCom.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/UdpCom.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/service/UdpCom.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/UdpCom.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/service/ZeroTierOneService.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/ZeroTierOneService.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/service/ZeroTierOneService.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/service/ZeroTierOneService.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/ui/HexKeyboard.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/ui/HexKeyboard.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/ui/HexKeyboard.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/ui/HexKeyboard.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/ui/JoinNetworkActivity.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/ui/JoinNetworkActivity.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/ui/JoinNetworkActivity.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/ui/JoinNetworkActivity.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/ui/JoinNetworkFragment.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/ui/JoinNetworkFragment.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/ui/JoinNetworkFragment.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/ui/JoinNetworkFragment.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/ui/NetworkListActivity.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/ui/NetworkListActivity.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/ui/NetworkListActivity.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/ui/NetworkListActivity.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/ui/NetworkListFragment.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/ui/NetworkListFragment.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/ui/NetworkListFragment.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/ui/NetworkListFragment.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/ui/PrefsActivity.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/ui/PrefsActivity.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/ui/PrefsActivity.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/ui/PrefsActivity.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/ui/PrefsFragment.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/ui/PrefsFragment.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/ui/PrefsFragment.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/ui/PrefsFragment.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/ui/SingleFragmentActivity.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/ui/SingleFragmentActivity.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/ui/SingleFragmentActivity.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/ui/SingleFragmentActivity.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/util/IPPacketUtils.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/util/IPPacketUtils.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/util/IPPacketUtils.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/util/IPPacketUtils.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/util/InetAddressUtils.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/util/InetAddressUtils.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/util/InetAddressUtils.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/util/InetAddressUtils.java diff --git a/integrations/Android/proj/app/src/main/java/com/zerotier/one/util/NetworkIdUtils.java b/integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/util/NetworkIdUtils.java similarity index 100% rename from integrations/Android/proj/app/src/main/java/com/zerotier/one/util/NetworkIdUtils.java rename to integrations/android/android_jni_lib/proj/app/src/main/java/com/zerotier/one/util/NetworkIdUtils.java diff --git a/integrations/Android/proj/app/src/main/res/drawable/button_style.xml b/integrations/android/android_jni_lib/proj/app/src/main/res/drawable/button_style.xml similarity index 100% rename from integrations/Android/proj/app/src/main/res/drawable/button_style.xml rename to integrations/android/android_jni_lib/proj/app/src/main/res/drawable/button_style.xml diff --git a/integrations/Android/proj/app/src/main/res/drawable/hex.png b/integrations/android/android_jni_lib/proj/app/src/main/res/drawable/hex.png similarity index 100% rename from integrations/Android/proj/app/src/main/res/drawable/hex.png rename to integrations/android/android_jni_lib/proj/app/src/main/res/drawable/hex.png diff --git a/integrations/Android/proj/app/src/main/res/drawable/ic_launcher.png b/integrations/android/android_jni_lib/proj/app/src/main/res/drawable/ic_launcher.png similarity index 100% rename from integrations/Android/proj/app/src/main/res/drawable/ic_launcher.png rename to integrations/android/android_jni_lib/proj/app/src/main/res/drawable/ic_launcher.png diff --git a/integrations/Android/proj/app/src/main/res/drawable/sym_keyboard_allleft.png b/integrations/android/android_jni_lib/proj/app/src/main/res/drawable/sym_keyboard_allleft.png similarity index 100% rename from integrations/Android/proj/app/src/main/res/drawable/sym_keyboard_allleft.png rename to integrations/android/android_jni_lib/proj/app/src/main/res/drawable/sym_keyboard_allleft.png diff --git a/integrations/Android/proj/app/src/main/res/drawable/sym_keyboard_allright.png b/integrations/android/android_jni_lib/proj/app/src/main/res/drawable/sym_keyboard_allright.png similarity index 100% rename from integrations/Android/proj/app/src/main/res/drawable/sym_keyboard_allright.png rename to integrations/android/android_jni_lib/proj/app/src/main/res/drawable/sym_keyboard_allright.png diff --git a/integrations/Android/proj/app/src/main/res/drawable/sym_keyboard_delete.png b/integrations/android/android_jni_lib/proj/app/src/main/res/drawable/sym_keyboard_delete.png similarity index 100% rename from integrations/Android/proj/app/src/main/res/drawable/sym_keyboard_delete.png rename to integrations/android/android_jni_lib/proj/app/src/main/res/drawable/sym_keyboard_delete.png diff --git a/integrations/Android/proj/app/src/main/res/drawable/sym_keyboard_done.png b/integrations/android/android_jni_lib/proj/app/src/main/res/drawable/sym_keyboard_done.png similarity index 100% rename from integrations/Android/proj/app/src/main/res/drawable/sym_keyboard_done.png rename to integrations/android/android_jni_lib/proj/app/src/main/res/drawable/sym_keyboard_done.png diff --git a/integrations/Android/proj/app/src/main/res/drawable/sym_keyboard_left.png b/integrations/android/android_jni_lib/proj/app/src/main/res/drawable/sym_keyboard_left.png similarity index 100% rename from integrations/Android/proj/app/src/main/res/drawable/sym_keyboard_left.png rename to integrations/android/android_jni_lib/proj/app/src/main/res/drawable/sym_keyboard_left.png diff --git a/integrations/Android/proj/app/src/main/res/drawable/sym_keyboard_return.png b/integrations/android/android_jni_lib/proj/app/src/main/res/drawable/sym_keyboard_return.png similarity index 100% rename from integrations/Android/proj/app/src/main/res/drawable/sym_keyboard_return.png rename to integrations/android/android_jni_lib/proj/app/src/main/res/drawable/sym_keyboard_return.png diff --git a/integrations/Android/proj/app/src/main/res/drawable/sym_keyboard_right.png b/integrations/android/android_jni_lib/proj/app/src/main/res/drawable/sym_keyboard_right.png similarity index 100% rename from integrations/Android/proj/app/src/main/res/drawable/sym_keyboard_right.png rename to integrations/android/android_jni_lib/proj/app/src/main/res/drawable/sym_keyboard_right.png diff --git a/integrations/Android/proj/app/src/main/res/drawable/txt.png b/integrations/android/android_jni_lib/proj/app/src/main/res/drawable/txt.png similarity index 100% rename from integrations/Android/proj/app/src/main/res/drawable/txt.png rename to integrations/android/android_jni_lib/proj/app/src/main/res/drawable/txt.png diff --git a/integrations/Android/proj/app/src/main/res/layout/activity_fragment.xml b/integrations/android/android_jni_lib/proj/app/src/main/res/layout/activity_fragment.xml similarity index 100% rename from integrations/Android/proj/app/src/main/res/layout/activity_fragment.xml rename to integrations/android/android_jni_lib/proj/app/src/main/res/layout/activity_fragment.xml diff --git a/integrations/Android/proj/app/src/main/res/layout/fragment_join_network.xml b/integrations/android/android_jni_lib/proj/app/src/main/res/layout/fragment_join_network.xml similarity index 100% rename from integrations/Android/proj/app/src/main/res/layout/fragment_join_network.xml rename to integrations/android/android_jni_lib/proj/app/src/main/res/layout/fragment_join_network.xml diff --git a/integrations/Android/proj/app/src/main/res/layout/list_item_network.xml b/integrations/android/android_jni_lib/proj/app/src/main/res/layout/list_item_network.xml similarity index 100% rename from integrations/Android/proj/app/src/main/res/layout/list_item_network.xml rename to integrations/android/android_jni_lib/proj/app/src/main/res/layout/list_item_network.xml diff --git a/integrations/Android/proj/app/src/main/res/layout/list_item_recent_network.xml b/integrations/android/android_jni_lib/proj/app/src/main/res/layout/list_item_recent_network.xml similarity index 100% rename from integrations/Android/proj/app/src/main/res/layout/list_item_recent_network.xml rename to integrations/android/android_jni_lib/proj/app/src/main/res/layout/list_item_recent_network.xml diff --git a/integrations/Android/proj/app/src/main/res/layout/network_list_fragment.xml b/integrations/android/android_jni_lib/proj/app/src/main/res/layout/network_list_fragment.xml similarity index 100% rename from integrations/Android/proj/app/src/main/res/layout/network_list_fragment.xml rename to integrations/android/android_jni_lib/proj/app/src/main/res/layout/network_list_fragment.xml diff --git a/integrations/Android/proj/app/src/main/res/menu/menu_network_list.xml b/integrations/android/android_jni_lib/proj/app/src/main/res/menu/menu_network_list.xml similarity index 100% rename from integrations/Android/proj/app/src/main/res/menu/menu_network_list.xml rename to integrations/android/android_jni_lib/proj/app/src/main/res/menu/menu_network_list.xml diff --git a/integrations/Android/proj/app/src/main/res/mipmap-hdpi/ic_launcher.png b/integrations/android/android_jni_lib/proj/app/src/main/res/mipmap-hdpi/ic_launcher.png similarity index 100% rename from integrations/Android/proj/app/src/main/res/mipmap-hdpi/ic_launcher.png rename to integrations/android/android_jni_lib/proj/app/src/main/res/mipmap-hdpi/ic_launcher.png diff --git a/integrations/Android/proj/app/src/main/res/mipmap-mdpi/ic_launcher.png b/integrations/android/android_jni_lib/proj/app/src/main/res/mipmap-mdpi/ic_launcher.png similarity index 100% rename from integrations/Android/proj/app/src/main/res/mipmap-mdpi/ic_launcher.png rename to integrations/android/android_jni_lib/proj/app/src/main/res/mipmap-mdpi/ic_launcher.png diff --git a/integrations/Android/proj/app/src/main/res/mipmap-xhdpi/ic_launcher.png b/integrations/android/android_jni_lib/proj/app/src/main/res/mipmap-xhdpi/ic_launcher.png similarity index 100% rename from integrations/Android/proj/app/src/main/res/mipmap-xhdpi/ic_launcher.png rename to integrations/android/android_jni_lib/proj/app/src/main/res/mipmap-xhdpi/ic_launcher.png diff --git a/integrations/Android/proj/app/src/main/res/mipmap-xxhdpi/ic_launcher.png b/integrations/android/android_jni_lib/proj/app/src/main/res/mipmap-xxhdpi/ic_launcher.png similarity index 100% rename from integrations/Android/proj/app/src/main/res/mipmap-xxhdpi/ic_launcher.png rename to integrations/android/android_jni_lib/proj/app/src/main/res/mipmap-xxhdpi/ic_launcher.png diff --git a/integrations/Android/proj/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png b/integrations/android/android_jni_lib/proj/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png similarity index 100% rename from integrations/Android/proj/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png rename to integrations/android/android_jni_lib/proj/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png diff --git a/integrations/Android/proj/app/src/main/res/values-w820dp/dimens.xml b/integrations/android/android_jni_lib/proj/app/src/main/res/values-w820dp/dimens.xml similarity index 100% rename from integrations/Android/proj/app/src/main/res/values-w820dp/dimens.xml rename to integrations/android/android_jni_lib/proj/app/src/main/res/values-w820dp/dimens.xml diff --git a/integrations/Android/proj/app/src/main/res/values/dimens.xml b/integrations/android/android_jni_lib/proj/app/src/main/res/values/dimens.xml similarity index 100% rename from integrations/Android/proj/app/src/main/res/values/dimens.xml rename to integrations/android/android_jni_lib/proj/app/src/main/res/values/dimens.xml diff --git a/integrations/Android/proj/app/src/main/res/values/strings.xml b/integrations/android/android_jni_lib/proj/app/src/main/res/values/strings.xml similarity index 100% rename from integrations/Android/proj/app/src/main/res/values/strings.xml rename to integrations/android/android_jni_lib/proj/app/src/main/res/values/strings.xml diff --git a/integrations/Android/proj/app/src/main/res/values/styles.xml b/integrations/android/android_jni_lib/proj/app/src/main/res/values/styles.xml similarity index 100% rename from integrations/Android/proj/app/src/main/res/values/styles.xml rename to integrations/android/android_jni_lib/proj/app/src/main/res/values/styles.xml diff --git a/integrations/Android/proj/app/src/main/res/xml/app_tracker.xml b/integrations/android/android_jni_lib/proj/app/src/main/res/xml/app_tracker.xml similarity index 100% rename from integrations/Android/proj/app/src/main/res/xml/app_tracker.xml rename to integrations/android/android_jni_lib/proj/app/src/main/res/xml/app_tracker.xml diff --git a/integrations/Android/proj/app/src/main/res/xml/hex_keyboard.xml b/integrations/android/android_jni_lib/proj/app/src/main/res/xml/hex_keyboard.xml similarity index 100% rename from integrations/Android/proj/app/src/main/res/xml/hex_keyboard.xml rename to integrations/android/android_jni_lib/proj/app/src/main/res/xml/hex_keyboard.xml diff --git a/integrations/Android/proj/app/src/main/res/xml/preferences.xml b/integrations/android/android_jni_lib/proj/app/src/main/res/xml/preferences.xml similarity index 100% rename from integrations/Android/proj/app/src/main/res/xml/preferences.xml rename to integrations/android/android_jni_lib/proj/app/src/main/res/xml/preferences.xml diff --git a/integrations/Android/proj/build.gradle b/integrations/android/android_jni_lib/proj/build.gradle similarity index 100% rename from integrations/Android/proj/build.gradle rename to integrations/android/android_jni_lib/proj/build.gradle diff --git a/integrations/Android/proj/gradle.properties b/integrations/android/android_jni_lib/proj/gradle.properties similarity index 100% rename from integrations/Android/proj/gradle.properties rename to integrations/android/android_jni_lib/proj/gradle.properties diff --git a/integrations/Android/proj/gradle/wrapper/gradle-wrapper.jar b/integrations/android/android_jni_lib/proj/gradle/wrapper/gradle-wrapper.jar similarity index 100% rename from integrations/Android/proj/gradle/wrapper/gradle-wrapper.jar rename to integrations/android/android_jni_lib/proj/gradle/wrapper/gradle-wrapper.jar diff --git a/integrations/Android/proj/gradle/wrapper/gradle-wrapper.properties b/integrations/android/android_jni_lib/proj/gradle/wrapper/gradle-wrapper.properties similarity index 100% rename from integrations/Android/proj/gradle/wrapper/gradle-wrapper.properties rename to integrations/android/android_jni_lib/proj/gradle/wrapper/gradle-wrapper.properties diff --git a/integrations/Android/proj/gradlew b/integrations/android/android_jni_lib/proj/gradlew similarity index 100% rename from integrations/Android/proj/gradlew rename to integrations/android/android_jni_lib/proj/gradlew diff --git a/integrations/Android/proj/gradlew.bat b/integrations/android/android_jni_lib/proj/gradlew.bat similarity index 100% rename from integrations/Android/proj/gradlew.bat rename to integrations/android/android_jni_lib/proj/gradlew.bat diff --git a/integrations/Android/proj/local.properties b/integrations/android/android_jni_lib/proj/local.properties similarity index 100% rename from integrations/Android/proj/local.properties rename to integrations/android/android_jni_lib/proj/local.properties diff --git a/integrations/Android/proj/proj.iml b/integrations/android/android_jni_lib/proj/proj.iml similarity index 100% rename from integrations/Android/proj/proj.iml rename to integrations/android/android_jni_lib/proj/proj.iml diff --git a/integrations/Android/proj/settings.gradle b/integrations/android/android_jni_lib/proj/settings.gradle similarity index 100% rename from integrations/Android/proj/settings.gradle rename to integrations/android/android_jni_lib/proj/settings.gradle diff --git a/integrations/Android/proj/zerotierandroid.iml b/integrations/android/android_jni_lib/proj/zerotierandroid.iml similarity index 100% rename from integrations/Android/proj/zerotierandroid.iml rename to integrations/android/android_jni_lib/proj/zerotierandroid.iml diff --git a/integrations/android/example_app/.gitignore b/integrations/android/example_app/.gitignore new file mode 100644 index 0000000..c6cbe56 --- /dev/null +++ b/integrations/android/example_app/.gitignore @@ -0,0 +1,8 @@ +*.iml +.gradle +/local.properties +/.idea/workspace.xml +/.idea/libraries +.DS_Store +/build +/captures diff --git a/integrations/android/example_app/app/.gitignore b/integrations/android/example_app/app/.gitignore new file mode 100644 index 0000000..796b96d --- /dev/null +++ b/integrations/android/example_app/app/.gitignore @@ -0,0 +1 @@ +/build diff --git a/integrations/android/example_app/app/build.gradle b/integrations/android/example_app/app/build.gradle new file mode 100644 index 0000000..ec81786 --- /dev/null +++ b/integrations/android/example_app/app/build.gradle @@ -0,0 +1,30 @@ +apply plugin: 'com.android.application' + +android { + compileSdkVersion 23 + buildToolsVersion "23.0.3" + defaultConfig { + applicationId "com.example.joseph.example_android_app" + minSdkVersion 15 + targetSdkVersion 23 + versionCode 1 + versionName "1.0" + testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" + } + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' + } + } +} + +dependencies { + compile fileTree(dir: 'libs', include: ['*.jar']) + compile 'com.android.support:appcompat-v7:23.4.0' + compile 'com.android.support.constraint:constraint-layout:1.0.0-alpha1' + testCompile 'junit:junit:4.12' + androidTestCompile 'com.android.support.test.espresso:espresso-core:2.2.2' + androidTestCompile 'com.android.support.test:runner:0.5' + androidTestCompile 'com.android.support:support-annotations:23.4.0' +} diff --git a/integrations/android/example_app/app/proguard-rules.pro b/integrations/android/example_app/app/proguard-rules.pro new file mode 100644 index 0000000..171ee89 --- /dev/null +++ b/integrations/android/example_app/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/Joseph/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/integrations/android/example_app/app/src/androidTest/java/com/example/joseph/example_android_app/ExampleInstrumentationTest.java b/integrations/android/example_app/app/src/androidTest/java/com/example/joseph/example_android_app/ExampleInstrumentationTest.java new file mode 100644 index 0000000..449fb8e --- /dev/null +++ b/integrations/android/example_app/app/src/androidTest/java/com/example/joseph/example_android_app/ExampleInstrumentationTest.java @@ -0,0 +1,29 @@ +package com.example.joseph.example_android_app; + +import android.content.Context; +import android.support.test.InstrumentationRegistry; +import android.support.test.filters.MediumTest; +import android.support.test.runner.AndroidJUnit4; + +import org.junit.Test; +import org.junit.runner.RunWith; + + +import static org.junit.Assert.*; + +/** + * Instrumentation test, which will execute on an Android device. + * + * @see Testing documentation + */ +@MediumTest +@RunWith(AndroidJUnit4.class) +public class ExampleInstrumentationTest { + @Test + public void useAppContext() throws Exception { + // Context of the app under test. + Context appContext = InstrumentationRegistry.getTargetContext(); + + assertEquals("com.example.joseph.example_android_app", appContext.getPackageName()); + } +} \ No newline at end of file diff --git a/integrations/android/example_app/app/src/main/AndroidManifest.xml b/integrations/android/example_app/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000..48d32c8 --- /dev/null +++ b/integrations/android/example_app/app/src/main/AndroidManifest.xml @@ -0,0 +1,24 @@ + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/integrations/android/example_app/app/src/main/java/ZeroTierSDK/ZeroTierSDK/ZeroTierSDK.java b/integrations/android/example_app/app/src/main/java/ZeroTierSDK/ZeroTierSDK/ZeroTierSDK.java new file mode 100644 index 0000000..8d416f9 --- /dev/null +++ b/integrations/android/example_app/app/src/main/java/ZeroTierSDK/ZeroTierSDK/ZeroTierSDK.java @@ -0,0 +1,5 @@ +package ZeroTierSDK.ZeroTierSDK; +public class ZeroTierSDK { + public native void startOneService(); + static { System.loadLibrary("ZeroTierOneJNI"); } // Loads JNI code +} \ No newline at end of file diff --git a/integrations/android/example_app/app/src/main/java/com/example/joseph/example_android_app/MainActivity.java b/integrations/android/example_app/app/src/main/java/com/example/joseph/example_android_app/MainActivity.java new file mode 100644 index 0000000..2099e6c --- /dev/null +++ b/integrations/android/example_app/app/src/main/java/com/example/joseph/example_android_app/MainActivity.java @@ -0,0 +1,21 @@ +package com.example.joseph.example_android_app; + +import android.support.v7.app.AppCompatActivity; +import android.os.Bundle; + +public class MainActivity extends AppCompatActivity { + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setContentView(R.layout.activity_main); + + new Thread(new Runnable() { + public void run() { + ZeroTierSDK wrapper = new ZeroTierSDK(); + wrapper.startOneService(); // Calls to JNI code + } + }).start(); + + } +} diff --git a/integrations/android/example_app/app/src/main/res/layout/activity_main.xml b/integrations/android/example_app/app/src/main/res/layout/activity_main.xml new file mode 100644 index 0000000..754c23e --- /dev/null +++ b/integrations/android/example_app/app/src/main/res/layout/activity_main.xml @@ -0,0 +1,19 @@ + + + + + + diff --git a/integrations/android/example_app/app/src/main/res/mipmap-hdpi/ic_launcher.png b/integrations/android/example_app/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/integrations/android/example_app/app/src/main/res/mipmap-xhdpi/ic_launcher.png b/integrations/android/example_app/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/integrations/android/example_app/app/src/main/res/mipmap-xxhdpi/ic_launcher.png b/integrations/android/example_app/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/integrations/android/example_app/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png b/integrations/android/example_app/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..aee44e138434630332d88b1680f33c4b24c70ab3 GIT binary patch literal 10486 zcmai4byOU|lb&5k+^GN3bv-?^>(QkVinb zlU9`mfQEQnq$S4VGrg6fmMQ=QFarQQ0ss(?uiys&;LQU7M-~7engIZmZaH5x#UC3m z-zvYBd&I}<`b3rPHj1tDgVv1x| zQss$ELI?W?E(!7PKk$lm@;7PwPX3o43{Ccd9@_BUsL4kQzSMa&=g{>4wj9#)9wgYw;=H@gH9KK{s?Be8N1_8W< z1Rh%Lm&PAfyYb*rGB%E#3q+}riOBB~+@@X<`9mgIiAex!QP8vg-XT>=+N&y*jC-f< zGihyr7XAly+G)|_e)qA?rnKZGG(x?=lLM7nrPk&93@5eX#7I_$g8kMX`0h=}l`HH) z=bpOkBCx=z*-fyr{yp7A9F=%o*qm93t_#tB2lAM@O{fX9ju%X#0~)nRUMvrXClh9w ze8|a0|0}JJg(_@$2wItI?LUY{zF78o(P2BR7;aC^@(jOp{8RE%U3m>MV5%Lu*46b@ zw*c?Nweu!TULS~}*9mi!ejNfNa=`po1*!jiYK)osxi%b59(thEyUZ>#lX@uEXSb_x?3)0kvB?8*TAh)7}IbzSm}5Ia;_?10{}M; z7vq-OS;Ayk8%_c-gg1Ee0FsrRU5phNs#H9Lp!1t+hwyK~9W0bWCxuG$LM~wQuumEw z=fbBD@sQE%1^j z`T@`PZLRVyWjX@*tjc7r;w$H~aW&7vu?|war?84^sg!{J*RH|mhq?KTsCVQBC1~fR z>99jeR=g-Q2b=d;pKwzXwYjrG>?pd3tFSsHN4in{usYLdK;01X2BdRLFI`cuB9yI) zI_ZX?7_(bz`MX2@^mCknx7 z*f}KV@}TBBc}CXMR8T_5yInD3p`KrNROSA;HoJJtlNG3weri%utO$eeY0 z+w-NEn;(;UCBk=OM$f%=%ma24wV7$idelqyNWI>sz1>BlGwr_3UugqVjY+UYyi9P) zxCB?&rPUetoZN?|*D%=hOOJ_${JU3GRjppY%&8Ws^G6>iokr^Bmv1&*@#2#5mXu05 zhPVXaQ`qe5i0lP-1^XL45x`ertKU5d-8b_?*1+tSU!qCeqD9gZP_>ZLq9p)RKtV(B zOh&^x>gV^eqb&c~Oi0|HgGG|gjpbR`9aRdZhOimvS2Y3e?eCFiw+L#_mi9j z;nU}gih+zTn{nv_|L}IllD1Dr3~@yitI}+4C&+;SR+cEfelqJ?eUjZ%&Qz)W8S750 z+vG8Lvo}xXz2C}S-m|9*uE?NWQWT#W+p@$DkH8wVn#=gLKa13M!Yva9qsfE(5Z#0V`A0pN)Ok zP*Eq0(~e$~m@iej0#Av_z703y-7|W6`UuGDS8fpy2rUgINZs#`33@@0(S%~%XUO5G zscEp&x^dU`8syC67USOswNLq>Z_}q#gLh2x`zR)0wvor72-IW@oDpnT0x zWn%LZ_yvR*7geY6<}MC~SViD+4`S9XC|L}N0ANpsUU;50sAjL zb5h>&s<-wcdf2>}P91QgeAu~ZnB7;;FkfKJp^8ne8!-`jK0+O(^`s~#RE0@)=IWiQ z@(vh6D^4jN5ih;*c4J48FMC9MwoN(cXk1Wiq55Vi-^X#p8R_(!y81}YDdMefwdl2F zNA0n}-!P4!FaCe-jnf{^I#?5W=%9T1C|$ z`+tq*x!rEx)Bkv-eO9$mWML9_yId)A_OltKIH-X=0eJ`Opqqj&s^T;PLIZXJ!pEi!=3ZLHPGi*~?<(L&m6;{M(636VC<08tan>&c6fW z%KEuUN9x|i7Wc^-0l&Vf20kI~_XfD4hEac=&}5n&MoYL`Xsx=1po#V*6wUpwB@pu* z*@2n|zglL~zr$9&uOd9_%)GWk&0UN`<&GAm8=Ba-@MT&TH*`NHlt+CMi2Ag;LgGpm zm+ybGL-!1Z$kBYk66=39zAsErw1}|-l1npj-?3g1LE#PXU%%_{8kO=5!W!6pQ?z&i zc_MuV(xKMXSA0ga@IsiwYspm&d4|n@L_zji`zUWxsM}|=@R}BFfT2P!uJcrQf81WG z;7~y_$uMK=ih(2hrfqIGOzb(81e}^7h$dQ*w9&zG_k*kV{ml>Dkn2!p9tb_+Sa82P zf!TC+{4a(i^7UC$53;w?sleb~lFWqeCjv5msi}#JQ!wJtA>=k~`WL0M{^a9PG3%vT z6x=jB0{7wX7$gs%H}xJ&s+hHnzrl#L*=KB8OZd%sPoxKs(`;%|I$(^;nFYa4Cg|3D zmbQ)m6I_Y@t)A~{YBRo!2sYI^n!q)$tPp|m&n1BkYVmX22Z+nY#4N{Bb0!Ko=DOhh z8)8*=>e(W&-%LSWUN;u45Wex{{R747!a~45S>12$wNc{9N95&r%gU+b#-B7PcF%`_ zbDPAsmvpVBsQpf}s{igh23+1)`QSj71!|zjij@kvxgob&J{E97Lwu==Z)RY-lujF1 zts{7+jfS(K5+clZ(CY~%ks(F!=cb)YtqEu(dp_7=A?O!zz8KONrrma{eU-54%}Dm| zMb0!-=YUH?S7JzBX|TVr;=fB(8}a+Mcip|v&=pAeFMCaHj_Nkl!sWeZSb#k<%oczm z#`lGsgJHo7RywsRYYQs4O`J_C=fARQ$)B1peZk)|&ULCaa#RJ45lrml54sxO!CCv< zACe-^PSoZc!)x$#iZa*NuMlS%Jd!_x9|UdgLzlGyF0cI$EUFG4O;L+8*+s;KNL-ld z?R+O)guOt(>{+*e-+_A{1MBbRn&>53j=33ngVZ*A9^^??x8!ww@-m%DVVPmliJh;B zA?gVg!0|Rs7)?hBD^!lSxbI8;-8Q65B4DKw29-K9_w0glvBA&vz=a(hBCWqSnbKS0 zUg%$!iEY%1jOqivHBW;uSX*e&(J!Yr7cborEc&_4TQAAt(Hs@99pynWwVQc-PD)!b zEAfVEq-cX>10nj+=mUt(v;j?>9`bLJayfOcTYEOojVJwg!qg=XHGMAonnJPa; zUJ!+pYTulTHW%^S;&|h~V3suNSc{q3^zg~L0z(5QQ;Fz}<5*7QiE`G{EY!_Bq6Tf3 z#Y6<%5EL^6+vT44<%^2!TOb&Drb?#eUqR@vqcvAd=l_6n*oWcLU38eLio z&XA9a$>+}PoZ&n7&1;j$MfqAp&SK~ziPsl|%{|CWXWM9wxyVKXe0%lk}rDC8g z8X@%6X|;SG;muLTK4d!cPgVxqjvaX=-$(Q65p5S*rI%=0cH7U(J{e1RPLJ7=nOmA) zMlRB`!r37ZXhzV+&X?quSyu}sbAn^a+S992*Te=%QW1izNzH-(Fc!u`0^%jIwx-q{ zjJ$P>vDS90xVX3yM??JQE(8|%*Ent^LOWJSOM1DpOGR5rG_7xH(O_SiI zQPhe?AtaSr$aWQDFB=s4vG}6A7sKS9#`*O?Gvb$VpNFveZ{M$e6gN?k zBAf6x8lMv8irB7O2F*?SxjQ+G9(Zzcf(-v6B#Che%7km*jk@ z)2}#vcILe$u75B8OqP#aD^OyEpX+8%bA;T*9+xPtBOA56r>VBH?W|l@4D*s*oHF7b zKiEI(=9Q&zzKDNu(c_-(iYp|O=RX90e|T*1D)Vi}F|XXxwzlFY%vI5oyr@gp+zfor zE{L0=4=<&pTg$Vb2&yaL(=zg-A=-V)<6G@}QKeym;mw^FzryGI(YX6E{x5!pKKNFb zX2wUTC}&?H`qv0{Ouyp!O!9>BD+&bp+x5*hFxlEJ|Jlx!dC36CiNWcOOOUw5NPT2n zckQz+nHS7$v`1`e33@@emu_-PmpnE%>A~wldBhO+8|uKd(CXF1LguU>p-iuo+6+#A(zwt<~}iz8;e zi$`F>cJ*M;o0PM7dMP=uB26set3i}BC!lE@>Gk`4oZQIG&&(O{wh_khwAz^jz zLMdgg*JfCk1{LlNW)C?WLX_!#5OsEIb3ZPWV7*KBWoBhmt&{(fw|eI)9LZTDrF;Cm zrRI0DXcArT*)L<`{Gy!R-`j)ca2)6Ks~48Jcl^Qg{XgWYyo6RpJj`Aq>-T>){#|lR zRPY`?<2vJ#s7v8mNz1zwnz@<9ofov5TnYTqj(PJN^Hv0N1N6rZY2Q2ixJ9IY`5B)j z?o!|2DLA8bc-{QD-^}@UP_JB`BjVr};f3o#5P`$++U2>eVvNM%RKxPV7J0hzme%(z zR7M~;#x=}vL&%^k)1dkFp)ApEinI%CXma_IcfN1= zghNTqbv$mD$mXwAWysU;hUAFR0^jhAYjE}TV=j$O0>v_@{)|7er^HCFN$j4D(Rxa+ zr>@Me?gS|zVlda*cn+sM7^g8|~YJlBlxK`p<| zo$B!mr$%Z4An3pBbh@BK4Hi-E7l^3GMOiG?^~~z1Oxn$0PAR&}&*9D$O)(_>aB04e z*{ihG%K2UZE9c%O@J$1R+qtuhVW+Li7>Bw~LBLxQ_2GJ6dWmr`sMzGzRfiKQrm?9I zR~`S8uz0=lw5lTY3!?lQ|2LJNx(Ly%0Hkj_Q0C+f8>^@`ot4vM)#Bo9*u)9;#4lPQ zkD$dnQJ;T3;cR_9pRiRuc^MkgYiS>6*;09uV{z*IYw3#i;TH$m(R{*3w>BS-cM7T<{u?6<8}o91iDU^B)<6wJwL{eG{=U+MNz z>#f)F`15Bnp|A(04!41E4ixt89MvouKW88SEk-A`6{3;V9M)Ips3VNFol3u5WiBmL ze0Uor5Z+x~NDGz=5gd!i#D5L)gN!7;`5bPc*8~;4hQOzIJ_RM07TD_cA!r1XISg_x z%9r&%6tsJq$>~|UQ1|7AZe{Oeu!2V&rjYX=>T-qb@S?3(7FC=Z^XOYf24G=+FJR;^ z&+s!YCtoncOWkA~zS!&wfYTiV$WJeR&@pINr7!v$Vw3}H92S?Mj>$ckH9eSoqhxli^L9 zl6?;LH$mT|@_S}#35}P!_7@h%=&u7n2PH0zl8K6L4SX!;*Nkxnnt~qhgVoG_|@w$t9uwee?p`9loMG zr|Qqo!ws?ZaVp;+zT!zH^@xtf^zzvEF*EJK-3hdBe&e4hTya+V7cwy9k?-&u+1W$J9MsjiXQu0{sN!(0)p=yn;5R~ zm8G1M$wClU4oHZeWuEucT>8fj9@#M0kY>Zjx}{F%fX>qa5#{2}lM>g}Xnjo}l|ew8 zkXA5h=I9hvEufUW_wOT8b^(DlBKCuM+=VI>J`Ua;1OioQTVInOmu*pv>=0&M>MOS| z%x%82SVXH|##aK|&I9wXCi2Kuz8@~`}P*VwE0=zPr%s5aHvFP`FsjEx2cBo)6ex*A zWp5GPoq0Vy74R>2aPlQP>~oZKw3$U(jAdy#E}=(clqiqe%$7=zb#t-GOC`@<-LJz{!m%n21KVT2lg4>F^Qyl9E2SvvZNE^Kq<8~8z*~izg_2G$e)DWZ z&r)^t$fjc4=0*E2GgW8V@;;-uQTLpkoe4G&6_Gi{=*bj1demc_{W*z@M)N3w-y!I2 zxt>0g2bLTSCr87lvU@@?w=y0(8-&vH2iDYp1oVatM3hj{k zTI09~y|)(A+XuR&rxolH&~6OyHuw;ulgO_ zPuTLyiVw)P|B03nB7klGZ1SdadQT)(_wcJpUd5Dw*Tl^3%=>G;G`B&%wwFm(MjZi# zMzuQuU>R1Zq8as9MkmM~4%8aV4m60Cl4X`?$zw27Nx(x@)C3hiNs$loyeJV|;3R`m z=2BoxiLeZq;~pUpKfO}+8=>;xkRT&Wh?xRT*$vA=e1-1-a(LQ&8&RQ!R;p| z0{dFY6Iuv97U8}VgGV$6PB!6w5}-jehsz>M8R?2d0-?1=c9Ek)8Yhh)!3TZPk1>d^py>9{d~my1NBGJ)ypHC;!FbEqzyVi zu?k`sqbi!2$c8~?{{=5xCd5}QNx$~UD2(hV0{VWx-}##X2uo*=a!4(~o_<3lOh;=1 zGWy!R&!cXBeOPdKzslPq+FOzt2P)Y6SL*2}8s1q7(#-PEp*Wm`{7r`W-T4WD{gKfb zL=!WtyH86@TGc=5%hW+QVgF5lmp6`bUz|y3kvDq8cEX#Zcon0xK`W6icDQ>?Gb=4k zx9`mayKC`XvhQ;fwwljzxg#~7>oUV^PafLCvQ3GNmYh3%udW9gpP}zdP01_?V#F|} zu+6A+v$!2@w>!LQS}Htz#xrDTMCHF(viHn9B@`r*AN^Uh^K1dYX%OU(L;QO-NS7sm zB}n&5G=+cvZdostKMXC?^Pljs93+p|U_TbCD$_YFH_al)C6D--qOJJg^-4S{e(_Bh(hqonQpIAR3 zLn22yQovcP8^(~lYa;Iw1iN45bC1LAyPgyMn!Us#kC~Od)l{8iBF=vyb{%q5Uo|At z`GioU@7{~W>87(`5`y7oUan|z+y9y6kLnnMdpTsuWXtd+^OE@Rc1&DlS#6q{VJQ~^2R25csGlWAI6%1)G(k1hy(%a6 zP8;j(?t{iGcAAzn*N4^9x1BG`9YQD?lsKuJE}E(!LRb-C04hKL&@?*uDt+rmq#F+E zy;MAG%p~MH`3$_n9%+YIg%-3+vV)5OcqKaeQuCmrhtqvaxZ!JAr|$dSF%)+`Yvoou zOSNuZL?Y9b&gUmyj|pfc5HOzcO#wTn_4)qhXWH?-2h*_V$bXFzOAO}R;U0Utm6jK1 zARXYF88&Au<4|bU zjIqU6CietjeFXz>A`VLxAln~?Tc3Z$!7ZUwvHhxe6;yAIYyV5DChijA_*mxgWa1Hf zpMe^m_ zi=Br9$|jmRXy`ALU7%BL%h!;kp0u2jEG>Y(3_SumS4~Ap=R2K`FOb*E9xFaK2xw@q5)FC9ki5__UGG^ChH* zg8T@CWK(2ZAhn)tl(@xrQ|@?sJZYbg?wPRykjvXSzBgO!5l;~}n=Vx=*>!3~hpG!QO_vZ7nOf(H%X8Zyf5zQI9<;&VgO`J^g!d%ci*Gayzi9E zzV{ggWXFUOwfXv^Cu9g;LXloZZQq$>osapDJ&dlE+FA zOAq0EeuKAV6~J_=V4ai?3X&T(A2S-Y-bb`Ai`xZ-D`VrnQ>pAdiPR0)l-S!eWp};M zhdf*YpjTWa+F;wAvaF(x6TW7LroZ>f%xX1B>ku{kHy23f4Gr*{SyBzch&H417J0V$b=yDLEIl7<2;YbKQ&{=ZOVvMR0}AxP zsmR+tme$kQHP;7Yn9&3eFJljv567buHH|D~F|nOk<45BcE*rk)#MT#RvWplVxMlzpi*dmU?7Pzz{?ICX{O>V+&4<<0nM?7@q6?=qp|+- z^F2j+>w(o9IZ#i9MKt?we*u>AF^=)GwlEo-<8)ZNsl`DO9Ts^3mN?;` zpu-&&=Gn~8C2og^of_Emg!Z)!`}l6?zCnvZ2)$RRO7E_te3B9iY#R5%#LUxR2a$64 zRNuv={A!3W0>=Vd9-Gygqi!GqnO4Wu*hSIx$FOH*78(*CzB@93|C9L^)cR86oytQX zz(VBa;uz&eA4;0&+0T7h>1okMFU4QmpaK8N1A2wlN0S5ncCO%AcYgA${c!kFQ+TiA zSE{2T+HSjei*$%Ai4A}4W1S3}-mXNa1B^jTL+Biw<*SD;pmpz7SdmFu%Z231W zkED`=rBr|FkuV%mCW~b>XQTCw%K0Clxj&QGIm4o%6lpuc4OgwWW^N>I z$CiUaixkCEQf)R*DBF6P&%z|)%AGchvGhBH3v_5YPKL6o6gDG~@`ZoTScT$`HQPz7 zQiqtq$|yTKXN%7 zSaCG2Ucn>50Z`>XxJnz6%(tPlqY9dGm@zHtV2!nWMmS!~Ac!e66nI-(6fh>Qh>8n)+v%wQv>T#tc54h zB%~5--xs;qRhX+bIms&XJP;?K$K2_5H1EpFn-*GyZaD5sGDZ&n5P~FndmWj1xxfxb zSocm{R9OVmD?CfFE;Oebf@%V^7{ZETZUhZ?GM(@uT|gImuIH#AeMtxlE^*teXWH`b z$LnM8?Q_|vjv^u(kO-Y$cB1?ICmH@j5PY(q zaPxf3LgA{hO>D7{M2?XnUpAsX?0!P#eL3cHStcyY4^PB2N&Y`}U05UvjiREStj@u{ z|B)ET + + 64dp + diff --git a/integrations/android/example_app/app/src/main/res/values/colors.xml b/integrations/android/example_app/app/src/main/res/values/colors.xml new file mode 100644 index 0000000..3ab3e9c --- /dev/null +++ b/integrations/android/example_app/app/src/main/res/values/colors.xml @@ -0,0 +1,6 @@ + + + #3F51B5 + #303F9F + #FF4081 + diff --git a/integrations/android/example_app/app/src/main/res/values/dimens.xml b/integrations/android/example_app/app/src/main/res/values/dimens.xml new file mode 100644 index 0000000..47c8224 --- /dev/null +++ b/integrations/android/example_app/app/src/main/res/values/dimens.xml @@ -0,0 +1,5 @@ + + + 16dp + 16dp + diff --git a/integrations/android/example_app/app/src/main/res/values/strings.xml b/integrations/android/example_app/app/src/main/res/values/strings.xml new file mode 100644 index 0000000..d0454e9 --- /dev/null +++ b/integrations/android/example_app/app/src/main/res/values/strings.xml @@ -0,0 +1,3 @@ + + Example_Android_App + diff --git a/integrations/android/example_app/app/src/main/res/values/styles.xml b/integrations/android/example_app/app/src/main/res/values/styles.xml new file mode 100644 index 0000000..5885930 --- /dev/null +++ b/integrations/android/example_app/app/src/main/res/values/styles.xml @@ -0,0 +1,11 @@ + + + + + + diff --git a/integrations/android/example_app/app/src/test/java/com/example/joseph/example_android_app/ExampleUnitTest.java b/integrations/android/example_app/app/src/test/java/com/example/joseph/example_android_app/ExampleUnitTest.java new file mode 100644 index 0000000..4448952 --- /dev/null +++ b/integrations/android/example_app/app/src/test/java/com/example/joseph/example_android_app/ExampleUnitTest.java @@ -0,0 +1,17 @@ +package com.example.joseph.example_android_app; + +import org.junit.Test; + +import static org.junit.Assert.*; + +/** + * Example local unit test, which will execute on the development machine (host). + * + * @see Testing documentation + */ +public class ExampleUnitTest { + @Test + public void addition_isCorrect() throws Exception { + assertEquals(4, 2 + 2); + } +} \ No newline at end of file diff --git a/integrations/android/example_app/build.gradle b/integrations/android/example_app/build.gradle new file mode 100644 index 0000000..12df91c --- /dev/null +++ b/integrations/android/example_app/build.gradle @@ -0,0 +1,23 @@ +// 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:2.2.0-alpha1' + + // NOTE: Do not place your application dependencies here; they belong + // in the individual module build.gradle files + } +} + +allprojects { + repositories { + jcenter() + } +} + +task clean(type: Delete) { + delete rootProject.buildDir +} diff --git a/integrations/android/example_app/gradle.properties b/integrations/android/example_app/gradle.properties new file mode 100644 index 0000000..5eb079f --- /dev/null +++ b/integrations/android/example_app/gradle.properties @@ -0,0 +1,20 @@ +# Project-wide Gradle settings. + +# IDE (e.g. Android Studio) users: +# Gradle settings configured through the IDE *will override* +# any settings specified in this file. + +# For more details on how to configure your build environment visit +# http://www.gradle.org/docs/current/userguide/build_environment.html + +# Specifies the JVM arguments used for the daemon process. +# The setting is particularly useful for tweaking memory settings. +org.gradle.jvmargs=-Xmx1536m + +org.gradle.daemon=true +org.gradle.parallel=true + +# 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 diff --git a/integrations/android/example_app/gradle/wrapper/gradle-wrapper.jar b/integrations/android/example_app/gradle/wrapper/gradle-wrapper.jar new file mode 100644 index 0000000000000000000000000000000000000000..13372aef5e24af05341d49695ee84e5f9b594659 GIT binary patch literal 53636 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ⅅ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 H-+%o-(+5aQ literal 0 HcmV?d00001 diff --git a/integrations/android/example_app/gradle/wrapper/gradle-wrapper.properties b/integrations/android/example_app/gradle/wrapper/gradle-wrapper.properties new file mode 100644 index 0000000..122a0dc --- /dev/null +++ b/integrations/android/example_app/gradle/wrapper/gradle-wrapper.properties @@ -0,0 +1,6 @@ +#Mon Dec 28 10:00:20 PST 2015 +distributionBase=GRADLE_USER_HOME +distributionPath=wrapper/dists +zipStoreBase=GRADLE_USER_HOME +zipStorePath=wrapper/dists +distributionUrl=https\://services.gradle.org/distributions/gradle-2.10-all.zip diff --git a/integrations/android/example_app/gradlew b/integrations/android/example_app/gradlew new file mode 100755 index 0000000..9d82f78 --- /dev/null +++ b/integrations/android/example_app/gradlew @@ -0,0 +1,160 @@ +#!/usr/bin/env bash + +############################################################################## +## +## Gradle start up script for UN*X +## +############################################################################## + +# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. +DEFAULT_JVM_OPTS="" + +APP_NAME="Gradle" +APP_BASE_NAME=`basename "$0"` + +# Use the maximum available, or set MAX_FD != -1 to use that value. +MAX_FD="maximum" + +warn ( ) { + echo "$*" +} + +die ( ) { + echo + echo "$*" + echo + exit 1 +} + +# OS specific support (must be 'true' or 'false'). +cygwin=false +msys=false +darwin=false +case "`uname`" in + CYGWIN* ) + cygwin=true + ;; + Darwin* ) + darwin=true + ;; + MINGW* ) + msys=true + ;; +esac + +# Attempt to set APP_HOME +# Resolve links: $0 may be a link +PRG="$0" +# Need this for relative symlinks. +while [ -h "$PRG" ] ; do + ls=`ls -ld "$PRG"` + link=`expr "$ls" : '.*-> \(.*\)$'` + if expr "$link" : '/.*' > /dev/null; then + PRG="$link" + else + PRG=`dirname "$PRG"`"/$link" + fi +done +SAVED="`pwd`" +cd "`dirname \"$PRG\"`/" >/dev/null +APP_HOME="`pwd -P`" +cd "$SAVED" >/dev/null + +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"` + JAVACMD=`cygpath --unix "$JAVACMD"` + + # We build the pattern for arguments to be converted via cygpath + ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` + SEP="" + for dir in $ROOTDIRSRAW ; do + ROOTDIRS="$ROOTDIRS$SEP$dir" + SEP="|" + done + OURCYGPATTERN="(^($ROOTDIRS))" + # Add a user-defined pattern to the cygpath arguments + if [ "$GRADLE_CYGPATTERN" != "" ] ; then + OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" + fi + # Now convert the arguments - kludge to limit ourselves to /bin/sh + i=0 + for arg in "$@" ; do + CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` + CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option + + if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition + eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` + else + eval `echo args$i`="\"$arg\"" + fi + i=$((i+1)) + done + case $i in + (0) set -- ;; + (1) set -- "$args0" ;; + (2) set -- "$args0" "$args1" ;; + (3) set -- "$args0" "$args1" "$args2" ;; + (4) set -- "$args0" "$args1" "$args2" "$args3" ;; + (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; + (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; + (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; + (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; + (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; + esac +fi + +# 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/integrations/android/example_app/gradlew.bat b/integrations/android/example_app/gradlew.bat new file mode 100644 index 0000000..aec9973 --- /dev/null +++ b/integrations/android/example_app/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/integrations/android/example_app/settings.gradle b/integrations/android/example_app/settings.gradle new file mode 100644 index 0000000..e7b4def --- /dev/null +++ b/integrations/android/example_app/settings.gradle @@ -0,0 +1 @@ +include ':app' diff --git a/integrations/Apple/Example_OSX_App/Example_OSX_App.xcodeproj/project.pbxproj b/integrations/apple/example_app/Example_OSX_App.xcodeproj/project.pbxproj similarity index 100% rename from integrations/Apple/Example_OSX_App/Example_OSX_App.xcodeproj/project.pbxproj rename to integrations/apple/example_app/Example_OSX_App.xcodeproj/project.pbxproj diff --git a/integrations/Apple/Example_OSX_App/Example_OSX_App.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/integrations/apple/example_app/Example_OSX_App.xcodeproj/project.xcworkspace/contents.xcworkspacedata similarity index 100% rename from integrations/Apple/Example_OSX_App/Example_OSX_App.xcodeproj/project.xcworkspace/contents.xcworkspacedata rename to integrations/apple/example_app/Example_OSX_App.xcodeproj/project.xcworkspace/contents.xcworkspacedata diff --git a/integrations/Apple/Example_OSX_App/Example_OSX_App.xcodeproj/project.xcworkspace/xcuserdata/Joseph.xcuserdatad/UserInterfaceState.xcuserstate b/integrations/apple/example_app/Example_OSX_App.xcodeproj/project.xcworkspace/xcuserdata/Joseph.xcuserdatad/UserInterfaceState.xcuserstate similarity index 100% rename from integrations/Apple/Example_OSX_App/Example_OSX_App.xcodeproj/project.xcworkspace/xcuserdata/Joseph.xcuserdatad/UserInterfaceState.xcuserstate rename to integrations/apple/example_app/Example_OSX_App.xcodeproj/project.xcworkspace/xcuserdata/Joseph.xcuserdatad/UserInterfaceState.xcuserstate diff --git a/integrations/Apple/Example_OSX_App/Example_OSX_App.xcodeproj/xcuserdata/Joseph.xcuserdatad/xcschemes/Example_OSX_App.xcscheme b/integrations/apple/example_app/Example_OSX_App.xcodeproj/xcuserdata/Joseph.xcuserdatad/xcschemes/Example_OSX_App.xcscheme similarity index 100% rename from integrations/Apple/Example_OSX_App/Example_OSX_App.xcodeproj/xcuserdata/Joseph.xcuserdatad/xcschemes/Example_OSX_App.xcscheme rename to integrations/apple/example_app/Example_OSX_App.xcodeproj/xcuserdata/Joseph.xcuserdatad/xcschemes/Example_OSX_App.xcscheme diff --git a/integrations/Apple/Example_OSX_App/Example_OSX_App.xcodeproj/xcuserdata/Joseph.xcuserdatad/xcschemes/xcschememanagement.plist b/integrations/apple/example_app/Example_OSX_App.xcodeproj/xcuserdata/Joseph.xcuserdatad/xcschemes/xcschememanagement.plist similarity index 100% rename from integrations/Apple/Example_OSX_App/Example_OSX_App.xcodeproj/xcuserdata/Joseph.xcuserdatad/xcschemes/xcschememanagement.plist rename to integrations/apple/example_app/Example_OSX_App.xcodeproj/xcuserdata/Joseph.xcuserdatad/xcschemes/xcschememanagement.plist diff --git a/integrations/Apple/Example_OSX_App/Example_OSX_App/AppDelegate.swift b/integrations/apple/example_app/Example_OSX_App/AppDelegate.swift similarity index 100% rename from integrations/Apple/Example_OSX_App/Example_OSX_App/AppDelegate.swift rename to integrations/apple/example_app/Example_OSX_App/AppDelegate.swift diff --git a/integrations/Apple/Example_OSX_App/Example_OSX_App/Assets.xcassets/AppIcon.appiconset/Contents.json b/integrations/apple/example_app/Example_OSX_App/Assets.xcassets/AppIcon.appiconset/Contents.json similarity index 100% rename from integrations/Apple/Example_OSX_App/Example_OSX_App/Assets.xcassets/AppIcon.appiconset/Contents.json rename to integrations/apple/example_app/Example_OSX_App/Assets.xcassets/AppIcon.appiconset/Contents.json diff --git a/integrations/Apple/Example_OSX_App/Example_OSX_App/Base.lproj/Main.storyboard b/integrations/apple/example_app/Example_OSX_App/Base.lproj/Main.storyboard similarity index 100% rename from integrations/Apple/Example_OSX_App/Example_OSX_App/Base.lproj/Main.storyboard rename to integrations/apple/example_app/Example_OSX_App/Base.lproj/Main.storyboard diff --git a/integrations/Apple/Example_OSX_App/Example_OSX_App/Info.plist b/integrations/apple/example_app/Example_OSX_App/Info.plist similarity index 100% rename from integrations/Apple/Example_OSX_App/Example_OSX_App/Info.plist rename to integrations/apple/example_app/Example_OSX_App/Info.plist diff --git a/integrations/Apple/Example_OSX_App/Example_OSX_App/ViewController.swift b/integrations/apple/example_app/Example_OSX_App/ViewController.swift similarity index 100% rename from integrations/Apple/Example_OSX_App/Example_OSX_App/ViewController.swift rename to integrations/apple/example_app/Example_OSX_App/ViewController.swift diff --git a/make-mac.mk b/make-mac.mk index b3ffcf3..11eeb17 100644 --- a/make-mac.mk +++ b/make-mac.mk @@ -71,9 +71,9 @@ ios_unity3d_bundle: # Build library for Android Unity integrations # Build JNI library for Android app integration android_jni_lib: - cd integrations/android/proj; ./gradlew assembleDebug -# cd integrations/android/java/libs/; for f in *; do mv "$f" "android_jni_lib_$f"; done - mv integrations/android/java/libs/* build + cd integrations/android/android_jni_lib/proj; ./gradlew assembleDebug +# cd integrations/android/android_jni_lib/java/libs/; for f in *; do mv "$f" "android_jni_lib_$f"; done + mv integrations/android/android_jni_lib/java/libs/* build cp docs/android_zt_sdk.md build/README.md osx_shared_lib: $(OBJS) @@ -97,9 +97,15 @@ clean: find . -type f -name '*.o' -delete find . -type f -name '*.so' -delete find . -type f -name '*.o.d' -delete - # Remove junk generated by Android builds - cd integrations/Android/proj; ./gradlew clean - rm -rf integrations/Android/proj/.gradle - rm -rf integrations/Android/proj/.idea - rm -rf integrations/Android/proj/build + + # android JNI lib project + cd integrations/android/android_jni_lib/proj; ./gradlew clean + rm -rf integrations/android/android_jni_lib/proj/.gradle + rm -rf integrations/android/android_jni_lib/proj/.idea + rm -rf integrations/android/android_jni_lib/proj/build + + # example android app project + cd integrations/android/example_app; ./gradlew clean + rm -rf integrations/android/example_app/.idea + rm -rf integrations/android/example_app/.gradle FORCE: diff --git a/src/SDK_ServiceSetup.cpp b/src/SDK_ServiceSetup.cpp index 87b82ab..00de4be 100644 --- a/src/SDK_ServiceSetup.cpp +++ b/src/SDK_ServiceSetup.cpp @@ -129,7 +129,7 @@ extern "C" { * Starts a new service instance */ #if defined(__ANDROID__) - JNIEXPORT void JNICALL Java_SDK_SDK_Wrapper_startOneService(JNIEnv *env, jobject thisObj) + JNIEXPORT void JNICALL Java_ZeroTierSDK_startOneService(JNIEnv *env, jobject thisObj) //JNIEXPORT void JNICALL Java_Netcon_NetconWrapper_startOneService(JNIEnv *env, jobject thisObj) { #else diff --git a/src/SDK_ServiceSetup.hpp b/src/SDK_ServiceSetup.hpp index 940c3de..c144992 100644 --- a/src/SDK_ServiceSetup.hpp +++ b/src/SDK_ServiceSetup.hpp @@ -40,7 +40,7 @@ extern "C" { #define INTERCEPT_DISABLED 222 #if defined(__ANDROID__) - JNIEXPORT void JNICALL Java_SDK_SDK_Wrapper_startOneService(JNIEnv *env, jobject thisObj); + JNIEXPORT void JNICALL Java_ZeroTierSDK_startOneService(JNIEnv *env, jobject thisObj); #else void *startOneService(void *thread_id); void init_service(int key, const char * path);