#geocoding #http-service #service #coordinates #nearest #find #name

geosuggest-core

Suggest by name or find nearest by coordinates cities

16 releases

0.6.5 Dec 16, 2024
0.6.4 Sep 20, 2024
0.6.3 Jun 15, 2024
0.6.2 Mar 23, 2024
0.5.1 Sep 28, 2023

#156 in HTTP server

Download history 252/week @ 2024-09-22 153/week @ 2024-09-29 187/week @ 2024-10-06 160/week @ 2024-10-13 189/week @ 2024-10-20 195/week @ 2024-10-27 208/week @ 2024-11-03 143/week @ 2024-11-10 226/week @ 2024-11-17 170/week @ 2024-11-24 434/week @ 2024-12-01 187/week @ 2024-12-08 316/week @ 2024-12-15 189/week @ 2024-12-22 159/week @ 2024-12-29 229/week @ 2025-01-05

899 downloads per month
Used in 2 crates

MIT license

54KB
1K SLoC

geosuggest-core

Library to suggest and to find nearest by coordinates cities

Live demo with sources

HTTP service

Examples

Usage example

use tokio;
use anyhow::Result;

use geosuggest_core::{Engine, storage::{self, IndexStorage}};
use geosuggest_utils::{IndexUpdater, IndexUpdaterSettings};

#[tokio::main]
async fn main() -> Result<()> {
    println!("Build index...");
    let engine = load_engine().await?;

    println!(
        "Suggest result: {:#?}",
        engine.suggest::<&str>("Beverley", 1, None, Some(&["us"]))
    );
    println!(
        "Reverse result: {:#?}",
        engine.reverse::<&str>((11.138298, 57.510973), 1, None, None)
    );

    Ok(())
}

async fn load_engine() -> Result<Engine> {
    let index_file = std::path::Path::new("/tmp/geosuggest-index.bincode");

    let updater = IndexUpdater::new(IndexUpdaterSettings {
        names: None, // no multilang support
        ..Default::default()
    })?;

    let storage = storage::bincode::Storage::new();

    Ok(if index_file.exists() {
        // load existed index
        let metadata = storage
            .read_metadata(index_file)
            .map_err(|e| anyhow::anyhow!("On load index metadata from {index_file:?}: {e}"))?;

        match metadata {
            Some(m) if updater.has_updates(&m).await? => {
                let engine = updater.build().await?;
                storage
                    .dump_to(index_file, &engine)
                    .map_err(|e| anyhow::anyhow!("Failed dump to {index_file:?}: {e}"))?;
                engine
            }
            _ => storage
                .load_from(index_file)
                .map_err(|e| anyhow::anyhow!("On load index from {index_file:?}: {e}"))?,
        }
    } else {
        // initial
        let engine = updater.build().await?;
        storage
            .dump_to(index_file, &engine)
            .map_err(|e| anyhow::anyhow!("Failed dump to {index_file:?}: {e}"))?;
        engine
    })

}

Dependencies

~7–30MB
~441K SLoC