source: ntrip/trunk/GnssCenter/monitor/thriftclient.cpp@ 5483

Last change on this file since 5483 was 5483, checked in by mervart, 11 years ago
File size: 4.1 KB
Line 
1
2#include <iostream>
3#include <iomanip>
4#include <sstream>
5#include <vector>
6
7#include "thriftclient.h"
8#include "monitor.h"
9
10using namespace apache::thrift;
11using namespace apache::thrift::protocol;
12using namespace apache::thrift::transport;
13
14using namespace com::gpssolutions::rtnet;
15using namespace std;
16using namespace boost;
17
18using namespace GnssCenter;
19
20// Constructor
21//////////////////////////////////////////////////////////////////////////////
22t_thriftClient::t_thriftClient(t_monitor* parent, const QString& host, int port) {
23 _stop = false;
24 _parent = parent;
25 _host = host.toAscii().data();
26 _port = port;
27}
28
29// Destructor
30//////////////////////////////////////////////////////////////////////////////
31t_thriftClient::~t_thriftClient() {
32}
33
34// Run (virtual)
35//////////////////////////////////////////////////////////////////////////////
36void t_thriftClient::run() {
37
38 shared_ptr<TSocket> socket(new TSocket(_host, _port));
39 shared_ptr<TTransport> transport(new TBufferedTransport(socket));
40 shared_ptr<TProtocol> protocol(new TBinaryProtocol(transport));
41 shared_ptr<RtnetDataIf> dataHandler(new t_thriftHandler(_parent));
42 shared_ptr<TProcessor> processor(new RtnetDataProcessor(dataHandler));
43
44 try {
45 transport->open();
46 while (true) {
47 {
48 QMutexLocker locker(&_mutex);
49 if (_stop) {
50 break;
51 }
52 }
53 if (processor->process(protocol,protocol,0) == 0) {
54 break;
55 }
56 }
57 transport->close();
58 }
59 catch (TException& e) {
60 emit message(e.what());
61 }
62 catch (...) {
63 emit message("Unknown exception");
64 }
65}
66
67// Constructor
68//////////////////////////////////////////////////////////////////////////////
69t_thriftHandler::t_thriftHandler(t_monitor* parent) {
70 _parent = parent;
71}
72
73// Destructor
74//////////////////////////////////////////////////////////////////////////////
75t_thriftHandler::~t_thriftHandler() {
76}
77
78// Handle Satellite Positions
79//////////////////////////////////////////////////////////////////////////////
80void t_thriftHandler::
81handleSatelliteXYZ(const vector<SatelliteXYZ>& svXYZList) {
82 vector<t_thriftSatellite*>* satellites = new vector<t_thriftSatellite*>;
83 for (unsigned ii = 0; ii < svXYZList.size(); ii++) {
84 const SatelliteXYZ& sat = svXYZList[ii];
85 t_thriftSatellite* satellite = new t_thriftSatellite;
86 satellite->_x = sat.xyz.x;
87 satellite->_y = sat.xyz.y;
88 satellite->_z = sat.xyz.z;
89 char ch;
90 switch(sat.constellation) {
91 case (ConstellationType::GPS): ch = 'G'; break;
92 case (ConstellationType::GLONASS): ch = 'R'; break;
93 case (ConstellationType::SBAS): ch = 'S'; break;
94 case (ConstellationType::GALILEO): ch = 'E'; break;
95 case (ConstellationType::QZSS): ch = 'J'; break;
96 case (ConstellationType::COMPASS): ch = 'C'; break;
97 }
98 cout << unsigned(sat.ID) << endl;
99 }
100}
101
102// Handle Station Info
103//////////////////////////////////////////////////////////////////////////////
104void t_thriftHandler::
105handleStationInfo(const vector<StationInfo>& stationList) {
106 for (unsigned ii = 0; ii < stationList.size(); ii++) {
107 const StationInfo& staInfo = stationList[ii];
108 _stationCrd[staInfo.ID]._x = staInfo.xyz.x;
109 _stationCrd[staInfo.ID]._y = staInfo.xyz.y;
110 _stationCrd[staInfo.ID]._z = staInfo.xyz.z;
111 }
112}
113
114// Handle Epoch Results
115//////////////////////////////////////////////////////////////////////////////
116void t_thriftHandler::
117handleEpochResults(const RtnetEpoch& epoch) {
118 vector<t_thriftResult*>* results = new vector<t_thriftResult*>;
119 for (unsigned ii = 0; ii < epoch.stationResultList.size(); ii++) {
120 const StationResults& staRes = epoch.stationResultList[ii];
121 t_thriftResult* res = new t_thriftResult;
122 res->_name = staRes.stationName;
123 res->_nGPS = staRes.nsv_gps_used;
124 res->_nGLO = staRes.nsv_glonass_used;
125 if (_stationCrd.find(staRes.stationName) != _stationCrd.end()) {
126 res->_x = _stationCrd[staRes.stationName]._x;
127 res->_y = _stationCrd[staRes.stationName]._y;
128 res->_z = _stationCrd[staRes.stationName]._z;
129 }
130 results->push_back(res);
131 }
132 _parent->putThriftResults(results);
133}
Note: See TracBrowser for help on using the repository browser.