All Projects → gnustep → tools-android

gnustep / tools-android

Licence: MIT license
Objective-C on Android with Foundation, CoreFoundation, and libdispatch.

Programming Languages

shell
77523 projects

Projects that are alternatives of or similar to tools-android

Objective-CPP
C++ compatibility library for Objective-C - Objective-CPP is a library intended to ease software development using Objective-C++. It declares categories on Objective-C classes, to work with the STL C++ types, such as std::string, std::vector, etc.
Stars: ✭ 37 (-2.63%)
Mutual labels:  objective-c-plus-plus, foundation
extensions-kit
📦 Collection of Swift+Apple Frameworks extensions for speeding up software development [iOS & iPadOS].
Stars: ✭ 71 (+86.84%)
Mutual labels:  foundation
Scrivener html
HTML view helpers for Scrivener
Stars: ✭ 112 (+194.74%)
Mutual labels:  foundation
bazel-compile-commands-extractor
Goal: Enable awesome tooling for Bazel users of the C language family.
Stars: ✭ 295 (+676.32%)
Mutual labels:  objective-c-plus-plus
Bootstrap Table
An extended table to integration with some of the most widely used CSS frameworks. (Supports Bootstrap, Semantic UI, Bulma, Material Design, Foundation, Vue.js)
Stars: ✭ 11,068 (+29026.32%)
Mutual labels:  foundation
SwipeSelection
An improvement to iOS's text editing that allows you to move the cursor and select text using gestures on the keyboard itself.
Stars: ✭ 99 (+160.53%)
Mutual labels:  objective-c-plus-plus
Angular Foundation 6
Foundation 6 directives for Angular 1.5+
Stars: ✭ 93 (+144.74%)
Mutual labels:  foundation
Ignite
A comprehensive Flask boilerplate to build SaaS applications that includes Stripe billing, emails, login, and OAuth.
Stars: ✭ 102 (+168.42%)
Mutual labels:  foundation
mesh
A page builder, simplified. Get the most flexibility to display content by adding multiple content sections within Pages, Posts, or Custom Post Types.
Stars: ✭ 44 (+15.79%)
Mutual labels:  foundation
Scipio Erp
Your Online Business Kit - Build your own business applications. Create your own online shop. Customize to your own needs.
Stars: ✭ 247 (+550%)
Mutual labels:  foundation
Swift Essentials
A set of essential Swift stuff I use in every single iOS app.
Stars: ✭ 223 (+486.84%)
Mutual labels:  foundation
Cornerstone
Cornerstone is a WordPress starter theme based on the Zurb Foundation Responsive Framework. Cornerstone aims to provide a lightweight starter theme that is responsive and SEO friendly that web designers can build great looking websites on.
Stars: ✭ 154 (+305.26%)
Mutual labels:  foundation
Mapbox Gl Native
Interactive, thoroughly customizable maps in native Android, iOS, macOS, Node.js, and Qt applications, powered by vector tiles and OpenGL
Stars: ✭ 4,091 (+10665.79%)
Mutual labels:  objective-c-plus-plus
Foundation7
Drupal 7 theme built using ZURB Foundation Sites
Stars: ✭ 132 (+247.37%)
Mutual labels:  foundation
reactive.foundation
reactive.foundation website
Stars: ✭ 18 (-52.63%)
Mutual labels:  foundation
Swifterswift
A handy collection of more than 500 native Swift extensions to boost your productivity.
Stars: ✭ 10,706 (+28073.68%)
Mutual labels:  foundation
Vue Foundation
VueJS + Foundation + Vue-Router + Webpack
Stars: ✭ 212 (+457.89%)
Mutual labels:  foundation
foundation-server
(v1) A scalable cryptocurrency mining pool server written in Node.js
Stars: ✭ 45 (+18.42%)
Mutual labels:  foundation
Swift-ISO8601-DurationParser
Swift ISO8601 Parser
Stars: ✭ 24 (-36.84%)
Mutual labels:  foundation
Textmate
TextMate is a graphical text editor for macOS 10.12 or later
Stars: ✭ 13,729 (+36028.95%)
Mutual labels:  objective-c-plus-plus

GNUstep Android Toolchain

CI

This project comprises a collection of scripts to build a GNUstep toolchain for Android. The toolchain can then be used in an Android project to compile and run Objective-C code using the Foundation and CoreFoundation libraries.

The toolchain is built using the Android NDK (installed e.g. via Android Studio), and is set up to target Android API level 23 (6.0 / Marshmallow) and all common Android ABIs (armeabi-v7a, arm64-v8a, x86, x86_64).

Libraries

The toolchain currently compiles the following libraries for Android:

Requirements

Supported host platforms are macOS and Linux.

The toolchain requires the Android NDK, which can be installed via Android Studio’s SDK Manager. The NDK installation will be located using the ANDROID_NDK_ROOT environment variable if set, or otherwise it will use the latest version in ~/Library/Android/sdk/ndk (macOS) / ~/Android/sdk/ndk (Linux). A different NDK path can also be provided using the --ndk flag when building the toolchain (see below).

Please note that NDK r21 or later is required, as earlier NDK releases contain Clang versions with bugs which prevent usage of the gnustep-2.0 Objective-C runtime.

Installation

