PUD: import nmealib v0.6.9
[olsrd.git] / lib / pud / nmealib / samples / generator / main.c
1 /*
2  * This file is part of nmealib.
3  *
4  * Copyright (c) 2008 Timur Sinitsyn
5  * Copyright (c) 2011 Ferry Huberts
6  *
7  * This library is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Lesser General Public
9  * License as published by the Free Software Foundation; either
10  * version 2.1 of the License, or (at your option) any later version.
11  *
12  * This library is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15  * Lesser General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program. If not, see <http://www.gnu.org/licenses/>.
19  */
20
21 #include <nmea/nmea.h>
22
23 #include <stdio.h>
24 #include <unistd.h>
25
26 int main(int argc __attribute__((unused)), char *argv[] __attribute__((unused))) {
27     nmeaGENERATOR *gen;
28     nmeaINFO info;
29     char buff[2048];
30     int gen_sz;
31     int it;
32
33     nmea_zero_INFO(&info);
34
35     if(0 == (gen = nmea_create_generator(NMEA_GEN_ROTATE, &info)))
36         return -1;
37
38     for(it = 0; it < 10000; ++it)
39     {
40         gen_sz = nmea_generate_from(
41             &buff[0], 2048, &info, gen,
42             GPGGA | GPGSA | GPGSV | GPRMC | GPVTG
43             );
44
45         buff[gen_sz] = 0;
46         printf("%s\n", &buff[0]);
47
48         usleep(500000);        
49     }
50
51     nmea_gen_destroy(gen);
52
53     return 0;
54 }