Skip to content

Releases: jillesvangurp/geogeometry

Sealed class for geometry, kotlinx serialization

29 Jan 09:58
Compare
Choose a tag to compare
  • change the geometry interface to be a sealed class
  • add Serializable annotations for kotlinx.serialization; this adds a dependency on kotlinx serialization unfortunately. I may split this off into a separate library at some point. Let me know if this bothers/blocks you.

Thanks @NikkyAI for the PR.

GeometryType.clazz() & GeoGeometry.headingFromTwoPoints

12 Jan 09:00
Compare
Choose a tag to compare
  • new clazz() function on GeometryType to point at the correct Geometry implementation class. Useful for writing custom serializer/deserializer logic for json parsers that don't know what to do with the Geometry interface.
  • new GeoGeometry.headingFromTwoPoints function that calculates the compass direction a line between two points is headed.

New maven repo: jillesvangurp.com

24 Aug 15:59
Compare
Choose a tag to compare

No functional changes since 3.1.1.

Since that release, this is a kotlin multiplatform distribution with packages for -jvm and -js (currently). Unfortunately,
multiplatform does not currently work with jitpack.io which I use on other projects. 3.1.2-3.1.4 on jitpack don't work unfortunately.

So, as a workaround, I currently distribute jars via my website. To add the repository, add something
like this to your build.gradle.kts file:

repositories {
    mavenCentral()
    maven { url = uri("https://www.jillesvangurp.com/maven") }
}

and then add the dependency:

implementation("com.github.jillesvangurp:geogeometry:3.1.5")

Older versions are still available on jitpack. If you are interested,
there's an open bug for this.

Fix jitpack release

24 Aug 11:07
Compare
Choose a tag to compare

Attempt to fix the broken publish step (works fine locally).

Improved multi platform build

01 Aug 06:12
Compare
Choose a tag to compare

More build refactoring. Still trying to iron out some issues with jitpack.io

Multi platform build

20 Jul 09:13
Compare
Choose a tag to compare

Lots of refactoring on the build to enable multiplatform builds. This should still push a jar to jitpack.io but will now also produce a npm package in the build directory (not published currently).

Maintenance release

18 Jul 14:00
Compare
Choose a tag to compare
  • refactor build script
  • get rid of testng

Geojson model classes & bbox fix

16 Jul 16:29
Compare
Choose a tag to compare

This release addresses a few long standing pain points. And in case you are wondering, I'm getting ready to use this framework after not having worked on this for quite some time. So expect more updates in the next months. I already added a few issues as a 'note to self'. If you want to work on this, let me know.

  • We now have geojson model classes. These may be used with your favorite json serialization framework and are awesome for copy pasting stuff to geojson.io. I've also added a few convenient methods for turning sets of geohashes into feature collections, getting a polygon from a bbox, etc. This makes debugging stuff a lot more straightforward. And yes, I'm considering seeing if I can make leaflet and kotlin-js play together for some awesome development tool. Sadly my chronic lack of time is an obstacle for this.
  • Don't worry, this library is still cross platform and has no other dependencies than the kotlin std lib and should continue to work on kotlin-native, kotlin-js, and kotlin-jvm. The project I'm currently working on might end up depending on this for a mobile app with cross platform IOS/Android libraries.
  • Bounding boxes now follow the geojson conventionn of [westLongitude,southLatitude,eastLongitude,northLatitude]. This affects a lot of the algorithms. Let me know if you encounter new bugs. This was a nasty one to fix and forced me to wrap my head around shit I figured out in 2012.
  • Consequently, readability of a lot of the code has been improved by e.g. relying on extension functions and properties of the type aliases we have.
  • This may have a slight impact on runtime performance. However, I've done no bench marking to confirm this. Let me know if you have issues with this.

Minor dependency updates

04 Apr 05:10
Compare
Choose a tag to compare

No functional changes; just did some updates to misc dependencies (mostly test related)

Kotlin Port

28 Jun 12:43
43905ad
Compare
Choose a tag to compare
  • Code ported to Kotlin. I had no other goal with this than to amuse me and to clean up some code. But Kotlin is awesome for code like this.
  • Build now uses gradle.
  • Introduced GeoJson type aliases and cleaned up a lot of Kotlin related warnings
  • Remove runtime dependencies on Java specific packages. My intention is to be able to use this in multi platform kotlin projects. So no more guava, commons-lang or java.lang/java.util dependencies
  • Should mostly be backwards compatible with Java but beware minor API changes. All the key methods are in companion objects and annotated with @JvmStatic which means they look just like they used to from Java.
  • note. I've not yet cut a release and will probably do some more changes before that happens. Check the legacy-java branch if you need the old 2.x releases.