From b7aeb06639ef421381f7aa6be26f27634ed12d93 Mon Sep 17 00:00:00 2001 From: Teemu Ikonen Date: Tue, 30 Jan 2024 17:44:06 +0200 Subject: [PATCH] Write speed to GPX 1.0 files --- CHANGELOG.md | 4 ++++ src/writer.rs | 25 ++++++++++++++++--------- 2 files changed, 20 insertions(+), 9 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 043940a..8233435 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,9 @@ # CHANGELOG +## Unreleased + +- [#101](https://github.com/georust/gpx/pull/101): Write speed to GPX 1.0 files + ## 0.10.0 - [#100](https://github.com/georust/gpx/pull/100): Add write examples to `README.md` diff --git a/src/writer.rs b/src/writer.rs index 667cc32..8fef2a5 100644 --- a/src/writer.rs +++ b/src/writer.rs @@ -70,13 +70,13 @@ pub fn write_with_event_writer(gpx: &Gpx, writer: &mut EventWriter) )?; write_metadata(gpx, writer)?; for point in &gpx.waypoints { - write_waypoint("wpt", point, writer)?; + write_waypoint(gpx.version, "wpt", point, writer)?; } for track in &gpx.tracks { - write_track(track, writer)?; + write_track(gpx.version, track, writer)?; } for route in &gpx.routes { - write_route(route, writer)?; + write_route(gpx.version, route, writer)?; } write_xml_event(XmlEvent::end_element(), writer)?; Ok(()) @@ -293,7 +293,7 @@ fn write_fix_if_exists(fix: &Option, writer: &mut EventWriter) Ok(()) } -fn write_track(track: &Track, writer: &mut EventWriter) -> GpxResult<()> { +fn write_track(version: GpxVersion, track: &Track, writer: &mut EventWriter) -> GpxResult<()> { write_xml_event(XmlEvent::start_element("trk"), writer)?; write_string_if_exists("name", &track.name, writer)?; write_string_if_exists("cmt", &track.comment, writer)?; @@ -304,13 +304,13 @@ fn write_track(track: &Track, writer: &mut EventWriter) -> GpxResul } write_string_if_exists("type", &track.type_, writer)?; for segment in &track.segments { - write_track_segment(segment, writer)?; + write_track_segment(version, segment, writer)?; } write_xml_event(XmlEvent::end_element(), writer)?; Ok(()) } -fn write_route(route: &Route, writer: &mut EventWriter) -> GpxResult<()> { +fn write_route(version: GpxVersion, route: &Route, writer: &mut EventWriter) -> GpxResult<()> { write_xml_event(XmlEvent::start_element("rte"), writer)?; write_string_if_exists("name", &route.name, writer)?; write_string_if_exists("cmt", &route.comment, writer)?; @@ -322,25 +322,27 @@ fn write_route(route: &Route, writer: &mut EventWriter) -> GpxResul write_value_if_exists("number", &route.number, writer)?; write_string_if_exists("type", &route.type_, writer)?; for point in &route.points { - write_waypoint("rtept", point, writer)?; + write_waypoint(version, "rtept", point, writer)?; } write_xml_event(XmlEvent::end_element(), writer)?; Ok(()) } fn write_track_segment( + version: GpxVersion, segment: &TrackSegment, writer: &mut EventWriter, ) -> GpxResult<()> { write_xml_event(XmlEvent::start_element("trkseg"), writer)?; for point in &segment.points { - write_waypoint("trkpt", point, writer)?; + write_waypoint(version, "trkpt", point, writer)?; } write_xml_event(XmlEvent::end_element(), writer)?; Ok(()) } fn write_waypoint( + version: GpxVersion, tagname: &str, waypoint: &Waypoint, writer: &mut EventWriter, @@ -352,7 +354,12 @@ fn write_waypoint( writer, )?; write_value_if_exists("ele", &waypoint.elevation, writer)?; - // TODO: write speed if GPX version == 1.0 + match version { + GpxVersion::Gpx10 => { + write_value_if_exists("speed", &waypoint.speed, writer)?; + } + _ => {} + } write_time_if_exists(&waypoint.time, writer)?; write_value_if_exists("geoidheight", &waypoint.geoidheight, writer)?; write_string_if_exists("name", &waypoint.name, writer)?;