Skip to content

Commit 6daae9a

Browse files
committed
FIX: Fix serde feature for const gen
1 parent c9b095f commit 6daae9a

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
@@ -483,7 +483,7 @@ fn test_string() {
483483
use std::error::Error;
484484

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

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

@@ -504,7 +504,7 @@ fn test_string() {
504504

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

523523
#[test]
524524
fn test_string_parse_from_str() {
525525
let text = "hello world";
526-
let u: ArrayString<[_; 11]> = text.parse().unwrap();
526+
let u: ArrayString<11> = text.parse().unwrap();
527527
assert_eq!(&u, text);
528528
assert_eq!(u.len(), text.len());
529529
}
@@ -539,17 +539,17 @@ fn test_string_from_bytes() {
539539
#[test]
540540
fn test_string_clone() {
541541
let text = "hi";
542-
let mut s = ArrayString::<[_; 4]>::new();
542+
let mut s = ArrayString::<4>::new();
543543
s.push_str("abcd");
544-
let t = ArrayString::<[_; 4]>::from(text).unwrap();
544+
let t = ArrayString::<4>::from(text).unwrap();
545545
s.clone_from(&t);
546546
assert_eq!(&t, &s);
547547
}
548548

549549
#[test]
550550
fn test_string_push() {
551551
let text = "abcαβγ";
552-
let mut s = ArrayString::<[_; 8]>::new();
552+
let mut s = ArrayString::<8>::new();
553553
for c in text.chars() {
554554
if let Err(_) = s.try_push(c) {
555555
break;
@@ -645,7 +645,7 @@ fn test_sizes() {
645645
#[test]
646646
fn test_default() {
647647
use std::net;
648-
let s: ArrayString<[u8; 4]> = Default::default();
648+
let s: ArrayString<4> = Default::default();
649649
// Something without `Default` implementation.
650650
let v: ArrayVec<net::TcpStream, 4> = Default::default();
651651
assert_eq!(s.len(), 0);
@@ -689,6 +689,6 @@ fn test_extend_zst() {
689689
#[test]
690690
fn test_try_from_argument() {
691691
use core::convert::TryFrom;
692-
let v = ArrayString::<[u8; 16]>::try_from(format_args!("Hello {}", 123)).unwrap();
692+
let v = ArrayString::<16>::try_from(format_args!("Hello {}", 123)).unwrap();
693693
assert_eq!(&v, "Hello 123");
694694
}

0 commit comments

Comments
 (0)