Compare commits
11 Commits
v0.7.0-bet
...
v0.8.0
Author | SHA1 | Date | |
---|---|---|---|
c3cc6d5c73 | |||
d01309cccf
|
|||
92403738ca | |||
3353475261
|
|||
84c1c47fe1
|
|||
c4bbf91be8
|
|||
7200e10250
|
|||
66ae83c0ce | |||
2439c9e5fd | |||
e992aad52c | |||
77135af2bc |
15
CHANGELOG.md
15
CHANGELOG.md
@ -8,6 +8,21 @@ and this project adheres to [Semantic Versioning](http://semver.org/).
|
|||||||
|
|
||||||
# [unreleased]
|
# [unreleased]
|
||||||
|
|
||||||
|
# [v0.8.0] 2024-02-05
|
||||||
|
|
||||||
|
## Added
|
||||||
|
|
||||||
|
- Added `len_written` and `to_vec` methods to the `TimeWriter` trait.
|
||||||
|
|
||||||
|
# [v0.7.0] 2024-02-01
|
||||||
|
|
||||||
|
# [v0.7.0-beta.4] 2024-01-23
|
||||||
|
|
||||||
|
## Fixed
|
||||||
|
|
||||||
|
- `MetadataPduCreator`: The serialization function shifted the closure requested information
|
||||||
|
to the wrong position (first reserved bit) inside the raw content field.
|
||||||
|
|
||||||
# [v0.7.0-beta.3] 2023-12-06
|
# [v0.7.0-beta.3] 2023-12-06
|
||||||
|
|
||||||
## Added
|
## Added
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
[package]
|
[package]
|
||||||
name = "spacepackets"
|
name = "spacepackets"
|
||||||
version = "0.7.0-beta.3"
|
version = "0.8.0"
|
||||||
edition = "2021"
|
edition = "2021"
|
||||||
rust-version = "1.61"
|
rust-version = "1.61"
|
||||||
authors = ["Robin Mueller <muellerr@irs.uni-stuttgart.de>"]
|
authors = ["Robin Mueller <muellerr@irs.uni-stuttgart.de>"]
|
||||||
@ -53,4 +53,4 @@ alloc = ["postcard/alloc", "chrono/alloc"]
|
|||||||
|
|
||||||
[package.metadata.docs.rs]
|
[package.metadata.docs.rs]
|
||||||
all-features = true
|
all-features = true
|
||||||
rustdoc-args = ["--cfg", "doc_cfg"]
|
rustdoc-args = ["--cfg", "doc_cfg", "--generate-link-to-definition"]
|
||||||
|
@ -175,7 +175,7 @@ impl WritablePduPacket for MetadataPduCreator<'_, '_, '_> {
|
|||||||
let mut current_idx = self.pdu_header.write_to_bytes(buf)?;
|
let mut current_idx = self.pdu_header.write_to_bytes(buf)?;
|
||||||
buf[current_idx] = FileDirectiveType::MetadataPdu as u8;
|
buf[current_idx] = FileDirectiveType::MetadataPdu as u8;
|
||||||
current_idx += 1;
|
current_idx += 1;
|
||||||
buf[current_idx] = ((self.metadata_params.closure_requested as u8) << 7)
|
buf[current_idx] = ((self.metadata_params.closure_requested as u8) << 6)
|
||||||
| (self.metadata_params.checksum_type as u8);
|
| (self.metadata_params.checksum_type as u8);
|
||||||
current_idx += 1;
|
current_idx += 1;
|
||||||
current_idx += write_fss_field(
|
current_idx += write_fss_field(
|
||||||
@ -364,6 +364,8 @@ pub mod tests {
|
|||||||
|
|
||||||
fn generic_metadata_pdu<'opts>(
|
fn generic_metadata_pdu<'opts>(
|
||||||
crc_flag: CrcFlag,
|
crc_flag: CrcFlag,
|
||||||
|
checksum_type: ChecksumType,
|
||||||
|
closure_requested: bool,
|
||||||
fss: LargeFileFlag,
|
fss: LargeFileFlag,
|
||||||
opts: &'opts [Tlv],
|
opts: &'opts [Tlv],
|
||||||
) -> (
|
) -> (
|
||||||
@ -372,7 +374,7 @@ pub mod tests {
|
|||||||
MetadataPduCreator<'static, 'static, 'opts>,
|
MetadataPduCreator<'static, 'static, 'opts>,
|
||||||
) {
|
) {
|
||||||
let pdu_header = PduHeader::new_no_file_data(common_pdu_conf(crc_flag, fss), 0);
|
let pdu_header = PduHeader::new_no_file_data(common_pdu_conf(crc_flag, fss), 0);
|
||||||
let metadata_params = MetadataGenericParams::new(false, ChecksumType::Crc32, 0x1010);
|
let metadata_params = MetadataGenericParams::new(closure_requested, checksum_type, 0x1010);
|
||||||
let src_filename = Lv::new_from_str(SRC_FILENAME).expect("Generating string LV failed");
|
let src_filename = Lv::new_from_str(SRC_FILENAME).expect("Generating string LV failed");
|
||||||
let dest_filename =
|
let dest_filename =
|
||||||
Lv::new_from_str(DEST_FILENAME).expect("Generating destination LV failed");
|
Lv::new_from_str(DEST_FILENAME).expect("Generating destination LV failed");
|
||||||
@ -391,8 +393,13 @@ pub mod tests {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_basic() {
|
fn test_basic() {
|
||||||
let (src_filename, dest_filename, metadata_pdu) =
|
let (src_filename, dest_filename, metadata_pdu) = generic_metadata_pdu(
|
||||||
generic_metadata_pdu(CrcFlag::NoCrc, LargeFileFlag::Normal, &[]);
|
CrcFlag::NoCrc,
|
||||||
|
ChecksumType::Crc32,
|
||||||
|
false,
|
||||||
|
LargeFileFlag::Normal,
|
||||||
|
&[],
|
||||||
|
);
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
metadata_pdu.len_written(),
|
metadata_pdu.len_written(),
|
||||||
metadata_pdu.pdu_header().header_len()
|
metadata_pdu.pdu_header().header_len()
|
||||||
@ -408,6 +415,11 @@ pub mod tests {
|
|||||||
assert_eq!(metadata_pdu.crc_flag(), CrcFlag::NoCrc);
|
assert_eq!(metadata_pdu.crc_flag(), CrcFlag::NoCrc);
|
||||||
assert_eq!(metadata_pdu.file_flag(), LargeFileFlag::Normal);
|
assert_eq!(metadata_pdu.file_flag(), LargeFileFlag::Normal);
|
||||||
assert_eq!(metadata_pdu.pdu_type(), PduType::FileDirective);
|
assert_eq!(metadata_pdu.pdu_type(), PduType::FileDirective);
|
||||||
|
assert!(!metadata_pdu.metadata_params().closure_requested);
|
||||||
|
assert_eq!(
|
||||||
|
metadata_pdu.metadata_params().checksum_type,
|
||||||
|
ChecksumType::Crc32
|
||||||
|
);
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
metadata_pdu.file_directive_type(),
|
metadata_pdu.file_directive_type(),
|
||||||
Some(FileDirectiveType::MetadataPdu)
|
Some(FileDirectiveType::MetadataPdu)
|
||||||
@ -422,44 +434,103 @@ pub mod tests {
|
|||||||
assert_eq!(metadata_pdu.transaction_seq_num(), TEST_SEQ_NUM.into());
|
assert_eq!(metadata_pdu.transaction_seq_num(), TEST_SEQ_NUM.into());
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
fn check_metadata_raw_fields(
|
||||||
fn test_serialization() {
|
metadata_pdu: &MetadataPduCreator,
|
||||||
let (src_filename, dest_filename, metadata_pdu) =
|
buf: &[u8],
|
||||||
generic_metadata_pdu(CrcFlag::NoCrc, LargeFileFlag::Normal, &[]);
|
written_bytes: usize,
|
||||||
let mut buf: [u8; 64] = [0; 64];
|
checksum_type: ChecksumType,
|
||||||
let res = metadata_pdu.write_to_bytes(&mut buf);
|
closure_requested: bool,
|
||||||
assert!(res.is_ok());
|
expected_src_filename: &Lv,
|
||||||
let written = res.unwrap();
|
expected_dest_filename: &Lv,
|
||||||
|
) {
|
||||||
|
verify_raw_header(metadata_pdu.pdu_header(), buf);
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
written,
|
written_bytes,
|
||||||
metadata_pdu.pdu_header.header_len()
|
metadata_pdu.pdu_header.header_len()
|
||||||
+ 1
|
+ 1
|
||||||
+ 1
|
+ 1
|
||||||
+ 4
|
+ 4
|
||||||
+ src_filename.len_full()
|
+ expected_src_filename.len_full()
|
||||||
+ dest_filename.len_full()
|
+ expected_dest_filename.len_full()
|
||||||
);
|
);
|
||||||
verify_raw_header(metadata_pdu.pdu_header(), &buf);
|
|
||||||
assert_eq!(buf[7], FileDirectiveType::MetadataPdu as u8);
|
assert_eq!(buf[7], FileDirectiveType::MetadataPdu as u8);
|
||||||
assert_eq!(buf[8] >> 6, false as u8);
|
assert_eq!(buf[8] >> 6, closure_requested as u8);
|
||||||
assert_eq!(buf[8] & 0b1111, ChecksumType::Crc32 as u8);
|
assert_eq!(buf[8] & 0b1111, checksum_type as u8);
|
||||||
assert_eq!(u32::from_be_bytes(buf[9..13].try_into().unwrap()), 0x1010);
|
assert_eq!(u32::from_be_bytes(buf[9..13].try_into().unwrap()), 0x1010);
|
||||||
let mut current_idx = 13;
|
let mut current_idx = 13;
|
||||||
let src_name_from_raw =
|
let src_name_from_raw =
|
||||||
Lv::from_bytes(&buf[current_idx..]).expect("Creating source name LV failed");
|
Lv::from_bytes(&buf[current_idx..]).expect("Creating source name LV failed");
|
||||||
assert_eq!(src_name_from_raw, src_filename);
|
assert_eq!(src_name_from_raw, *expected_src_filename);
|
||||||
current_idx += src_name_from_raw.len_full();
|
current_idx += src_name_from_raw.len_full();
|
||||||
let dest_name_from_raw =
|
let dest_name_from_raw =
|
||||||
Lv::from_bytes(&buf[current_idx..]).expect("Creating dest name LV failed");
|
Lv::from_bytes(&buf[current_idx..]).expect("Creating dest name LV failed");
|
||||||
assert_eq!(dest_name_from_raw, dest_filename);
|
assert_eq!(dest_name_from_raw, *expected_dest_filename);
|
||||||
current_idx += dest_name_from_raw.len_full();
|
current_idx += dest_name_from_raw.len_full();
|
||||||
// No options, so no additional data here.
|
// No options, so no additional data here.
|
||||||
assert_eq!(current_idx, written);
|
assert_eq!(current_idx, written_bytes);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_serialization_0() {
|
||||||
|
let checksum_type = ChecksumType::Crc32;
|
||||||
|
let closure_requested = false;
|
||||||
|
let (src_filename, dest_filename, metadata_pdu) = generic_metadata_pdu(
|
||||||
|
CrcFlag::NoCrc,
|
||||||
|
checksum_type,
|
||||||
|
closure_requested,
|
||||||
|
LargeFileFlag::Normal,
|
||||||
|
&[],
|
||||||
|
);
|
||||||
|
let mut buf: [u8; 64] = [0; 64];
|
||||||
|
let res = metadata_pdu.write_to_bytes(&mut buf);
|
||||||
|
assert!(res.is_ok());
|
||||||
|
let written = res.unwrap();
|
||||||
|
check_metadata_raw_fields(
|
||||||
|
&metadata_pdu,
|
||||||
|
&buf,
|
||||||
|
written,
|
||||||
|
checksum_type,
|
||||||
|
closure_requested,
|
||||||
|
&src_filename,
|
||||||
|
&dest_filename,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_serialization_1() {
|
||||||
|
let checksum_type = ChecksumType::Modular;
|
||||||
|
let closure_requested = true;
|
||||||
|
let (src_filename, dest_filename, metadata_pdu) = generic_metadata_pdu(
|
||||||
|
CrcFlag::NoCrc,
|
||||||
|
checksum_type,
|
||||||
|
closure_requested,
|
||||||
|
LargeFileFlag::Normal,
|
||||||
|
&[],
|
||||||
|
);
|
||||||
|
let mut buf: [u8; 64] = [0; 64];
|
||||||
|
let res = metadata_pdu.write_to_bytes(&mut buf);
|
||||||
|
assert!(res.is_ok());
|
||||||
|
let written = res.unwrap();
|
||||||
|
check_metadata_raw_fields(
|
||||||
|
&metadata_pdu,
|
||||||
|
&buf,
|
||||||
|
written,
|
||||||
|
checksum_type,
|
||||||
|
closure_requested,
|
||||||
|
&src_filename,
|
||||||
|
&dest_filename,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_write_to_vec() {
|
fn test_write_to_vec() {
|
||||||
let (_, _, metadata_pdu) = generic_metadata_pdu(CrcFlag::NoCrc, LargeFileFlag::Normal, &[]);
|
let (_, _, metadata_pdu) = generic_metadata_pdu(
|
||||||
|
CrcFlag::NoCrc,
|
||||||
|
ChecksumType::Crc32,
|
||||||
|
false,
|
||||||
|
LargeFileFlag::Normal,
|
||||||
|
&[],
|
||||||
|
);
|
||||||
let mut buf: [u8; 64] = [0; 64];
|
let mut buf: [u8; 64] = [0; 64];
|
||||||
let pdu_vec = metadata_pdu.to_vec().unwrap();
|
let pdu_vec = metadata_pdu.to_vec().unwrap();
|
||||||
let written = metadata_pdu.write_to_bytes(&mut buf).unwrap();
|
let written = metadata_pdu.write_to_bytes(&mut buf).unwrap();
|
||||||
@ -478,7 +549,13 @@ pub mod tests {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_deserialization() {
|
fn test_deserialization() {
|
||||||
let (_, _, metadata_pdu) = generic_metadata_pdu(CrcFlag::NoCrc, LargeFileFlag::Normal, &[]);
|
let (_, _, metadata_pdu) = generic_metadata_pdu(
|
||||||
|
CrcFlag::NoCrc,
|
||||||
|
ChecksumType::Crc32,
|
||||||
|
true,
|
||||||
|
LargeFileFlag::Normal,
|
||||||
|
&[],
|
||||||
|
);
|
||||||
let mut buf: [u8; 64] = [0; 64];
|
let mut buf: [u8; 64] = [0; 64];
|
||||||
metadata_pdu.write_to_bytes(&mut buf).unwrap();
|
metadata_pdu.write_to_bytes(&mut buf).unwrap();
|
||||||
let pdu_read_back = MetadataPduReader::from_bytes(&buf);
|
let pdu_read_back = MetadataPduReader::from_bytes(&buf);
|
||||||
@ -489,8 +566,13 @@ pub mod tests {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_with_crc_flag() {
|
fn test_with_crc_flag() {
|
||||||
let (src_filename, dest_filename, metadata_pdu) =
|
let (src_filename, dest_filename, metadata_pdu) = generic_metadata_pdu(
|
||||||
generic_metadata_pdu(CrcFlag::WithCrc, LargeFileFlag::Normal, &[]);
|
CrcFlag::WithCrc,
|
||||||
|
ChecksumType::Crc32,
|
||||||
|
true,
|
||||||
|
LargeFileFlag::Normal,
|
||||||
|
&[],
|
||||||
|
);
|
||||||
assert_eq!(metadata_pdu.crc_flag(), CrcFlag::WithCrc);
|
assert_eq!(metadata_pdu.crc_flag(), CrcFlag::WithCrc);
|
||||||
let mut buf: [u8; 64] = [0; 64];
|
let mut buf: [u8; 64] = [0; 64];
|
||||||
let write_res = metadata_pdu.write_to_bytes(&mut buf);
|
let write_res = metadata_pdu.write_to_bytes(&mut buf);
|
||||||
@ -513,8 +595,13 @@ pub mod tests {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_with_large_file_flag() {
|
fn test_with_large_file_flag() {
|
||||||
let (src_filename, dest_filename, metadata_pdu) =
|
let (src_filename, dest_filename, metadata_pdu) = generic_metadata_pdu(
|
||||||
generic_metadata_pdu(CrcFlag::NoCrc, LargeFileFlag::Large, &[]);
|
CrcFlag::NoCrc,
|
||||||
|
ChecksumType::Crc32,
|
||||||
|
false,
|
||||||
|
LargeFileFlag::Large,
|
||||||
|
&[],
|
||||||
|
);
|
||||||
let mut buf: [u8; 64] = [0; 64];
|
let mut buf: [u8; 64] = [0; 64];
|
||||||
let write_res = metadata_pdu.write_to_bytes(&mut buf);
|
let write_res = metadata_pdu.write_to_bytes(&mut buf);
|
||||||
assert!(write_res.is_ok());
|
assert!(write_res.is_ok());
|
||||||
@ -573,8 +660,13 @@ pub mod tests {
|
|||||||
let tlv2 = Tlv::new(TlvType::MsgToUser, &msg_to_user).unwrap();
|
let tlv2 = Tlv::new(TlvType::MsgToUser, &msg_to_user).unwrap();
|
||||||
let tlv_vec = vec![tlv1, tlv2];
|
let tlv_vec = vec![tlv1, tlv2];
|
||||||
let opts_len = tlv1.len_full() + tlv2.len_full();
|
let opts_len = tlv1.len_full() + tlv2.len_full();
|
||||||
let (src_filename, dest_filename, metadata_pdu) =
|
let (src_filename, dest_filename, metadata_pdu) = generic_metadata_pdu(
|
||||||
generic_metadata_pdu(CrcFlag::NoCrc, LargeFileFlag::Normal, &tlv_vec);
|
CrcFlag::NoCrc,
|
||||||
|
ChecksumType::Crc32,
|
||||||
|
false,
|
||||||
|
LargeFileFlag::Normal,
|
||||||
|
&tlv_vec,
|
||||||
|
);
|
||||||
let mut buf: [u8; 128] = [0; 128];
|
let mut buf: [u8; 128] = [0; 128];
|
||||||
let write_res = metadata_pdu.write_to_bytes(&mut buf);
|
let write_res = metadata_pdu.write_to_bytes(&mut buf);
|
||||||
assert!(write_res.is_ok());
|
assert!(write_res.is_ok());
|
||||||
@ -604,7 +696,13 @@ pub mod tests {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_invalid_directive_code() {
|
fn test_invalid_directive_code() {
|
||||||
let (_, _, metadata_pdu) = generic_metadata_pdu(CrcFlag::NoCrc, LargeFileFlag::Large, &[]);
|
let (_, _, metadata_pdu) = generic_metadata_pdu(
|
||||||
|
CrcFlag::NoCrc,
|
||||||
|
ChecksumType::Crc32,
|
||||||
|
true,
|
||||||
|
LargeFileFlag::Large,
|
||||||
|
&[],
|
||||||
|
);
|
||||||
let mut metadata_vec = metadata_pdu.to_vec().unwrap();
|
let mut metadata_vec = metadata_pdu.to_vec().unwrap();
|
||||||
metadata_vec[7] = 0xff;
|
metadata_vec[7] = 0xff;
|
||||||
let metadata_error = MetadataPduReader::from_bytes(&metadata_vec);
|
let metadata_error = MetadataPduReader::from_bytes(&metadata_vec);
|
||||||
@ -624,7 +722,13 @@ pub mod tests {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_wrong_directive_code() {
|
fn test_wrong_directive_code() {
|
||||||
let (_, _, metadata_pdu) = generic_metadata_pdu(CrcFlag::NoCrc, LargeFileFlag::Large, &[]);
|
let (_, _, metadata_pdu) = generic_metadata_pdu(
|
||||||
|
CrcFlag::NoCrc,
|
||||||
|
ChecksumType::Crc32,
|
||||||
|
false,
|
||||||
|
LargeFileFlag::Large,
|
||||||
|
&[],
|
||||||
|
);
|
||||||
let mut metadata_vec = metadata_pdu.to_vec().unwrap();
|
let mut metadata_vec = metadata_pdu.to_vec().unwrap();
|
||||||
metadata_vec[7] = FileDirectiveType::EofPdu as u8;
|
metadata_vec[7] = FileDirectiveType::EofPdu as u8;
|
||||||
let metadata_error = MetadataPduReader::from_bytes(&metadata_vec);
|
let metadata_error = MetadataPduReader::from_bytes(&metadata_vec);
|
||||||
|
@ -1201,6 +1201,10 @@ impl TimeWriter for TimeProvider<DaysLen16Bits> {
|
|||||||
}
|
}
|
||||||
Ok(self.len_as_bytes())
|
Ok(self.len_as_bytes())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn len_written(&self) -> usize {
|
||||||
|
self.len_as_bytes()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl TimeWriter for TimeProvider<DaysLen24Bits> {
|
impl TimeWriter for TimeProvider<DaysLen24Bits> {
|
||||||
@ -1221,6 +1225,10 @@ impl TimeWriter for TimeProvider<DaysLen24Bits> {
|
|||||||
}
|
}
|
||||||
Ok(self.len_as_bytes())
|
Ok(self.len_as_bytes())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn len_written(&self) -> usize {
|
||||||
|
self.len_as_bytes()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<DaysLenProvider: ProvidesDaysLength> PartialEq for TimeProvider<DaysLenProvider> {
|
impl<DaysLenProvider: ProvidesDaysLength> PartialEq for TimeProvider<DaysLenProvider> {
|
||||||
@ -2270,4 +2278,22 @@ mod tests {
|
|||||||
assert_eq!(first, second);
|
assert_eq!(first, second);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_stamp_to_vec_u16() {
|
||||||
|
let stamp = TimeProvider::new_with_u16_days(1, 1);
|
||||||
|
let stamp_vec = stamp.to_vec().unwrap();
|
||||||
|
let mut buf: [u8; 7] = [0; 7];
|
||||||
|
stamp.write_to_bytes(&mut buf).unwrap();
|
||||||
|
assert_eq!(stamp_vec, buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_stamp_to_vec_u24() {
|
||||||
|
let stamp = TimeProvider::new_with_u24_days(1, 1).unwrap();
|
||||||
|
let stamp_vec = stamp.to_vec().unwrap();
|
||||||
|
let mut buf: [u8; 10] = [0; 10];
|
||||||
|
stamp.write_to_bytes(&mut buf).unwrap();
|
||||||
|
assert_eq!(stamp_vec, buf[..stamp.len_written()]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -587,6 +587,10 @@ impl TimeWriter for TimeProviderCcsdsEpoch {
|
|||||||
}
|
}
|
||||||
Ok(current_idx)
|
Ok(current_idx)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn len_written(&self) -> usize {
|
||||||
|
self.len_as_bytes()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl CcsdsTimeProvider for TimeProviderCcsdsEpoch {
|
impl CcsdsTimeProvider for TimeProviderCcsdsEpoch {
|
||||||
@ -1226,4 +1230,13 @@ mod tests {
|
|||||||
panic!("unexpected error: {}", cuc_error);
|
panic!("unexpected error: {}", cuc_error);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_stamp_to_vec() {
|
||||||
|
let stamp = TimeProviderCcsdsEpoch::new_u16_counter(100);
|
||||||
|
let stamp_vec = stamp.to_vec().unwrap();
|
||||||
|
let mut buf: [u8; 16] = [0; 16];
|
||||||
|
stamp.write_to_bytes(&mut buf).unwrap();
|
||||||
|
assert_eq!(stamp_vec, buf[..stamp.len_written()]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -189,9 +189,18 @@ pub fn ms_of_day(seconds_since_epoch: f64) -> u32 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub trait TimeWriter {
|
pub trait TimeWriter {
|
||||||
|
fn len_written(&self) -> usize;
|
||||||
|
|
||||||
/// Generic function to convert write a timestamp into a raw buffer.
|
/// Generic function to convert write a timestamp into a raw buffer.
|
||||||
/// Returns the number of written bytes on success.
|
/// Returns the number of written bytes on success.
|
||||||
fn write_to_bytes(&self, bytes: &mut [u8]) -> Result<usize, TimestampError>;
|
fn write_to_bytes(&self, bytes: &mut [u8]) -> Result<usize, TimestampError>;
|
||||||
|
|
||||||
|
#[cfg(feature = "alloc")]
|
||||||
|
fn to_vec(&self) -> Result<alloc::vec::Vec<u8>, TimestampError> {
|
||||||
|
let mut vec = alloc::vec![0; self.len_written()];
|
||||||
|
self.write_to_bytes(&mut vec)?;
|
||||||
|
Ok(vec)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub trait TimeReader {
|
pub trait TimeReader {
|
||||||
|
Reference in New Issue
Block a user