Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/google/j2objc
A Java to iOS Objective-C translation tool and runtime.
https://github.com/google/j2objc
Last synced: 5 days ago
JSON representation
A Java to iOS Objective-C translation tool and runtime.
- Host: GitHub
- URL: https://github.com/google/j2objc
- Owner: google
- License: apache-2.0
- Created: 2014-01-30T20:19:56.000Z (almost 11 years ago)
- Default Branch: master
- Last Pushed: 2025-01-06T22:37:14.000Z (19 days ago)
- Last Synced: 2025-01-07T16:08:19.396Z (18 days ago)
- Language: Java
- Homepage: http://j2objc.org
- Size: 99 MB
- Stars: 5,999
- Watchers: 287
- Forks: 975
- Open Issues: 87
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Authors: AUTHORS
Awesome Lists containing this project
- awesome-java - J2ObjC - Java-to-Objective-C translator for porting Android libraries to iOS. (Projects / Miscellaneous)
- starred-awesome - j2objc - A Java to iOS Objective-C translation tool and runtime. (Java)
README
# J2ObjC: Java to Objective-C Translator and Runtime #
**Project site:**
**J2ObjC blog:**
**Questions and discussion:**### What J2ObjC Is ###
J2ObjC is an open-source command-line tool from Google that translates
Java source code to Objective-C for the iOS (iPhone/iPad) platform. This tool
enables Java source to be part of an iOS application's build, as no editing
of the generated files is necessary. The goal is to write an app's non-UI
code (such as application logic and data models) in Java, which is then
shared by web apps (using [GWT](http://www.gwtproject.org/)), Android apps,
and iOS apps.J2ObjC supports most Java language and runtime features required by
client-side application developers, including exceptions, inner and
anonymous classes, generic types, threads and reflection. JUnit test
translation and execution is also supported.J2ObjC is currently beta quality. Several Google projects rely on it, but
when new projects first start working with it, they usually find new bugs
to be fixed. If you run into issues with your project, please report them!### What J2ObjC isn't ###
J2ObjC does not provide any sort of platform-independent UI toolkit, nor are
there any plans to do so in the future. We believe that iOS UI code needs to
be written in Objective-C, Objective-C++ or Swift using Apple's iOS SDK (Android
UIs using Android's API, web app UIs using GWT, etc.).J2ObjC cannot convert Android binary applications. Developers must have source
code for their Android app, which they either own or are licensed to use.## Requirements ##
* JDK 11
* Mac workstation or laptop
* OS X 10.12 or higher
* Xcode 8 or higher## License ##
This library is distributed under the Apache 2.0 license found in the
[LICENSE](https://github.com/google/j2objc/blob/master/LICENSE) file.
The protocol buffers library is distributed under the same BSD license as
Google's protocol buffers. See its
[README](https://github.com/protocolbuffers/protobuf/blob/master/README.md) and
[LICENSE](https://github.com/protocolbuffers/protobuf/blob/master/LICENSE).## Running on GNU/Linux ##
To build and run on GNU/Linux, install [the Darling project](http://www.darlinghq.org/), then following [its Compile and Run a Program example](https://wiki.darlinghq.org/what_to_try#compile_and_run_a_program). Please note that j2objc is only supported on iOS/macOS.
## Artifact Signatures ##
This project publishes some artifacts through Maven Central with a `groupId` of `com.google.j2objc`.
These artifacts are currently signed with [the following PGP/GPG key]
(https://keyserver.ubuntu.com/pks/lookup?op=get&search=0xeb1b3de71713c9ec2e87cc26ee92349ad86de446):```
pub rsa2048 2023-01-10 [SC] [expires: 2025-01-09]
EB1B3DE71713C9EC2E87CC26EE92349AD86DE446
uid [ unknown] Thomas Ball
sub rsa2048 2023-01-10 [E] [expires: 2025-01-09]
```Older artifacts are signed with the following PGP/GPG key:
```
pub rsa2048 2015-09-25 [SC]
B801E2F8EF035068EC1139CC29579F18FA8FD93B
uid [ unknown] Tom Ball
sub rsa2048 2015-09-25 [E]
```