forked from GPSBabel/gpsbabel
-
Notifications
You must be signed in to change notification settings - Fork 0
/
format.h
229 lines (192 loc) · 6.04 KB
/
format.h
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
/*
Format converter module skeleton.
Steps to create a new format.
1) Copy this file to <your_format_name>.c
2) Rename all format_skeleton tokens to <your_format_name>.
3) Replace the fictional name and address in the Copyright section below.
** As your work is likely built on the work of others, please retain
the original line. **
4) Create a new section in vecs.c.
5) Add compilation instructions to Makefile.
6) Add sample files (it's better when they're created by the "real"
application and not our own output) to reference/ along with
files in a well supported (preferably non-binary) format and
entries in our 'testo' program. This allows users of different
OSes and hardware to exercise your module.
Copyright (C) YYYY John Doe, [email protected]
Copyright (C) 2001-YYYY Robert Lipe, [email protected]
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
#ifndef FORMAT_H_INCLUDED_
#define FORMAT_H_INCLUDED_
#include "defs.h"
class Format
{
public:
Format() = default;
// Provide virtual public destructor to avoid undefined behavior when
// an object of derived class type is deleted through a pointer to
// its base class type.
// https://wiki.sei.cmu.edu/confluence/display/cplusplus/OOP52-CPP.+Do+not+delete+a+polymorphic+object+without+a+virtual+destructor
virtual ~Format() = default;
// And that requires us to explicitly default or delete the move and copy operations.
// To prevent slicing we delete them.
// https://github.com/isocpp/CppCoreGuidelines/blob/master/CppCoreGuidelines.md#c21-if-you-define-or-delete-any-default-operation-define-or-delete-them-all.
Format(const Format&) = delete;
Format& operator=(const Format&) = delete;
Format(Format&&) = delete;
Format& operator=(Format&&) = delete;
/*******************************************************************************
* %%% global callbacks called by gpsbabel main process %%% *
*******************************************************************************/
virtual void rd_init(const QString& /* fname */)
{
fatal("Format does not support reading.\n");
// fin = gbfopen(fname, "r", MYNAME);
}
virtual void rd_deinit()
{
// gbfclose(fin);
}
virtual void read()
{
// your special code to extract waypoint, route and track
// information from gbfile "fin"
//
// Sample text-file read code:
// char *s;
// while ((s = gbfgetstr(fin))) {
// do_anything(s);
// }
//
//
// For waypoints:
// while (have waypoints) {
// waypoint = new waypoint
// populate waypoint
// waypt_add(waypoint);
// }
//
// For routes:
//
// route = route_head_alloc();
// populate struct route_hdr
// route_add_head(route);
// while (have more routepoints) {
// waypoint = new waypoint
// populate waypoint
// route_add_wpt(route, waypoint)
// }
//
// Tracks are just like routes, except the word "track" replaces "routes".
//
}
virtual void wr_init(const QString& /* fname */)
{
fatal("Format does not support writing.\n");
// fout = gbfopen(fname, "w", MYNAME);
}
virtual void wr_deinit()
{
// gbfclose(fout);
}
virtual void write()
{
// Here is how you register callbacks for all waypoints, routes, tracks.
// waypt_disp_all(waypt)
// route_disp_all(head, tail, rtept);
// track_disp_all(head, tail, trkpt);
}
virtual void exit() /* optional */
{
}
virtual void rd_position_init(const QString& /* fname */)
{
fatal("Realtime tracking (-T) is not supported by this input type.\n");
}
virtual Waypoint* rd_position(posn_status* /* status */)
{
return nullptr;
}
virtual void rd_position_deinit()
{
}
virtual void wr_position_init(const QString& /* fname */)
{
}
virtual void wr_position(Waypoint* /* wpt */)
{
fatal("This output format does not support output of realtime positioning.\n");
}
virtual void wr_position_deinit()
{
}
/*******************************************************************************
* %%% Accessors %%% *
*******************************************************************************/
virtual QVector<arglist_t>* get_args()
{
return nullptr;
}
virtual ff_type get_type() const = 0;
virtual QVector<ff_cap> get_cap() const = 0;
QString get_name() const
{
return name;
}
void set_name(const QString& nm)
{
name = nm;
}
QString get_argstring() const
{
return argstring;
}
void set_argstring(const QString& string)
{
argstring = string;
}
private:
QString name;
QString argstring;
protected:
template <class MyFormat>
class RteHdFunctor
{
public:
using RteHdCb = void (MyFormat::*)(const route_head*);
RteHdFunctor(MyFormat* obj, RteHdCb cb) : that(obj), _cb(cb) {}
void operator()(const route_head* rh)
{
((that)->*(_cb))(rh);
}
private:
MyFormat* that;
RteHdCb _cb;
};
template <class MyFormat>
class WayptFunctor
{
public:
using WayptCb = void (MyFormat::*)(const Waypoint*);
WayptFunctor(MyFormat* obj, WayptCb cb) : that(obj), _cb(cb) {}
void operator()(const Waypoint* wpt)
{
((that)->*(_cb))(wpt);
}
private:
MyFormat* that;
WayptCb _cb;
};
};
#endif // FORMAT_H_INCLUDED_