Skip to content

Commit b17ea58

Browse files
committed
FIX: Fix serde feature for const gen
1 parent 8ec646c commit b17ea58

File tree

5 files changed

+22
-25
lines changed

5 files changed

+22
-25
lines changed

src/array_string.rs

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -533,10 +533,10 @@ impl<'de, const CAP: usize> Deserialize<'de> for ArrayString<CAP>
533533
use serde::de::{self, Visitor};
534534
use std::marker::PhantomData;
535535

536-
struct ArrayStringVisitor<const CAP: usize>(PhantomData([u8; CAP]));
536+
struct ArrayStringVisitor<const CAP: usize>(PhantomData<[u8; CAP]>);
537537

538-
impl<'de, const CAP: usize> Visitor<'de> for ArrayStringVisitor {
539-
type Value = ArrayString;
538+
impl<'de, const CAP: usize> Visitor<'de> for ArrayStringVisitor<CAP> {
539+
type Value = ArrayString<CAP>;
540540

541541
fn expecting(&self, formatter: &mut fmt::Formatter) -> fmt::Result {
542542
write!(formatter, "a string no more than {} bytes long", CAP)

src/arrayvec.rs

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1141,17 +1141,17 @@ impl<'de, T: Deserialize<'de>, const CAP: usize> Deserialize<'de> for ArrayVec<T
11411141
type Value = ArrayVec<T, CAP>;
11421142

11431143
fn expecting(&self, formatter: &mut fmt::Formatter) -> fmt::Result {
1144-
write!(formatter, "an array with no more than {} items", A::CAPACITY)
1144+
write!(formatter, "an array with no more than {} items", CAP)
11451145
}
11461146

11471147
fn visit_seq<SA>(self, mut seq: SA) -> Result<Self::Value, SA::Error>
11481148
where SA: SeqAccess<'de>,
11491149
{
1150-
let mut values = ArrayVec::<A>::new();
1150+
let mut values = ArrayVec::<T, CAP>::new();
11511151

11521152
while let Some(value) = seq.next_element()? {
11531153
if let Err(_) = values.try_push(value) {
1154-
return Err(SA::Error::invalid_length(A::CAPACITY + 1, &self));
1154+
return Err(SA::Error::invalid_length(CAP + 1, &self));
11551155
}
11561156
}
11571157

src/lib.rs

Lines changed: 0 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -34,9 +34,6 @@ extern crate serde;
3434
#[cfg(not(feature="std"))]
3535
extern crate core as std;
3636

37-
#[cfg(feature="serde")]
38-
use serde::{Serialize, Deserialize, Serializer, Deserializer};
39-
4037
mod array;
4138
mod arrayvec_impl;
4239
mod arrayvec;

tests/serde.rs

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,7 @@ mod array_vec {
99

1010
#[test]
1111
fn test_ser_de_empty() {
12-
let vec = ArrayVec::<[u32; 0]>::new();
12+
let vec = ArrayVec::<u32, 0>::new();
1313

1414
assert_tokens(&vec, &[
1515
Token::Seq { len: Some(0) },
@@ -20,7 +20,7 @@ mod array_vec {
2020

2121
#[test]
2222
fn test_ser_de() {
23-
let mut vec = ArrayVec::<[u32; 3]>::new();
23+
let mut vec = ArrayVec::<u32, 3>::new();
2424
vec.push(20);
2525
vec.push(55);
2626
vec.push(123);
@@ -36,7 +36,7 @@ mod array_vec {
3636

3737
#[test]
3838
fn test_de_too_large() {
39-
assert_de_tokens_error::<ArrayVec<[u32; 2]>>(&[
39+
assert_de_tokens_error::<ArrayVec<u32, 2>>(&[
4040
Token::Seq { len: Some(3) },
4141
Token::U32(13),
4242
Token::U32(42),
@@ -52,7 +52,7 @@ mod array_string {
5252

5353
#[test]
5454
fn test_ser_de_empty() {
55-
let string = ArrayString::<[u8; 0]>::new();
55+
let string = ArrayString::<0>::new();
5656

5757
assert_tokens(&string, &[
5858
Token::Str(""),
@@ -62,7 +62,7 @@ mod array_string {
6262

6363
#[test]
6464
fn test_ser_de() {
65-
let string = ArrayString::<[u8; 9]>::from("1234 abcd")
65+
let string = ArrayString::<9>::from("1234 abcd")
6666
.expect("expected exact specified capacity to be enough");
6767

6868
assert_tokens(&string, &[
@@ -72,7 +72,7 @@ mod array_string {
7272

7373
#[test]
7474
fn test_de_too_large() {
75-
assert_de_tokens_error::<ArrayString<[u8; 2]>>(&[
75+
assert_de_tokens_error::<ArrayString<2>>(&[
7676
Token::Str("afd")
7777
], "invalid length 3, expected a string no more than 2 bytes long");
7878
}

tests/tests.rs

Lines changed: 10 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -484,7 +484,7 @@ fn test_string() {
484484
use std::error::Error;
485485

486486
let text = "hello world";
487-
let mut s = ArrayString::<[_; 16]>::new();
487+
let mut s = ArrayString::<16>::new();
488488
s.try_push_str(text).unwrap();
489489
assert_eq!(&s, text);
490490
assert_eq!(text, &s);
@@ -494,7 +494,7 @@ fn test_string() {
494494
map.insert(s, 1);
495495
assert_eq!(map[text], 1);
496496

497-
let mut t = ArrayString::<[_; 2]>::new();
497+
let mut t = ArrayString::<2>::new();
498498
assert!(t.try_push_str(text).is_err());
499499
assert_eq!(&t, "");
500500

@@ -505,7 +505,7 @@ fn test_string() {
505505

506506
// Test Error trait / try
507507
let t = || -> Result<(), Box<dyn Error>> {
508-
let mut t = ArrayString::<[_; 2]>::new();
508+
let mut t = ArrayString::<2>::new();
509509
t.try_push_str(text)?;
510510
Ok(())
511511
}();
@@ -516,15 +516,15 @@ fn test_string() {
516516
fn test_string_from() {
517517
let text = "hello world";
518518
// Test `from` constructor
519-
let u = ArrayString::<[_; 11]>::from(text).unwrap();
519+
let u = ArrayString::<11>::from(text).unwrap();
520520
assert_eq!(&u, text);
521521
assert_eq!(u.len(), text.len());
522522
}
523523

524524
#[test]
525525
fn test_string_parse_from_str() {
526526
let text = "hello world";
527-
let u: ArrayString<[_; 11]> = text.parse().unwrap();
527+
let u: ArrayString<11> = text.parse().unwrap();
528528
assert_eq!(&u, text);
529529
assert_eq!(u.len(), text.len());
530530
}
@@ -540,17 +540,17 @@ fn test_string_from_bytes() {
540540
#[test]
541541
fn test_string_clone() {
542542
let text = "hi";
543-
let mut s = ArrayString::<[_; 4]>::new();
543+
let mut s = ArrayString::<4>::new();
544544
s.push_str("abcd");
545-
let t = ArrayString::<[_; 4]>::from(text).unwrap();
545+
let t = ArrayString::<4>::from(text).unwrap();
546546
s.clone_from(&t);
547547
assert_eq!(&t, &s);
548548
}
549549

550550
#[test]
551551
fn test_string_push() {
552552
let text = "abcαβγ";
553-
let mut s = ArrayString::<[_; 8]>::new();
553+
let mut s = ArrayString::<8>::new();
554554
for c in text.chars() {
555555
if let Err(_) = s.try_push(c) {
556556
break;
@@ -646,7 +646,7 @@ fn test_sizes() {
646646
#[test]
647647
fn test_default() {
648648
use std::net;
649-
let s: ArrayString<[u8; 4]> = Default::default();
649+
let s: ArrayString<4> = Default::default();
650650
// Something without `Default` implementation.
651651
let v: ArrayVec<net::TcpStream, 4> = Default::default();
652652
assert_eq!(s.len(), 0);
@@ -690,6 +690,6 @@ fn test_extend_zst() {
690690
#[test]
691691
fn test_try_from_argument() {
692692
use core::convert::TryFrom;
693-
let v = ArrayString::<[u8; 16]>::try_from(format_args!("Hello {}", 123)).unwrap();
693+
let v = ArrayString::<16>::try_from(format_args!("Hello {}", 123)).unwrap();
694694
assert_eq!(&v, "Hello 123");
695695
}

0 commit comments

Comments
 (0)