summaryrefslogtreecommitdiffstats
path: root/geoclue/gpsd-3.4.patch
diff options
context:
space:
mode:
authorpiernov <piernov@piernov.org>2012-01-23 02:46:50 +0100
committerpiernov <piernov@piernov.org>2012-01-23 02:46:50 +0100
commit4d3d674e3a374c06734ccc2e1d7a62e62cd54644 (patch)
treee16206a4c5b2f9a1f535e65894be15600ca80427 /geoclue/gpsd-3.4.patch
parentd2e1429c6c72b88f3bf84f91240b441bff0b4534 (diff)
downloadgnome3-4d3d674e3a374c06734ccc2e1d7a62e62cd54644.tar.gz
gnome3-4d3d674e3a374c06734ccc2e1d7a62e62cd54644.tar.bz2
gnome3-4d3d674e3a374c06734ccc2e1d7a62e62cd54644.tar.xz
gnome3-4d3d674e3a374c06734ccc2e1d7a62e62cd54644.zip
geoclue 0.12-3 nouveau patch
Diffstat (limited to 'geoclue/gpsd-3.4.patch')
-rw-r--r--geoclue/gpsd-3.4.patch75
1 files changed, 75 insertions, 0 deletions
diff --git a/geoclue/gpsd-3.4.patch b/geoclue/gpsd-3.4.patch
new file mode 100644
index 0000000..6a71017
--- /dev/null
+++ b/geoclue/gpsd-3.4.patch
@@ -0,0 +1,75 @@
+Description: Refactoring to support new libgps API
+Author: James Page <james.page@ubuntu.com>
+Bug: https://bugs.freedesktop.org/show_bug.cgi?id=40996
+Forwarded: no
+
+Index: geoclue-providers-0.12.0/providers/gpsd/geoclue-gpsd.c
+===================================================================
+--- geoclue-providers-0.12.0.orig/providers/gpsd/geoclue-gpsd.c 2011-12-14 10:57:44.000000000 +0000
++++ geoclue-providers-0.12.0/providers/gpsd/geoclue-gpsd.c 2011-12-14 11:03:11.271878045 +0000
+@@ -40,7 +40,12 @@
+ #include <geoclue/gc-iface-position.h>
+ #include <geoclue/gc-iface-velocity.h>
+
++#if GPSD_API_MAJOR_VERSION >= 5
++/* gps_data conflicts with gps_data function */
++typedef struct gps_data_t gps_data_l;
++#else
+ typedef struct gps_data_t gps_data;
++#endif
+ typedef struct gps_fix_t gps_fix;
+
+ /* only listing used tags */
+@@ -59,7 +64,11 @@
+ char *host;
+ char *port;
+
++#if GPSD_API_MAJOR_VERSION >= 5
++ gps_data_l *gpsdata;
++#else
+ gps_data *gpsdata;
++#endif
+
+ gps_fix *last_fix;
+
+@@ -394,10 +403,16 @@
+ static gboolean
+ geoclue_gpsd_start_gpsd (GeoclueGpsd *self)
+ {
++#if GPSD_API_MAJOR_VERSION >= 5
++ int status = gps_open (self->host, self->port, self->gpsdata);
++ if (status == 0) {
++ gps_stream(self->gpsdata, WATCH_ENABLE | WATCH_NMEA, NULL);
++#else
+ self->gpsdata = gps_open (self->host, self->port);
+ if (self->gpsdata) {
+ gps_stream(self->gpsdata, WATCH_ENABLE | WATCH_NMEA | POLL_NONBLOCK, NULL);
+ gps_set_raw_hook (self->gpsdata, gpsd_raw_hook);
++#endif
+ return TRUE;
+ } else {
+ g_warning ("gps_open() failed, is gpsd running (host=%s,port=%s)?", self->host, self->port);
+@@ -410,10 +425,23 @@
+ {
+ GeoclueGpsd *self = (GeoclueGpsd*)data;
+ if (self->gpsdata) {
++#if GPSD_API_MAJOR_VERSION >= 5
++ /* gps_poll and gps_set_raw_hook no longer present in this API version */
++ if (gps_waiting(self->gpsdata, 500)) {
++ if (gps_read(self->gpsdata) == -1) {
++ geoclue_gpsd_set_status (self, GEOCLUE_STATUS_ERROR);
++ geoclue_gpsd_stop_gpsd(self);
++ return FALSE;
++ } else {
++ /* Call existing raw_hook to process the data */
++ gpsd_raw_hook(self->gpsdata, NULL, 0);
++ }
++#else
+ if (gps_poll(self->gpsdata) < 0) {
+ geoclue_gpsd_set_status (self, GEOCLUE_STATUS_ERROR);
+ geoclue_gpsd_stop_gpsd(self);
+ return FALSE;
++#endif
+ }
+ }
+ return TRUE;