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

Last change on this file since 5485 was 5485, checked in by mervart, 11 years ago
File size: 4.2 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 char ch;
87 switch(sat.constellation) {
88 case (ConstellationType::GPS): ch = 'G'; break;
89 case (ConstellationType::GLONASS): ch = 'R'; break;
90 case (ConstellationType::SBAS): ch = 'S'; break;
91 case (ConstellationType::GALILEO): ch = 'E'; break;
92 case (ConstellationType::QZSS): ch = 'J'; break;
93 case (ConstellationType::COMPASS): ch = 'C'; break;
94 }
95 char prn[3];
96 sprintf(prn, "%c%2.2d", ch, sat.ID);
97 satellite->_prn = prn;
98 satellite->_x = sat.xyz.x;
99 satellite->_y = sat.xyz.y;
100 satellite->_z = sat.xyz.z;
101 cout << satellite->_prn << ' ' << satellite->_x << endl;
102 }
103}
104
105// Handle Station Info
106//////////////////////////////////////////////////////////////////////////////
107void t_thriftHandler::
108handleStationInfo(const vector<StationInfo>& stationList) {
109 for (unsigned ii = 0; ii < stationList.size(); ii++) {
110 const StationInfo& staInfo = stationList[ii];
111 _stationCrd[staInfo.ID]._x = staInfo.xyz.x;
112 _stationCrd[staInfo.ID]._y = staInfo.xyz.y;
113 _stationCrd[staInfo.ID]._z = staInfo.xyz.z;
114 }
115}
116
117// Handle Epoch Results
118//////////////////////////////////////////////////////////////////////////////
119void t_thriftHandler::
120handleEpochResults(const RtnetEpoch& epoch) {
121 vector<t_thriftResult*>* results = new vector<t_thriftResult*>;
122 for (unsigned ii = 0; ii < epoch.stationResultList.size(); ii++) {
123 const StationResults& staRes = epoch.stationResultList[ii];
124 t_thriftResult* res = new t_thriftResult;
125 res->_name = staRes.stationName;
126 res->_nGPS = staRes.nsv_gps_used;
127 res->_nGLO = staRes.nsv_glonass_used;
128 if (_stationCrd.find(staRes.stationName) != _stationCrd.end()) {
129 res->_x = _stationCrd[staRes.stationName]._x;
130 res->_y = _stationCrd[staRes.stationName]._y;
131 res->_z = _stationCrd[staRes.stationName]._z;
132 }
133 results->push_back(res);
134 }
135 _parent->putThriftResults(results);
136}
Note: See TracBrowser for help on using the repository browser.