To install a pre-built release, download it from the releases on GitHub and unpack the "GNUstep" folder into the following location depending on your OS ($GNUSTEP_HOME):

  • macOS: ~/Library/Android/GNUstep
  • Linux: ~/Android/GNUstep

Using the Toolchain

The android-examples repository contains Android Studio and Qt example projects using this project that can be used as templates for integrating Objective-C code into new or existing Android projects.

To use the toolchain from an Android project, you can use $GNUSTEP_HOME/$ABI_NAME/bin/gnustep-config to obtain various flags that should be used to compile and link Objective-C files, e.g.:

  • gnustep-config --variable=CC
  • gnustep-config --objc-flags (or --debug-flags)
  • gnustep-config --base-libs

Call gnustep-config --help to obtain the full list of available variables.

Status and Known Issues

The toolchain is being used in production in an award-winnning music app available on Google Play.

Following are some notes and known issues about using GNUstep on Android.

  • GNUstep base currently has no native integration between the Android run-loop and NSRunLoop or the libdispatch main queue, so things like -performSelector:withObject:afterDelay: or dispatching on dispatch_get_main_queue() will not work out of the box. An integration depends on the setup of the app (e.g. whether using Android Studio, Qt, or something else), and is possible to add in the app by swizzing NSRunLoop. Feel free to open an issue if this is of interest to you and you would like more information.
  • GNUstep Base is integrated with Android’s app-specific storage and uses the path returned by Context.getFilesDir() as NSHomeDirectory() and when querying for directory paths (NSLibraryDirectory, NSApplicationSupportDirectory, etc.). It also uses Context.getCacheDir() as NSTemporaryDirectory and NSCachesDirectory (with NSUserDomainMask).
  • GNUstep Base is further integrated with the Android asset manager, and supports accessing the app’s resources from [NSBundle mainBundle] via APIs such as -pathForResource:ofType: and -URLForResource:ofType:, and reading them using NSFileManager, NSFileHandle, and NSDirectoryEnumerator APIs. This is done by returning paths from NSBundle APIs with a fixed, fake, per-app prefix (Context.getPackageCodePath() without extension + /Resources), which internally get routed through the NDK’s AAsset API for reading.
  • Note that NSDirectoryEnumerator is not able to enumerate directories in the app’s main bundle due to a limitation of the AAssetDir API.
  • The app must call GSInitializeProcessAndroid() (defined in NSProcessInfo.h) on launch in order to initialize the above Android-specific functionality in GNUstep.
  • GNUstep Base doesn’t currently get the system languages on Android, which combined with the inability to list directories in the main bundle (see above) means that NSLocalizedString() won’t work out of the box even if localized strings are present in the app’s assets. As a workaround, the app should manually call -[NSUserDefaults setUserLanguages:] with a list of supported locales ordered by the user’s system language preferences.
  • GNUstep Base will also currently not return the system locale as the current NSLocale on Android (the current locale will always default to en_US_POSIX). As a workaround, the app can manually set the system’s locale identifier for the key "Locale" in NSUserDefaults, and use -[NSLocale autoupdatingCurrentLocale] to retreive the locale.
  • Android will not output stdout or stderr to logcat by default, which might cause some log or error output from GNUstep or other libraries to be missing. You can run a thread in your app to write these streams to the Android log to work around this, which is recommended for debugging.

For the last three points above please refer to GSInitialize.m in the examples for details.

Prerequisites for Building

The following packages are required for building the toolchain.

macOS

Install required packages via Homebrew:

brew install git-lfs cmake autoconf automake libtool pkg-config
git lfs install

Linux

Install required packages via APT:

sudo apt install git git-lfs curl cmake make autoconf libtool pkg-config texinfo python3-distutils
git lfs install

Please note that you need to have CMake version 3.15.1 or later (for libdispatch).

Building the Toolchain

Run the build.sh script to build the toolchain yourself:

Usage: ./build.sh
  --prefix INSTALL_ROOT      Install toolchain into given directory (default: see below)
  --dist-root DIST_ROOT      Make toolchain relocatable to given path relative to home folder on other machines
                             (use "HOME" as placeholder for home folder, e.g. "HOME/Library/Android/GNUstep")
  -n, --ndk NDK_PATH         Path to existing Android NDK (default: ANDROID_NDK_ROOT)
  -a, --abis ABI_NAMES       ABIs being targeted (default: "armeabi-v7a arm64-v8a x86 x86_64")
  -l, --level API_LEVEL      Android API level being targeted (default: 23)
  -b, --build BUILD_TYPE     Build type "Debug" or "Release" or "RelWithDebInfo" (default: RelWithDebInfo)
  -u, --no-update            Don't update projects to latest version from GitHub
  -c, --no-clean             Don't clean projects during build (e.g. for building local changes, only applies to first ABI being built)
  -p, --patches DIR          Apply additional patches from given directory
  -o, --only PHASE           Build only the given phase (e.g. "gnustep-base", requires previous build)
  -h, --help                 Print usage information and exit

The toolchain builds and installs the GNUstep toolchain into the following location ($GNUSTEP_HOME):

  • macOS: ~/Library/Android/GNUstep
  • Linux: ~/Android/GNUstep

The build for each supported ABI is installed into its separate subfolder at that location (both libraries and header files differ per ABI).

Acknowledgements

Based on original work by Ivan Vučica.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].