geoq

Build Status crates.io

Geoq is a command-line tool for working with geospatial data.

It combines common GIS serialization formats with utilities for manipulating and visualizing data on a map.

For example:

```sh

Print the geometry and the set of level 2 geohashes which covers the given geometry

$ echo '{"type":"Polygon","coordinates":[[[-34,38],[-37,32],[-23,33],[-34,38]]]}' | geoq gh covering 2 -o {"type":"Polygon","coordinates":[[[30,10],[40,40],[20,40],[10,20],[30,10]]]} eq en em ej

Feed that output into a map on geojson.io

$ echo '{"type":"Polygon","coordinates":[[[-34,38],[-37,32],[-23,33],[-34,38]]]}' | geoq gh covering 2 -o | geoq map ```

See the Manual for more examples and available commands.

Install

Geoq is installed via cargo, the Rust package manager, and requires nightly rust.

If you have all this set up, you can just run cargo install geoq.

To install Rust and the Cargo toolchain:

curl https://sh.rustup.rs -sSf | sh rustup toolchain install nightly rustup default nightly cargo install geoq

You'll also need to add Cargo's bin directory to your path:

```

e.g. in your ~/.bash_profile or other shell profile

export PATH="$HOME/.cargo/bin:$PATH" ```

Updating an Existing Installation

To pull and install a newer version from crates.io, run:

cargo install geoq --force

Supported Input Formats

Geoq will detect the following GIS input formats automatically:

One Feature Per Line, One Line Per Feature

Geoq processes text inputs on a per-line basis, and it expects inputs not to stretch across multiple lines.

This sometimes causes problems, especially with GeoJSON, because many JSON processing tools like to output pretty-printed JSON in a multi-line format.

One way to fix this problem with pretty-printed GeoJSON is to use the jq tool:

echo '{ "type": "Point", "coordinates": [30, 10] } ' | jq -c . | geoq map

Commands

See the built-in command help using geoq --help or geoq <subcommand> --help for more detailed information on these:

See the Manual for more examples and available commands.

Development

Running Tests

cargo test

Building / Releasing

cargo publish git tag release/<VERSION> git push origin release/<VERSION>