blob: e2770218187f1e247cdff31b6e2302453181746a (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
--- marble-4.6.80/src/plugins/positionprovider/gpsd/GpsdConnection.cpp
+++ marble-4.6.80/src/plugins/positionprovider/gpsd/GpsdConnection.cpp
@@ -18,6 +18,9 @@ using namespace Marble;
GpsdConnection::GpsdConnection( QObject* parent )
: QObject( parent ),
+#if defined( GPSD_API_MAJOR_VERSION ) && ( GPSD_API_MAJOR_VERSION >= 5 )
+ m_gpsd("localhost", DEFAULT_GPSD_PORT),
+#endif
m_timer( 0 )
{
connect( &m_timer, SIGNAL( timeout() ), this, SLOT( update() ) );
@@ -26,7 +29,11 @@ GpsdConnection::GpsdConnection( QObject*
void GpsdConnection::initialize()
{
m_timer.stop();
+#if defined( GPSD_API_MAJOR_VERSION ) && ( GPSD_API_MAJOR_VERSION >= 5 )
+ gps_data_t* data;
+#else
gps_data_t* data = m_gpsd.open();
+#endif
if ( data ) {
m_status = PositionProviderStatusAcquiring;
emit statusChanged( m_status );
@@ -73,8 +80,16 @@ void GpsdConnection::initialize()
void GpsdConnection::update()
{
#if defined( GPSD_API_MAJOR_VERSION ) && ( GPSD_API_MAJOR_VERSION >= 3 ) && defined( PACKET_SET )
+#if defined( GPSD_API_MAJOR_VERSION ) && ( GPSD_API_MAJOR_VERSION >= 5 )
+ if ( m_gpsd.waiting(0) ) {
+#else
if ( m_gpsd.waiting() ) {
+#endif
+#if defined( GPSD_API_MAJOR_VERSION ) && ( GPSD_API_MAJOR_VERSION >= 5 )
+ gps_data_t* data = m_gpsd.read();
+#else
gps_data_t* data = m_gpsd.poll();
+#endif
if ( data && data->set & PACKET_SET ) {
emit gpsdInfo( *data );
}
|