example.c 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. /*
  2. * Copyright © 2014 Kosma Moczek <kosma@cloudyourcar.com>
  3. * This program is free software. It comes without any warranty, to the extent
  4. * permitted by applicable law. You can redistribute it and/or modify it under
  5. * the terms of the Do What The Fuck You Want To Public License, Version 2, as
  6. * published by Sam Hocevar. See the COPYING file for more details.
  7. */
  8. #include <stdio.h>
  9. #include <string.h>
  10. #include <ctype.h>
  11. #include "minmea.h"
  12. #define INDENT_SPACES " "
  13. int main(void)
  14. {
  15. char line[MINMEA_MAX_SENTENCE_LENGTH];
  16. while (fgets(line, sizeof(line), stdin) != NULL) {
  17. printf("%s", line);
  18. switch (minmea_sentence_id(line, false)) {
  19. case MINMEA_SENTENCE_RMC: {
  20. struct minmea_sentence_rmc frame;
  21. if (minmea_parse_rmc(&frame, line)) {
  22. printf(INDENT_SPACES "$xxRMC: raw coordinates and speed: (%d/%d,%d/%d) %d/%d\n",
  23. frame.latitude.value, frame.latitude.scale,
  24. frame.longitude.value, frame.longitude.scale,
  25. frame.speed.value, frame.speed.scale);
  26. printf(INDENT_SPACES "$xxRMC fixed-point coordinates and speed scaled to three decimal places: (%d,%d) %d\n",
  27. minmea_rescale(&frame.latitude, 1000),
  28. minmea_rescale(&frame.longitude, 1000),
  29. minmea_rescale(&frame.speed, 1000));
  30. printf(INDENT_SPACES "$xxRMC floating point degree coordinates and speed: (%f,%f) %f\n",
  31. minmea_tocoord(&frame.latitude),
  32. minmea_tocoord(&frame.longitude),
  33. minmea_tofloat(&frame.speed));
  34. }
  35. else {
  36. printf(INDENT_SPACES "$xxRMC sentence is not parsed\n");
  37. }
  38. } break;
  39. case MINMEA_SENTENCE_GGA: {
  40. struct minmea_sentence_gga frame;
  41. if (minmea_parse_gga(&frame, line)) {
  42. printf(INDENT_SPACES "$xxGGA: fix quality: %d\n", frame.fix_quality);
  43. }
  44. else {
  45. printf(INDENT_SPACES "$xxGGA sentence is not parsed\n");
  46. }
  47. } break;
  48. case MINMEA_SENTENCE_GST: {
  49. struct minmea_sentence_gst frame;
  50. if (minmea_parse_gst(&frame, line)) {
  51. printf(INDENT_SPACES "$xxGST: raw latitude,longitude and altitude error deviation: (%d/%d,%d/%d,%d/%d)\n",
  52. frame.latitude_error_deviation.value, frame.latitude_error_deviation.scale,
  53. frame.longitude_error_deviation.value, frame.longitude_error_deviation.scale,
  54. frame.altitude_error_deviation.value, frame.altitude_error_deviation.scale);
  55. printf(INDENT_SPACES "$xxGST fixed point latitude,longitude and altitude error deviation"
  56. " scaled to one decimal place: (%d,%d,%d)\n",
  57. minmea_rescale(&frame.latitude_error_deviation, 10),
  58. minmea_rescale(&frame.longitude_error_deviation, 10),
  59. minmea_rescale(&frame.altitude_error_deviation, 10));
  60. printf(INDENT_SPACES "$xxGST floating point degree latitude, longitude and altitude error deviation: (%f,%f,%f)",
  61. minmea_tofloat(&frame.latitude_error_deviation),
  62. minmea_tofloat(&frame.longitude_error_deviation),
  63. minmea_tofloat(&frame.altitude_error_deviation));
  64. }
  65. else {
  66. printf(INDENT_SPACES "$xxGST sentence is not parsed\n");
  67. }
  68. } break;
  69. case MINMEA_SENTENCE_GSV: {
  70. struct minmea_sentence_gsv frame;
  71. if (minmea_parse_gsv(&frame, line)) {
  72. printf(INDENT_SPACES "$xxGSV: message %d of %d\n", frame.msg_nr, frame.total_msgs);
  73. printf(INDENT_SPACES "$xxGSV: satellites in view: %d\n", frame.total_sats);
  74. for (int i = 0; i < 4; i++)
  75. printf(INDENT_SPACES "$xxGSV: sat nr %d, elevation: %d, azimuth: %d, snr: %d dbm\n",
  76. frame.sats[i].nr,
  77. frame.sats[i].elevation,
  78. frame.sats[i].azimuth,
  79. frame.sats[i].snr);
  80. }
  81. else {
  82. printf(INDENT_SPACES "$xxGSV sentence is not parsed\n");
  83. }
  84. } break;
  85. case MINMEA_SENTENCE_VTG: {
  86. struct minmea_sentence_vtg frame;
  87. if (minmea_parse_vtg(&frame, line)) {
  88. printf(INDENT_SPACES "$xxVTG: true track degrees = %f\n",
  89. minmea_tofloat(&frame.true_track_degrees));
  90. printf(INDENT_SPACES " magnetic track degrees = %f\n",
  91. minmea_tofloat(&frame.magnetic_track_degrees));
  92. printf(INDENT_SPACES " speed knots = %f\n",
  93. minmea_tofloat(&frame.speed_knots));
  94. printf(INDENT_SPACES " speed kph = %f\n",
  95. minmea_tofloat(&frame.speed_kph));
  96. }
  97. else {
  98. printf(INDENT_SPACES "$xxVTG sentence is not parsed\n");
  99. }
  100. } break;
  101. case MINMEA_SENTENCE_ZDA: {
  102. struct minmea_sentence_zda frame;
  103. if (minmea_parse_zda(&frame, line)) {
  104. printf(INDENT_SPACES "$xxZDA: %d:%d:%d %02d.%02d.%d UTC%+03d:%02d\n",
  105. frame.time.hours,
  106. frame.time.minutes,
  107. frame.time.seconds,
  108. frame.date.day,
  109. frame.date.month,
  110. frame.date.year,
  111. frame.hour_offset,
  112. frame.minute_offset);
  113. }
  114. else {
  115. printf(INDENT_SPACES "$xxZDA sentence is not parsed\n");
  116. }
  117. } break;
  118. case MINMEA_INVALID: {
  119. printf(INDENT_SPACES "$xxxxx sentence is not valid\n");
  120. } break;
  121. default: {
  122. printf(INDENT_SPACES "$xxxxx sentence is not parsed\n");
  123. } break;
  124. }
  125. }
  126. return 0;
  127. }
  128. /* vim: set ts=4 sw=4 et: */