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
/*
 * Copyright (C) 2018 Kubos Corporation
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

//! Kubos API for interacting with [Adcole Maryland Aerospace MAI-400 ADACS](https://www.cubesatshop.com/product/mai-400-adacs/)
//!
//! All work is done against an instantiated [`MAI400`] struct.
//!
//! # Examples
//!
//! ```
//! use mai400_api::*;
//!
//! # fn func() -> MAIResult<()> {
//! // Create a new MAI connection
//! let mai = MAI400::new("/dev/ttyS5")?;
//!
//! // Set the GPS time to Jan 01, 2018
//! mai.set_gps_time(1198800018)?;
//!
//! // Pull the updated time out of the next standard telemetry message
//! let (std, _imu, _irehs) = mai.get_message()?;
//!
//! if let Some(telem) = std {
//!     println!("Current GPS time: {}", telem.gps_time);
//! }
//! # Ok(())
//! # }
//! ```
//!
//! [`MAI400`]: struct.MAI400.html

#![deny(missing_docs)]
//Need a higher recursion limit for nom when parsing larger (>60 bytes) structures
#![recursion_limit = "256"]

mod mai400;
mod messages;
#[cfg(test)]
mod tests;

pub use crate::mai400::*;
pub use crate::messages::rx::*;
pub use rust_uart::{mock, Connection, UartError};