X-Git-Url: https://git.street.me.uk/andy/viking.git/blobdiff_plain/acaf7113fffde4a6a6f6c0d57a4eea27e1024a31..af2341f318ad676de4945c1dd471c6a6ed2d313b:/src/vikwaypoint.c?ds=inline diff --git a/src/vikwaypoint.c b/src/vikwaypoint.c index d530d422..57626671 100644 --- a/src/vikwaypoint.c +++ b/src/vikwaypoint.c @@ -20,14 +20,17 @@ */ #include +#include #include "coords.h" #include "vikcoord.h" #include "vikwaypoint.h" +#include "globals.h" VikWaypoint *vik_waypoint_new() { VikWaypoint *wp = g_malloc ( sizeof ( VikWaypoint ) ); + wp->altitude = VIK_DEFAULT_ALTITUDE; wp->comment = NULL; wp->image = NULL; wp->symbol = NULL; @@ -98,3 +101,50 @@ VikWaypoint *vik_waypoint_copy(const VikWaypoint *wp) return new_wp; } +void vik_waypoint_marshall ( VikWaypoint *wp, guint8 **data, guint *datalen) +{ + GByteArray *b = g_byte_array_new(); + guint len; + + g_byte_array_append(b, (guint8 *)wp, sizeof(*wp)); + +#define vwm_append(s) \ + len = (s) ? strlen(s)+1 : 0; \ + g_byte_array_append(b, (guint8 *)&len, sizeof(len)); \ + if (s) g_byte_array_append(b, (guint8 *)s, len); + + vwm_append(wp->comment); + vwm_append(wp->image); + vwm_append(wp->symbol); + + *data = b->data; + *datalen = b->len; + g_byte_array_free(b, FALSE); +#undef vwm_append +} + +VikWaypoint *vik_waypoint_unmarshall (guint8 *data, guint datalen) +{ + guint len; + VikWaypoint *new_wp = vik_waypoint_new(); + memcpy(new_wp, data, sizeof(*new_wp)); + data += sizeof(*new_wp); + +#define vwu_get(s) \ + len = *(guint *)data; \ + data += sizeof(len); \ + if (len) { \ + (s) = g_strdup((gchar *)data); \ + } else { \ + (s) = NULL; \ + } \ + data += len; + + vwu_get(new_wp->comment); + vwu_get(new_wp->image); + vwu_get(new_wp->symbol); + + return new_wp; +#undef vwu_get +} +