f95cf1e9403efe9f2f79ecdebb94eac2794c1cc9
[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()
27 {
28     nmeaGENERATOR *gen;
29     nmeaINFO info;
30     char buff[2048];
31     int gen_sz;
32     int it;
33
34     nmea_zero_INFO(&info);
35
36     if(0 == (gen = nmea_create_generator(NMEA_GEN_ROTATE, &info)))
37         return -1;
38
39     for(it = 0; it < 10000; ++it)
40     {
41         gen_sz = nmea_generate_from(
42             &buff[0], 2048, &info, gen,
43             GPGGA | GPGSA | GPGSV | GPRMC | GPVTG
44             );
45
46         buff[gen_sz] = 0;
47         printf("%s\n", &buff[0]);
48
49         usleep(500000);        
50     }
51
52     nmea_gen_destroy(gen);
53
54     return 0;
55 }