diff --git a/README.in b/README.in
new file mode 100644
index 0000000..c524d9f
--- /dev/null
+++ b/README.in
@@ -0,0 +1,53 @@
+
+## jranges
+
+A set of functions and types for dealing with ranges and intervals.
+
+## Features
+
+* Immutable range types, for specifying ranges over all the available integral
+ and floating point types.
+* Functions for checking that values fall within given ranges.
+* High coverage test suite.
+* [OSGi-ready](https://www.osgi.org/)
+* [JPMS-ready](https://en.wikipedia.org/wiki/Java_Platform_Module_System)
+* ISC license.
+
+## Usage
+
+### Range Checks
+
+Use the `RangeCheck` class to perform range checks:
+
+```
+RangeCheck.checkIncludedInLong(
+ 23L,
+ "Number of assignments",
+ RangeInclusiveL.of(0L, 99),
+ "Valid number of assignments"
+);
+
+RangeCheck.checkIncludedInLong(
+ 130L,
+ "Number of assignments",
+ RangeInclusiveL.of(0L, 99),
+ "Valid number of assignments"
+);
+```
+
+The second call will throw a `RangeCheckException` with a message similar to
+`Range check failed: 0 <= Number of assignments (130) <= 99 (Valid number of assignments) == false`.
+
+### Range Types
+
+The package exposes numerous immutable half-open and inclusive range types,
+specialized to various Java numeric types:
+
+ * `RangeHalfOpenB`
+ * `RangeHalfOpenD`
+ * `RangeHalfOpenI`
+ * `RangeHalfOpenL`
+ * `RangeInclusiveB`
+ * `RangeInclusiveD`
+ * `RangeInclusiveI`
+ * `RangeInclusiveL`
diff --git a/README.md b/README.md
index f75e091..258eca5 100644
--- a/README.md
+++ b/README.md
@@ -13,3 +13,57 @@ jranges
| OpenJDK (Temurin) LTS | Linux | [![Build (OpenJDK (Temurin) LTS, Linux)](https://img.shields.io/github/actions/workflow/status/io7m-com/jranges/main.linux.temurin.lts.yml)](https://www.github.com/io7m-com/jranges/actions?query=workflow%3Amain.linux.temurin.lts)|
| OpenJDK (Temurin) Current | Windows | [![Build (OpenJDK (Temurin) Current, Windows)](https://img.shields.io/github/actions/workflow/status/io7m-com/jranges/main.windows.temurin.current.yml)](https://www.github.com/io7m-com/jranges/actions?query=workflow%3Amain.windows.temurin.current)|
| OpenJDK (Temurin) LTS | Windows | [![Build (OpenJDK (Temurin) LTS, Windows)](https://img.shields.io/github/actions/workflow/status/io7m-com/jranges/main.windows.temurin.lts.yml)](https://www.github.com/io7m-com/jranges/actions?query=workflow%3Amain.windows.temurin.lts)|
+
+## jranges
+
+A set of functions and types for dealing with ranges and intervals.
+
+## Features
+
+* Immutable range types, for specifying ranges over all the available integral
+ and floating point types.
+* Functions for checking that values fall within given ranges.
+* High coverage test suite.
+* [OSGi-ready](https://www.osgi.org/)
+* [JPMS-ready](https://en.wikipedia.org/wiki/Java_Platform_Module_System)
+* ISC license.
+
+## Usage
+
+### Range Checks
+
+Use the `RangeCheck` class to perform range checks:
+
+```
+RangeCheck.checkIncludedInLong(
+ 23L,
+ "Number of assignments",
+ RangeInclusiveL.of(0L, 99),
+ "Valid number of assignments"
+);
+
+RangeCheck.checkIncludedInLong(
+ 130L,
+ "Number of assignments",
+ RangeInclusiveL.of(0L, 99),
+ "Valid number of assignments"
+);
+```
+
+The second call will throw a `RangeCheckException` with a message similar to
+`Range check failed: 0 <= Number of assignments (130) <= 99 (Valid number of assignments) == false`.
+
+### Range Types
+
+The package exposes numerous immutable half-open and inclusive range types,
+specialized to various Java numeric types:
+
+ * `RangeHalfOpenB`
+ * `RangeHalfOpenD`
+ * `RangeHalfOpenI`
+ * `RangeHalfOpenL`
+ * `RangeInclusiveB`
+ * `RangeInclusiveD`
+ * `RangeInclusiveI`
+ * `RangeInclusiveL`
+
diff --git a/com.io7m.jranges.documentation/pom.xml b/com.io7m.jranges.documentation/pom.xml
deleted file mode 100644
index be55965..0000000
--- a/com.io7m.jranges.documentation/pom.xml
+++ /dev/null
@@ -1,223 +0,0 @@
-
-
-
- 4.0.0
-
- com.io7m.jranges
- com.io7m.jranges
- 5.0.1-SNAPSHOT
-
- com.io7m.jranges.documentation
-
- jar
- com.io7m.jranges.documentation
- Range handling (Documentation)
- https://www.io7m.com/software/jranges
-
-
- true
-
-
-
-
- ${project.groupId}
- com.io7m.jranges.core
- ${project.version}
-
-
- com.io7m.primogenitor
- com.io7m.primogenitor.support
-
-
- org.osgi
- org.osgi.annotation.versioning
- provided
-
-
- org.osgi
- org.osgi.annotation.bundle
- provided
-
-
- org.immutables
- value
- ${io7m.org.immutables.version}
- provided
-
-
- com.io7m.immutables.style
- com.io7m.immutables.style
- provided
-
-
-
-
-
-
-
- org.apache.maven.plugins
- maven-resources-plugin
-
-
- copy-documentation-resources
-
- copy-resources
-
- generate-resources
-
- ${project.build.directory}/documentation/
-
-
- src/main/resources/com/io7m/jranges/documentation/
- true
-
-
-
-
-
-
-
-
-
- org.apache.maven.plugins
- maven-dependency-plugin
-
-
- unpack-sources
- package
-
- unpack-dependencies
-
-
- module-info.java
- ${project.groupId}
- sources
- false
- ${project.build.directory}/javadoc-sources
-
-
-
- make-classpath
- package
-
- build-classpath
-
-
- ${project.build.directory}/javadoc-classpath
-
-
-
-
-
-
-
- com.io7m.jstructural
- io7m-jstructural-maven-plugin
-
-
- make-documentation-single
- prepare-package
-
- transform
-
-
- ${project.build.directory}/documentation/documentation.xml
- ${project.build.directory}/documentation/
- ${project.build.directory}/documentation/brand.xml
- XHTML_SINGLE
-
-
-
- make-documentation-multi
- prepare-package
-
- transform
-
-
- ${project.build.directory}/documentation/documentation.xml
- ${project.build.directory}/documentation/
- ${project.build.directory}/documentation/brand.xml
- XHTML_MULTI
-
-
-
-
-
-
-
- org.codehaus.mojo
- exec-maven-plugin
-
-
- javadoc
-
- java
-
- package
-
- com.io7m.primogenitor.support.TrivialJavadoc
-
- ${project.build.directory}/javadoc-sources
- ${project.build.directory}/javadoc-classpath
- ${project.build.directory}/documentation/apidocs
- ${project.build.directory}/javadoc-log.txt
- ${project.build.directory}/javadoc-options
-
-
-
-
-
-
-
-
- org.apache.maven.plugins
- maven-assembly-plugin
-
-
- src/main/assembly/documentation.xml
-
-
-
-
- make-assembly
- package
-
- single
-
-
- false
-
-
-
-
-
-
-
-
- org.codehaus.mojo
- truezip-maven-plugin
- false
-
-
- copy-site-documentation
-
- copy
-
- site
-
- true
-
- ${project.build.directory}/${project.name}-${project.version}.zip/${project.name}-${project.version}/
- ${project.parent.build.directory}/minisite/documentation/
-
-
-
-
-
-
-
-
-
diff --git a/com.io7m.jranges.documentation/src/main/assembly/documentation.xml b/com.io7m.jranges.documentation/src/main/assembly/documentation.xml
deleted file mode 100644
index b888871..0000000
--- a/com.io7m.jranges.documentation/src/main/assembly/documentation.xml
+++ /dev/null
@@ -1,20 +0,0 @@
-
- documentation
- ${project.name}-${project.version}
-
- zip
-
-
-
- ${project.build.directory}/documentation
- /
-
-
- ${project.build.directory}/site/apidocs
- /apidocs
-
-
-
diff --git a/com.io7m.jranges.documentation/src/main/java/com/io7m/jranges/documentation/Documentation.java b/com.io7m.jranges.documentation/src/main/java/com/io7m/jranges/documentation/Documentation.java
deleted file mode 100644
index a80b83b..0000000
--- a/com.io7m.jranges.documentation/src/main/java/com/io7m/jranges/documentation/Documentation.java
+++ /dev/null
@@ -1,29 +0,0 @@
-/*
- * Copyright © 2015 Mark Raynsford https://www.io7m.com
- *
- * Permission to use, copy, modify, and/or distribute this software for any
- * purpose with or without fee is hereby granted, provided that the above
- * copyright notice and this permission notice appear in all copies.
- *
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
- * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR
- * IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
- */
-
-package com.io7m.jranges.documentation;
-
-/**
- * Documentation marker class.
- */
-
-public final class Documentation
-{
- private Documentation()
- {
-
- }
-}
diff --git a/com.io7m.jranges.documentation/src/main/java/com/io7m/jranges/documentation/package-info.java b/com.io7m.jranges.documentation/src/main/java/com/io7m/jranges/documentation/package-info.java
deleted file mode 100644
index 835fd38..0000000
--- a/com.io7m.jranges.documentation/src/main/java/com/io7m/jranges/documentation/package-info.java
+++ /dev/null
@@ -1,22 +0,0 @@
-/*
- * Copyright © 2015 Mark Raynsford https://www.io7m.com
- *
- * Permission to use, copy, modify, and/or distribute this software for any
- * purpose with or without fee is hereby granted, provided that the above
- * copyright notice and this permission notice appear in all copies.
- *
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
- * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR
- * IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
- */
-
-/**
- * Documentation.
- */
-
-package com.io7m.jranges.documentation;
-
diff --git a/com.io7m.jranges.documentation/src/main/java/module-info.java b/com.io7m.jranges.documentation/src/main/java/module-info.java
deleted file mode 100644
index e855fe7..0000000
--- a/com.io7m.jranges.documentation/src/main/java/module-info.java
+++ /dev/null
@@ -1,31 +0,0 @@
-/*
- * Copyright © 2015 Mark Raynsford https://www.io7m.com
- *
- * Permission to use, copy, modify, and/or distribute this software for any
- * purpose with or without fee is hereby granted, provided that the above
- * copyright notice and this permission notice appear in all copies.
- *
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
- * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR
- * IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
- */
-
-/**
- * Documentation.
- */
-
-module com.io7m.jranges.documentation
-{
- requires static com.io7m.immutables.style;
- requires static org.immutables.value;
- requires static org.osgi.annotation.bundle;
- requires static org.osgi.annotation.versioning;
-
- requires com.io7m.jranges.core;
-
- exports com.io7m.jranges.documentation;
-}
\ No newline at end of file
diff --git a/com.io7m.jranges.documentation/src/main/resources/com/io7m/jranges/documentation/brand.xml b/com.io7m.jranges.documentation/src/main/resources/com/io7m/jranges/documentation/brand.xml
deleted file mode 100644
index 61f9658..0000000
--- a/com.io7m.jranges.documentation/src/main/resources/com/io7m/jranges/documentation/brand.xml
+++ /dev/null
@@ -1,9 +0,0 @@
-
-
\ No newline at end of file
diff --git a/com.io7m.jranges.documentation/src/main/resources/com/io7m/jranges/documentation/documentation.css b/com.io7m.jranges.documentation/src/main/resources/com/io7m/jranges/documentation/documentation.css
deleted file mode 100644
index 2b9cd43..0000000
--- a/com.io7m.jranges.documentation/src/main/resources/com/io7m/jranges/documentation/documentation.css
+++ /dev/null
@@ -1,63 +0,0 @@
-.brand
-{
- font-size: 75%;
- font-family: monospace;
-}
-
-.brand_left
-{
- float: left;
-}
-
-.brand_right
-{
- text-align: right;
-}
-
-.package
-{
- font-family: monospace;
- font-weight: bold;
-}
-
-.attribute,
-.class,
-.command,
-.constant,
-.element,
-.file,
-.function,
-.keyword,
-.type
-{
- font-family: monospace;
-}
-
-.example, .license, .terminal
-{
- font-family: monospace;
- border: 1px solid #ccc;
- padding-top: 1.0em;
- padding-left: 1.0em;
- padding-bottom: 1.0em;
- margin-top: 1.2em;
- overflow: auto;
-}
-
-.dependencies table td
-{
- padding-right: 3.0em;
- font-family: monospace;
- font-size: 9pt;
-}
-
-.platforms table td
-{
- padding-right: 2.0em;
-}
-.platforms table tbody,
-.platforms table thead
-{
- font-size: 8pt;
- font-family: monospace;
-}
diff --git a/com.io7m.jranges.documentation/src/main/resources/com/io7m/jranges/documentation/documentation.xml b/com.io7m.jranges.documentation/src/main/resources/com/io7m/jranges/documentation/documentation.xml
deleted file mode 100644
index fb5eb11..0000000
--- a/com.io7m.jranges.documentation/src/main/resources/com/io7m/jranges/documentation/documentation.xml
+++ /dev/null
@@ -1,124 +0,0 @@
-
-
-
-
-
- ${project.parent.name} ${project.version} Documentation
- documentation.css
-
-
-
- Package Information
-
-
- Orientation
-
- Overview
-
- The ${project.parent.name} package
- implements a set of functions and types for handling ranges and intervals
- in Java.
-
-
-
-
-
- Installation
-
- Source compilation
-
- The project can be compiled and installed with
- Maven:
-
-
-
-
-
-
-
- Maven
-
- Regular releases are made to the
- Central Repository,
- so it's possible to use the ${project.parent.name}
- package in your projects with the following Maven dependency:
-
-
-
- ${project.groupId}
- ${project.parent.artifactId}-core
- ${project.version}
-]]>
-
-
- All io7m.com
- packages use Semantic Versioning
-
- http://semver.org
- , which implies that it is always safe to use version ranges
- with an exclusive upper bound equal to the next major version - the API of
- the package will not change in a backwards-incompatible manner before the
- next major version.
-
-
-
-
-
- Platform Specific Issues
-
- There are currently no known platform-specific issues.
-
-
-
-
- License
-
- All files distributed with the ${project.parent.name}
- package are placed under the following license:
- https://www.io7m.com
-
-Permission to use, copy, modify, and/or distribute this software for any
-purpose with or without fee is hereby granted, provided that the above
-copyright notice and this permission notice appear in all copies.
-
-THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
-WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
-MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
-ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
-WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
-ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
-OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.]]>
-
-
-
-
-
-
- API Reference
-
-
- Javadoc
-
- API documentation for the package is provided via the
- included Javadoc.
-
-
-
-
-
diff --git a/pom.xml b/pom.xml
index def16f4..0a9c003 100644
--- a/pom.xml
+++ b/pom.xml
@@ -22,7 +22,6 @@
com.io7m.jranges.core
- com.io7m.jranges.documentation
com.io7m.jranges.tests
@@ -69,6 +68,10 @@
sonatype-nexus-staging
https://s01.oss.sonatype.org/service/local/staging/deploy/maven2/
+
+ sonatype-nexus-snapshots
+ https://s01.oss.sonatype.org/content/repositories/snapshots/
+
@@ -153,13 +156,6 @@
-
-
- com.io7m.jstructural
- io7m-jstructural-maven-plugin
- 5.0.0
-
-
com.github.spotbugs