Skip to main content

nmea_kit/
lib.rs

1//! # nmea-kit
2//!
3//! Bidirectional NMEA 0183 parser/encoder with AIS message decoding.
4//!
5//! ## Architecture
6//!
7//! ```text
8//! raw line ──→ parse_frame() ──→ NmeaFrame { prefix, talker, sentence_type, fields }
9//!                                     │
10//!                      ┌──────────────┼──────────────┐
11//!                      ▼              ▼               ▼
12//!                $ + known      $ + unknown     ! (AIVDM/AIVDO)
13//!                      │              │               │
14//!                      ▼              ▼               ▼
15//!               Typed struct    Raw fields      AisMessage enum
16//! ```
17//!
18//! ## Public API
19//!
20//! - [`parse_frame`] / [`encode_frame`] — frame layer (always available)
21//! - [`NmeaSentence`] — dispatch enum for all typed NMEA sentences
22//! - [`NmeaEncodable`] — trait for encoding NMEA sentences to wire format
23//! - [`ais`] — AIS decoder (behind `ais` feature)
24//!
25//! ## Features
26//!
27//! - `nmea` (default) — all 30 NMEA sentence types
28//! - `ais` (default) — 16 AIS message types (read-only decode)
29//! - `ais` (default) — AIS message decoding
30//! - `dbs`, `dbt`, `dpt`, … — individual sentence types
31
32mod error;
33mod frame;
34
35#[cfg(any(
36    feature = "nmea",
37    feature = "dbk",
38    feature = "dbs",
39    feature = "dbt",
40    feature = "dpt",
41    feature = "gbs",
42    feature = "gga",
43    feature = "gll",
44    feature = "gns",
45    feature = "gst",
46    feature = "hdg",
47    feature = "hdm",
48    feature = "hdt",
49    feature = "mtw",
50    feature = "mwd",
51    feature = "mwv",
52    feature = "pashr",
53    feature = "pgrme",
54    feature = "pskpdpt",
55    feature = "rmb",
56    feature = "rmc",
57    feature = "rot",
58    feature = "rsa",
59    feature = "ths",
60    feature = "txt",
61    feature = "vbw",
62    feature = "vhw",
63    feature = "vlw",
64    feature = "vtg",
65    feature = "xdr",
66    feature = "zda",
67))]
68pub mod nmea;
69
70#[cfg(feature = "ais")]
71pub mod ais;
72
73pub use error::*;
74pub use frame::*;
75
76#[cfg(any(
77    feature = "nmea",
78    feature = "dbk",
79    feature = "dbs",
80    feature = "dbt",
81    feature = "dpt",
82    feature = "gbs",
83    feature = "gga",
84    feature = "gll",
85    feature = "gns",
86    feature = "gst",
87    feature = "hdg",
88    feature = "hdm",
89    feature = "hdt",
90    feature = "mtw",
91    feature = "mwd",
92    feature = "mwv",
93    feature = "pashr",
94    feature = "pgrme",
95    feature = "pskpdpt",
96    feature = "rmb",
97    feature = "rmc",
98    feature = "rot",
99    feature = "rsa",
100    feature = "ths",
101    feature = "txt",
102    feature = "vbw",
103    feature = "vhw",
104    feature = "vlw",
105    feature = "vtg",
106    feature = "xdr",
107    feature = "zda",
108))]
109pub use nmea::NmeaSentence;
110
111#[cfg(any(
112    feature = "nmea",
113    feature = "dbk",
114    feature = "dbs",
115    feature = "dbt",
116    feature = "dpt",
117    feature = "gbs",
118    feature = "gga",
119    feature = "gll",
120    feature = "gns",
121    feature = "gst",
122    feature = "hdg",
123    feature = "hdm",
124    feature = "hdt",
125    feature = "mtw",
126    feature = "mwd",
127    feature = "mwv",
128    feature = "pashr",
129    feature = "pgrme",
130    feature = "pskpdpt",
131    feature = "rmb",
132    feature = "rmc",
133    feature = "rot",
134    feature = "rsa",
135    feature = "ths",
136    feature = "txt",
137    feature = "vbw",
138    feature = "vhw",
139    feature = "vlw",
140    feature = "vtg",
141    feature = "xdr",
142    feature = "zda",
143))]
144pub use nmea::NmeaEncodable;