Skip to content

SwiftJava/swift-android-samples

master
Switch branches/tags

Name already in use

A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?
Code
This branch is 41 commits ahead of SwiftAndroid:master.

Latest commit

 

Git stats

Files

Permalink
Failed to load latest commit information.
Type
Name
Latest commit message
Commit time
 
 
 
 
 
 

Samples for the SwiftAndroid toolchain.

Requires a build of the latest Android toolchain downloadable here. The gradle plugin used to build is now part of the toolchain which is installed by running swift-install/setup,sh. On Linux, make sure the usr/bin driectory of the toolchain you want to use is in your path when you run this script.The phone must be api 21 aka Android v5+ aka Lollipop or better (I used an LG K4.) The example app now uses SQLite which requires Beta III of the toolchain released 27/08/2017.

To create a new application, decide on a pair of interfaces to connect to and from your Swift code and place them in a Java Source. Use the command ./genswift.sh in the SwiftJava Project to generate Swift (& Java) sources to include in your application or adapt the genhello.sh script. If you only use interfaces/protocols, your app's only Package.swift dependency should be the core JNI interfacing code java_swift.

This example is coded to work with version 4 of the toolchain which has some additional requirements to work around requirements of the Swift port of Foundation. The cache directory used by web operations needs to be setup in the enironment variable "TMPDIR". This would usually be the value of Context.getCacheDir().getPath() from the java side. In addition, to be able to use SSL you need to add a CARoot info file to the application's raw resources and copy it to this cache directory to be picked up by Foundation as follows:

setenv("URLSessionCertificateAuthorityInfoFile", cacheDir! + "/cacert.pem", 1)
setenv("TMPDIR", cacheDir!, 1)

If you don't want peer validation you have the following option (not recommended at all)

setenv("URLSessionCertificateAuthorityInfoFile", “INSECURE_SSL_NO_VERIFY”, 1)

Simple demo of Swift code accessed over JNI.

To build, setup the Gradle plugin, then run ./gradlew installDebug

This demo is licensed under the Creative Commons CC0 license: do whatever you want.

About

Samples for the SwiftAndroid toolchain.

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Swift 78.6%
  • Java 21.4%