osdm_sys/models/
geo_position_ref.rs

1/*
2 * UIC 90918-10 - OSDM
3 *
4 * Specifications for the OSDM API standard. The OSDM specification supports two modes of operation: Retailer Mode and Distributor Mode. The API works identically in both modes, except that in distributor mode the API also returns fare information.  The following resources are key to get started:    -  [Processes](https://osdm.io/spec/processes/)   -  [Models](https://osdm.io/spec/models/)   -  [Getting started](https://osdm.io/spec/getting-started/) 
5 *
6 * The version of the OpenAPI document: 3.7.0
7 * Contact: osdm@uic.org
8 * Generated by: https://openapi-generator.tech
9 */
10
11use crate::models;
12use serde::{Deserialize, Serialize};
13
14/// GeoPositionRef : Reference to a GeoPosition consisting of latitude and longitude. 
15#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
16pub struct GeoPositionRef {
17    /// Attribute is used as discriminator for inheritance between data types.
18    #[serde(rename = "objectType")]
19    pub object_type: String,
20    /// Latitude from equator. -90 (South) to +90 (North). Decimal degrees. e.g. 56.356. 
21    #[serde(rename = "latitude")]
22    pub latitude: f64,
23    /// Longitude from Greenwich Meridian. -180 (West) to +180 (East). Decimal degrees. eg 2.356. 
24    #[serde(rename = "longitude")]
25    pub longitude: f64,
26}
27
28impl GeoPositionRef {
29    /// Reference to a GeoPosition consisting of latitude and longitude. 
30    pub fn new(object_type: String, latitude: f64, longitude: f64) -> GeoPositionRef {
31        GeoPositionRef {
32            object_type,
33            latitude,
34            longitude,
35        }
36    }
37}
38