Mercurial > gemma
view pkg/models/reproject.go @ 1017:a244b18cb916
Added GNU Affero General Public License.
Adjusted the headers of the Go files to be AGPLv3.
author | Sascha L. Teichmann <sascha.teichmann@intevation.de> |
---|---|
date | Tue, 23 Oct 2018 18:15:14 +0200 |
parents | 01ba06da8f46 |
children | d753ce6cf588 |
line wrap: on
line source
// This is Free Software under GNU Affero General Public License v >= 3.0 // without warranty, see README.md and license for details. // // SPDX-License-Identifier: AGPL-3.0-or-later // License-Filename: LICENSES/AGPL-3.0.txt // // Copyright (C) 2018 by via donau // – Österreichische Wasserstraßen-Gesellschaft mbH // Software engineering by Intevation GmbH // // Author(s): // * Sascha L. Teichmann <sascha.teichmann@intevation.de> package models import ( "context" "database/sql" ) const reprojectSQL = ` SELECT ST_X(p), ST_Y(p) FROM ST_Transform(ST_SetSRID(ST_MakePoint($1, $2), $3::integer), $4::integer) AS p` type Reprojector struct { stmt *sql.Stmt FromEPSG uint32 ToEPSG uint32 } func NewReprojector( conn *sql.Conn, ctx context.Context, fromEPSG, toEPSG uint32, ) (*Reprojector, error) { stmt, err := conn.PrepareContext(ctx, reprojectSQL) if err != nil { return nil, err } return &Reprojector{ stmt: stmt, FromEPSG: fromEPSG, ToEPSG: toEPSG, }, nil } func (r *Reprojector) Close() error { if s := r.stmt; s != nil { r.stmt = nil return s.Close() } return nil } func (r *Reprojector) Reproject( x, y float64, ctx context.Context, ) (v, w float64, err error) { err = r.stmt.QueryRowContext(ctx, x, y, r.FromEPSG, r.ToEPSG).Scan(&v, &w) return }