Skip to content

Commit

Permalink
Merge pull request #773 from seadowg/docs
Browse files Browse the repository at this point in the history
Improve docs
  • Loading branch information
lognaturel authored Jul 1, 2024
2 parents 6e72a2a + 0cd7d38 commit 2d4a5f4
Show file tree
Hide file tree
Showing 2 changed files with 49 additions and 6 deletions.
31 changes: 31 additions & 0 deletions PLUGINS.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
# Plugins

Various use cases of JavaRosa can be extended with plugins.

## Parse

Intercept parts of the process and attach data to the created `FormDef` through its extras.

### API
- `XFormParser#addProcessor`
- `FormDef#getExtras`

The default `XFormParser` can be overridden by creating an implementation of `IXFormParserFactory` (`IXFormParserFactory.Wrapper` if you want to chain multiple plugins) and calling `XFormUtils.setXFormParserFactory` with it.

## Finalization

Inspect the `FormEntryModel` after finalization (or "post processing") and attach data via its extras.

### API
- `FormEntryController#addPostProcessor`
- `FormEntryModel#getExtras`

## Instance

Inspect external instances (their ID and parsed XML) after parsing or provide custom parsers for specific instances or file types.

### API
- `ExternalInstanceParser#addFileInstanceParser`
- `ExternalInstanceparsser#addProcessor`

The default `ExternalInstanceParser` can be overridden by creating an implementation of `ExternalInstanceParserFactory` and calling `XFormUtils.setExternalInstanceParserFactory` with it.
24 changes: 18 additions & 6 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,11 +20,23 @@ ODK JavaRosa is part of ODK, a free and open-source set of tools which help orga
* ODK developer Slack chat: [https://slack.getodk.org](https://slack.getodk.org)
* ODK developer wiki: [https://github.com/getodk/getodk/wiki](https://github.com/getodk/getodk/wiki)

## Releases

Releases are available from [Maven Central](https://central.sonatype.com/artifact/org.getodk/javarosa).

Snapshots versions are also published for each commit to `master` and are available from [oss.sonatype.org](https://oss.sonatype.org).

## Requirements

JavaRosa works on Android API level 21+ (with desugaring enabled) and Java 8+.

## Setting up your development environment
## Extending

JavaRosa is intended be extended to support extra features through a "plugin" approach documented [here](PLUGINS.md) .

## Development

### Setting up your development environment

1. Fork the javarosa project ([why and how to fork](https://help.github.com/articles/fork-a-repo/))

Expand All @@ -34,13 +46,13 @@ JavaRosa works on Android API level 21+ (with desugaring enabled) and Java 8+.

We recommend using [IntelliJ IDEA](https://www.jetbrains.com/idea/) for development. On the welcome screen, click `Import Project`, navigate to your javarosa folder, and select the `build.gradle` file. Use the defaults through the wizard. Once the project is imported, IntelliJ may ask you to update your remote Maven repositories. Follow the instructions to do so.

## Building the project
### Building the project

To build the project, go to the `View` menu, then `Tool Windows > Gradle`. `build` will be in `javarosa > Tasks > build > build`. Double-click `build` to package the application. This Gradle task will now be the default action in your `Run` menu.

To package a jar, use the `jar` Gradle task.

## Running benchmarks
### Running benchmarks

JavaRosa can be used to parse and fill very large forms on inexpensive devices and so it's important to keep an eye on performance. Benchmarks using [JMH](http://openjdk.java.net/projects/code-tools/jmh/) and the [JMH Gradle plugin](https://github.com/melix/jmh-gradle-plugin) have been introduced to compare relative performance as code changes are made. We have found that running these benchmarks with the `jmh` Gradle task or through IntelliJ can produce inconsistent results. The most reliable way we have found to run them is to first build a `jar` with the `jmhJar` Gradle task and then to run the jar:

Expand All @@ -50,17 +62,17 @@ This also makes it easy to selectively run a subset of benchmarks by including a

While benchmarks can help identify relative performance improvements or regressions, they are not always a reliable proxy for how code will perform in a realistic context. Profiling is helpful for identifying parts of the code that are worth analyzing and optimizing as well as to validate that any performance changes have the intended effects.

## Contributing code
### Contributing code

Any and all contributions to the project are welcome. ODK JavaRosa is used across the world primarily by organizations with a social purpose so you can have real impact!

If you're ready to contribute code, see [the contribution guide](CONTRIBUTING.md).

## Downloading builds
### Downloading builds

Per-commit debug builds can be found on [CircleCI](https://circleci.com/gh/getodk/javarosa). Login with your GitHub account, click the build you'd like, then find the JAR in the Artifacts tab under $CIRCLE_ARTIFACTS.

## Publishing the jar to OSSRH and Maven Central
### Publishing the jar to OSSRH and Maven Central

Project maintainers have the private keys to upload signed jars to Sonatype's OSS Repository Hosting (OSSRH) service which is then synced to Maven's Central Repository. This process is [outlined here](http://central.sonatype.org/pages/apache-maven.html).

Expand Down

0 comments on commit 2d4a5f4

Please sign in to comment.