Skip to content

Latest commit

 

History

History
111 lines (80 loc) · 4.77 KB

README.md

File metadata and controls

111 lines (80 loc) · 4.77 KB

android-servicedirectory

Build Status Maven Central Maven Central (Snapshots)

The Palace Project's Android service directory.

What Is This?

The contents of this repository define an API used to provide a loosely-coupled application service directory for Android applications.

Features

  • Service directory implementation for loosely-coupled applications.
  • Avoids making code untestable with singletons by having all code pull dependencies from a service directory.
  • Prevents lifecycle issues by storing all state inside application-scoped services!
  • High-coverage automated test suite
  • Easily mocked, strongly-typed Kotlin API
  • API Semantic Versioning enforced with japicmp
  • Apache 2.0 license

Building

Build!

Make sure you clone this repository with git clone --recursive. If you forgot to use --recursive, then execute:

$ git submodule init
$ git submodule update --remote --recursive

The short version: Install an Android SDK and run:

$ ./gradlew clean assembleDebug test

Please read the list of instructions below for specific details on configurations.

Android SDK

Install the Android SDK and Android Studio. We don't support the use of any other IDE at the moment.

JDK

Install a reasonably modern JDK: Java 17 is the current recommendation for Android Studio.

The JAVA_HOME environment variable must be set correctly. You can check what it is set to in most shells with echo $JAVA_HOME. If that command does not show anything, adding the following line to $HOME/.profile and then executing source $HOME/.profile or opening a new shell should suffice:

# Replace NNN with your particular version of 17.
export JAVA_HOME=/path/to/jdk17_NNN

You can verify that everything is set up correctly by inspecting the results of both java -version and javac -version:

$ java -version
openjdk version "17.0.8" 2023-07-18
OpenJDK Runtime Environment (build 17.0.8+7)
OpenJDK 64-Bit Server VM (build 17.0.8+7, mixed mode)

Versioning

The API complies with Semantic Versioning 2.0.0, and this is enforced using japicmp. The current version of the code is analyzed with respect to the previous version, and incompatible changes will require a major version increment. Please see the VERSIONING.txt file for the list of packages that are exempt from versioning rules due to being private implementation packages.

Modules

The project is heavily modularized in order to keep the separate components as loosely coupled as possible. New features should typically be implemented as new modules.

Module Description
org.thepalaceproject.servicedirectory.boot Service directory (Boot)
org.thepalaceproject.servicedirectory.demo Service directory (Demo application)
org.thepalaceproject.servicedirectory.main Service directory (Main implementation)
org.thepalaceproject.servicedirectory.tests Service directory (Test suite)

License

Copyright 2023 LYRASIS

Licensed under the Apache License, Version 2.0 (the "License"); you may not use
this file except in compliance with the License. You may obtain a copy of the
License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed
under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
CONDITIONS OF ANY KIND, either express or implied. See the License for the
specific language governing permissions and limitations under the License.