• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 //! Generic data structure serialization framework.
2 //!
3 //! The two most important traits in this module are [`Serialize`] and
4 //! [`Serializer`].
5 //!
6 //!  - **A type that implements `Serialize` is a data structure** that can be
7 //!    serialized to any data format supported by Serde, and conversely
8 //!  - **A type that implements `Serializer` is a data format** that can
9 //!    serialize any data structure supported by Serde.
10 //!
11 //! # The Serialize trait
12 //!
13 //! Serde provides [`Serialize`] implementations for many Rust primitive and
14 //! standard library types. The complete list is below. All of these can be
15 //! serialized using Serde out of the box.
16 //!
17 //! Additionally, Serde provides a procedural macro called [`serde_derive`] to
18 //! automatically generate [`Serialize`] implementations for structs and enums
19 //! in your program. See the [derive section of the manual] for how to use this.
20 //!
21 //! In rare cases it may be necessary to implement [`Serialize`] manually for
22 //! some type in your program. See the [Implementing `Serialize`] section of the
23 //! manual for more about this.
24 //!
25 //! Third-party crates may provide [`Serialize`] implementations for types that
26 //! they expose. For example the [`linked-hash-map`] crate provides a
27 //! [`LinkedHashMap<K, V>`] type that is serializable by Serde because the crate
28 //! provides an implementation of [`Serialize`] for it.
29 //!
30 //! # The Serializer trait
31 //!
32 //! [`Serializer`] implementations are provided by third-party crates, for
33 //! example [`serde_json`], [`serde_yaml`] and [`bincode`].
34 //!
35 //! A partial list of well-maintained formats is given on the [Serde
36 //! website][data formats].
37 //!
38 //! # Implementations of Serialize provided by Serde
39 //!
40 //!  - **Primitive types**:
41 //!    - bool
42 //!    - i8, i16, i32, i64, i128, isize
43 //!    - u8, u16, u32, u64, u128, usize
44 //!    - f32, f64
45 //!    - char
46 //!    - str
47 //!    - &T and &mut T
48 //!  - **Compound types**:
49 //!    - \[T\]
50 //!    - \[T; 0\] through \[T; 32\]
51 //!    - tuples up to size 16
52 //!  - **Common standard library types**:
53 //!    - String
54 //!    - Option\<T\>
55 //!    - Result\<T, E\>
56 //!    - PhantomData\<T\>
57 //!  - **Wrapper types**:
58 //!    - Box\<T\>
59 //!    - Cow\<'a, T\>
60 //!    - Cell\<T\>
61 //!    - RefCell\<T\>
62 //!    - Mutex\<T\>
63 //!    - RwLock\<T\>
64 //!    - Rc\<T\>&emsp;*(if* features = ["rc"] *is enabled)*
65 //!    - Arc\<T\>&emsp;*(if* features = ["rc"] *is enabled)*
66 //!  - **Collection types**:
67 //!    - BTreeMap\<K, V\>
68 //!    - BTreeSet\<T\>
69 //!    - BinaryHeap\<T\>
70 //!    - HashMap\<K, V, H\>
71 //!    - HashSet\<T, H\>
72 //!    - LinkedList\<T\>
73 //!    - VecDeque\<T\>
74 //!    - Vec\<T\>
75 //!  - **FFI types**:
76 //!    - CStr
77 //!    - CString
78 //!    - OsStr
79 //!    - OsString
80 //!  - **Miscellaneous standard library types**:
81 //!    - Duration
82 //!    - SystemTime
83 //!    - Path
84 //!    - PathBuf
85 //!    - Range\<T\>
86 //!    - RangeInclusive\<T\>
87 //!    - Bound\<T\>
88 //!    - num::NonZero*
89 //!    - `!` *(unstable)*
90 //!  - **Net types**:
91 //!    - IpAddr
92 //!    - Ipv4Addr
93 //!    - Ipv6Addr
94 //!    - SocketAddr
95 //!    - SocketAddrV4
96 //!    - SocketAddrV6
97 //!
98 //! [Implementing `Serialize`]: https://serde.rs/impl-serialize.html
99 //! [`LinkedHashMap<K, V>`]: https://docs.rs/linked-hash-map/*/linked_hash_map/struct.LinkedHashMap.html
100 //! [`Serialize`]: ../trait.Serialize.html
101 //! [`Serializer`]: ../trait.Serializer.html
102 //! [`bincode`]: https://github.com/servo/bincode
103 //! [`linked-hash-map`]: https://crates.io/crates/linked-hash-map
104 //! [`serde_derive`]: https://crates.io/crates/serde_derive
105 //! [`serde_json`]: https://github.com/serde-rs/json
106 //! [`serde_yaml`]: https://github.com/dtolnay/serde-yaml
107 //! [derive section of the manual]: https://serde.rs/derive.html
108 //! [data formats]: https://serde.rs/#data-formats
109 
110 use lib::*;
111 
112 mod fmt;
113 mod impls;
114 mod impossible;
115 
116 pub use self::impossible::Impossible;
117 
118 #[cfg(feature = "std")]
119 #[doc(no_inline)]
120 pub use std::error::Error as StdError;
121 #[cfg(not(feature = "std"))]
122 #[doc(no_inline)]
123 pub use std_error::Error as StdError;
124 
125 ////////////////////////////////////////////////////////////////////////////////
126 
127 macro_rules! declare_error_trait {
128     (Error: Sized $(+ $($supertrait:ident)::+)*) => {
129         /// Trait used by `Serialize` implementations to generically construct
130         /// errors belonging to the `Serializer` against which they are
131         /// currently running.
132         ///
133         /// # Example implementation
134         ///
135         /// The [example data format] presented on the website shows an error
136         /// type appropriate for a basic JSON data format.
137         ///
138         /// [example data format]: https://serde.rs/data-format.html
139         pub trait Error: Sized $(+ $($supertrait)::+)* {
140             /// Used when a [`Serialize`] implementation encounters any error
141             /// while serializing a type.
142             ///
143             /// The message should not be capitalized and should not end with a
144             /// period.
145             ///
146             /// For example, a filesystem [`Path`] may refuse to serialize
147             /// itself if it contains invalid UTF-8 data.
148             ///
149             /// ```edition2018
150             /// # struct Path;
151             /// #
152             /// # impl Path {
153             /// #     fn to_str(&self) -> Option<&str> {
154             /// #         unimplemented!()
155             /// #     }
156             /// # }
157             /// #
158             /// use serde::ser::{self, Serialize, Serializer};
159             ///
160             /// impl Serialize for Path {
161             ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
162             ///     where
163             ///         S: Serializer,
164             ///     {
165             ///         match self.to_str() {
166             ///             Some(s) => serializer.serialize_str(s),
167             ///             None => Err(ser::Error::custom("path contains invalid UTF-8 characters")),
168             ///         }
169             ///     }
170             /// }
171             /// ```
172             ///
173             /// [`Path`]: https://doc.rust-lang.org/std/path/struct.Path.html
174             /// [`Serialize`]: ../trait.Serialize.html
175             fn custom<T>(msg: T) -> Self
176             where
177                 T: Display;
178         }
179     }
180 }
181 
182 #[cfg(feature = "std")]
183 declare_error_trait!(Error: Sized + StdError);
184 
185 #[cfg(not(feature = "std"))]
186 declare_error_trait!(Error: Sized + Debug + Display);
187 
188 ////////////////////////////////////////////////////////////////////////////////
189 
190 /// A **data structure** that can be serialized into any data format supported
191 /// by Serde.
192 ///
193 /// Serde provides `Serialize` implementations for many Rust primitive and
194 /// standard library types. The complete list is [here][ser]. All of these can
195 /// be serialized using Serde out of the box.
196 ///
197 /// Additionally, Serde provides a procedural macro called [`serde_derive`] to
198 /// automatically generate `Serialize` implementations for structs and enums in
199 /// your program. See the [derive section of the manual] for how to use this.
200 ///
201 /// In rare cases it may be necessary to implement `Serialize` manually for some
202 /// type in your program. See the [Implementing `Serialize`] section of the
203 /// manual for more about this.
204 ///
205 /// Third-party crates may provide `Serialize` implementations for types that
206 /// they expose. For example the [`linked-hash-map`] crate provides a
207 /// [`LinkedHashMap<K, V>`] type that is serializable by Serde because the crate
208 /// provides an implementation of `Serialize` for it.
209 ///
210 /// [Implementing `Serialize`]: https://serde.rs/impl-serialize.html
211 /// [`LinkedHashMap<K, V>`]: https://docs.rs/linked-hash-map/*/linked_hash_map/struct.LinkedHashMap.html
212 /// [`linked-hash-map`]: https://crates.io/crates/linked-hash-map
213 /// [`serde_derive`]: https://crates.io/crates/serde_derive
214 /// [derive section of the manual]: https://serde.rs/derive.html
215 /// [ser]: https://docs.serde.rs/serde/ser/index.html
216 pub trait Serialize {
217     /// Serialize this value into the given Serde serializer.
218     ///
219     /// See the [Implementing `Serialize`] section of the manual for more
220     /// information about how to implement this method.
221     ///
222     /// ```edition2018
223     /// use serde::ser::{Serialize, SerializeStruct, Serializer};
224     ///
225     /// struct Person {
226     ///     name: String,
227     ///     age: u8,
228     ///     phones: Vec<String>,
229     /// }
230     ///
231     /// // This is what #[derive(Serialize)] would generate.
232     /// impl Serialize for Person {
233     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
234     ///     where
235     ///         S: Serializer,
236     ///     {
237     ///         let mut s = serializer.serialize_struct("Person", 3)?;
238     ///         s.serialize_field("name", &self.name)?;
239     ///         s.serialize_field("age", &self.age)?;
240     ///         s.serialize_field("phones", &self.phones)?;
241     ///         s.end()
242     ///     }
243     /// }
244     /// ```
245     ///
246     /// [Implementing `Serialize`]: https://serde.rs/impl-serialize.html
serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error> where S: Serializer247     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
248     where
249         S: Serializer;
250 }
251 
252 ////////////////////////////////////////////////////////////////////////////////
253 
254 /// A **data format** that can serialize any data structure supported by Serde.
255 ///
256 /// The role of this trait is to define the serialization half of the [Serde
257 /// data model], which is a way to categorize every Rust data structure into one
258 /// of 29 possible types. Each method of the `Serializer` trait corresponds to
259 /// one of the types of the data model.
260 ///
261 /// Implementations of `Serialize` map themselves into this data model by
262 /// invoking exactly one of the `Serializer` methods.
263 ///
264 /// The types that make up the Serde data model are:
265 ///
266 ///  - **14 primitive types**
267 ///    - bool
268 ///    - i8, i16, i32, i64, i128
269 ///    - u8, u16, u32, u64, u128
270 ///    - f32, f64
271 ///    - char
272 ///  - **string**
273 ///    - UTF-8 bytes with a length and no null terminator.
274 ///    - When serializing, all strings are handled equally. When deserializing,
275 ///      there are three flavors of strings: transient, owned, and borrowed.
276 ///  - **byte array** - \[u8\]
277 ///    - Similar to strings, during deserialization byte arrays can be
278 ///      transient, owned, or borrowed.
279 ///  - **option**
280 ///    - Either none or some value.
281 ///  - **unit**
282 ///    - The type of `()` in Rust. It represents an anonymous value containing
283 ///      no data.
284 ///  - **unit_struct**
285 ///    - For example `struct Unit` or `PhantomData<T>`. It represents a named
286 ///      value containing no data.
287 ///  - **unit_variant**
288 ///    - For example the `E::A` and `E::B` in `enum E { A, B }`.
289 ///  - **newtype_struct**
290 ///    - For example `struct Millimeters(u8)`.
291 ///  - **newtype_variant**
292 ///    - For example the `E::N` in `enum E { N(u8) }`.
293 ///  - **seq**
294 ///    - A variably sized heterogeneous sequence of values, for example
295 ///      `Vec<T>` or `HashSet<T>`. When serializing, the length may or may not
296 ///      be known before iterating through all the data. When deserializing,
297 ///      the length is determined by looking at the serialized data.
298 ///  - **tuple**
299 ///    - A statically sized heterogeneous sequence of values for which the
300 ///      length will be known at deserialization time without looking at the
301 ///      serialized data, for example `(u8,)` or `(String, u64, Vec<T>)` or
302 ///      `[u64; 10]`.
303 ///  - **tuple_struct**
304 ///    - A named tuple, for example `struct Rgb(u8, u8, u8)`.
305 ///  - **tuple_variant**
306 ///    - For example the `E::T` in `enum E { T(u8, u8) }`.
307 ///  - **map**
308 ///    - A heterogeneous key-value pairing, for example `BTreeMap<K, V>`.
309 ///  - **struct**
310 ///    - A heterogeneous key-value pairing in which the keys are strings and
311 ///      will be known at deserialization time without looking at the
312 ///      serialized data, for example `struct S { r: u8, g: u8, b: u8 }`.
313 ///  - **struct_variant**
314 ///    - For example the `E::S` in `enum E { S { r: u8, g: u8, b: u8 } }`.
315 ///
316 /// Many Serde serializers produce text or binary data as output, for example
317 /// JSON or Bincode. This is not a requirement of the `Serializer` trait, and
318 /// there are serializers that do not produce text or binary output. One example
319 /// is the `serde_json::value::Serializer` (distinct from the main `serde_json`
320 /// serializer) that produces a `serde_json::Value` data structure in memory as
321 /// output.
322 ///
323 /// [Serde data model]: https://serde.rs/data-model.html
324 ///
325 /// # Example implementation
326 ///
327 /// The [example data format] presented on the website contains example code for
328 /// a basic JSON `Serializer`.
329 ///
330 /// [example data format]: https://serde.rs/data-format.html
331 pub trait Serializer: Sized {
332     /// The output type produced by this `Serializer` during successful
333     /// serialization. Most serializers that produce text or binary output
334     /// should set `Ok = ()` and serialize into an [`io::Write`] or buffer
335     /// contained within the `Serializer` instance. Serializers that build
336     /// in-memory data structures may be simplified by using `Ok` to propagate
337     /// the data structure around.
338     ///
339     /// [`io::Write`]: https://doc.rust-lang.org/std/io/trait.Write.html
340     type Ok;
341 
342     /// The error type when some error occurs during serialization.
343     type Error: Error;
344 
345     /// Type returned from [`serialize_seq`] for serializing the content of the
346     /// sequence.
347     ///
348     /// [`serialize_seq`]: #tymethod.serialize_seq
349     type SerializeSeq: SerializeSeq<Ok = Self::Ok, Error = Self::Error>;
350 
351     /// Type returned from [`serialize_tuple`] for serializing the content of
352     /// the tuple.
353     ///
354     /// [`serialize_tuple`]: #tymethod.serialize_tuple
355     type SerializeTuple: SerializeTuple<Ok = Self::Ok, Error = Self::Error>;
356 
357     /// Type returned from [`serialize_tuple_struct`] for serializing the
358     /// content of the tuple struct.
359     ///
360     /// [`serialize_tuple_struct`]: #tymethod.serialize_tuple_struct
361     type SerializeTupleStruct: SerializeTupleStruct<Ok = Self::Ok, Error = Self::Error>;
362 
363     /// Type returned from [`serialize_tuple_variant`] for serializing the
364     /// content of the tuple variant.
365     ///
366     /// [`serialize_tuple_variant`]: #tymethod.serialize_tuple_variant
367     type SerializeTupleVariant: SerializeTupleVariant<Ok = Self::Ok, Error = Self::Error>;
368 
369     /// Type returned from [`serialize_map`] for serializing the content of the
370     /// map.
371     ///
372     /// [`serialize_map`]: #tymethod.serialize_map
373     type SerializeMap: SerializeMap<Ok = Self::Ok, Error = Self::Error>;
374 
375     /// Type returned from [`serialize_struct`] for serializing the content of
376     /// the struct.
377     ///
378     /// [`serialize_struct`]: #tymethod.serialize_struct
379     type SerializeStruct: SerializeStruct<Ok = Self::Ok, Error = Self::Error>;
380 
381     /// Type returned from [`serialize_struct_variant`] for serializing the
382     /// content of the struct variant.
383     ///
384     /// [`serialize_struct_variant`]: #tymethod.serialize_struct_variant
385     type SerializeStructVariant: SerializeStructVariant<Ok = Self::Ok, Error = Self::Error>;
386 
387     /// Serialize a `bool` value.
388     ///
389     /// ```edition2018
390     /// # use serde::Serializer;
391     /// #
392     /// # serde::__private_serialize!();
393     /// #
394     /// impl Serialize for bool {
395     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
396     ///     where
397     ///         S: Serializer,
398     ///     {
399     ///         serializer.serialize_bool(*self)
400     ///     }
401     /// }
402     /// ```
serialize_bool(self, v: bool) -> Result<Self::Ok, Self::Error>403     fn serialize_bool(self, v: bool) -> Result<Self::Ok, Self::Error>;
404 
405     /// Serialize an `i8` value.
406     ///
407     /// If the format does not differentiate between `i8` and `i64`, a
408     /// reasonable implementation would be to cast the value to `i64` and
409     /// forward to `serialize_i64`.
410     ///
411     /// ```edition2018
412     /// # use serde::Serializer;
413     /// #
414     /// # serde::__private_serialize!();
415     /// #
416     /// impl Serialize for i8 {
417     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
418     ///     where
419     ///         S: Serializer,
420     ///     {
421     ///         serializer.serialize_i8(*self)
422     ///     }
423     /// }
424     /// ```
serialize_i8(self, v: i8) -> Result<Self::Ok, Self::Error>425     fn serialize_i8(self, v: i8) -> Result<Self::Ok, Self::Error>;
426 
427     /// Serialize an `i16` value.
428     ///
429     /// If the format does not differentiate between `i16` and `i64`, a
430     /// reasonable implementation would be to cast the value to `i64` and
431     /// forward to `serialize_i64`.
432     ///
433     /// ```edition2018
434     /// # use serde::Serializer;
435     /// #
436     /// # serde::__private_serialize!();
437     /// #
438     /// impl Serialize for i16 {
439     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
440     ///     where
441     ///         S: Serializer,
442     ///     {
443     ///         serializer.serialize_i16(*self)
444     ///     }
445     /// }
446     /// ```
serialize_i16(self, v: i16) -> Result<Self::Ok, Self::Error>447     fn serialize_i16(self, v: i16) -> Result<Self::Ok, Self::Error>;
448 
449     /// Serialize an `i32` value.
450     ///
451     /// If the format does not differentiate between `i32` and `i64`, a
452     /// reasonable implementation would be to cast the value to `i64` and
453     /// forward to `serialize_i64`.
454     ///
455     /// ```edition2018
456     /// # use serde::Serializer;
457     /// #
458     /// # serde::__private_serialize!();
459     /// #
460     /// impl Serialize for i32 {
461     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
462     ///     where
463     ///         S: Serializer,
464     ///     {
465     ///         serializer.serialize_i32(*self)
466     ///     }
467     /// }
468     /// ```
serialize_i32(self, v: i32) -> Result<Self::Ok, Self::Error>469     fn serialize_i32(self, v: i32) -> Result<Self::Ok, Self::Error>;
470 
471     /// Serialize an `i64` value.
472     ///
473     /// ```edition2018
474     /// # use serde::Serializer;
475     /// #
476     /// # serde::__private_serialize!();
477     /// #
478     /// impl Serialize for i64 {
479     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
480     ///     where
481     ///         S: Serializer,
482     ///     {
483     ///         serializer.serialize_i64(*self)
484     ///     }
485     /// }
486     /// ```
serialize_i64(self, v: i64) -> Result<Self::Ok, Self::Error>487     fn serialize_i64(self, v: i64) -> Result<Self::Ok, Self::Error>;
488 
489     serde_if_integer128! {
490         /// Serialize an `i128` value.
491         ///
492         /// ```edition2018
493         /// # use serde::Serializer;
494         /// #
495         /// # serde::__private_serialize!();
496         /// #
497         /// impl Serialize for i128 {
498         ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
499         ///     where
500         ///         S: Serializer,
501         ///     {
502         ///         serializer.serialize_i128(*self)
503         ///     }
504         /// }
505         /// ```
506         ///
507         /// This method is available only on Rust compiler versions >=1.26. The
508         /// default behavior unconditionally returns an error.
509         fn serialize_i128(self, v: i128) -> Result<Self::Ok, Self::Error> {
510             let _ = v;
511             Err(Error::custom("i128 is not supported"))
512         }
513     }
514 
515     /// Serialize a `u8` value.
516     ///
517     /// If the format does not differentiate between `u8` and `u64`, a
518     /// reasonable implementation would be to cast the value to `u64` and
519     /// forward to `serialize_u64`.
520     ///
521     /// ```edition2018
522     /// # use serde::Serializer;
523     /// #
524     /// # serde::__private_serialize!();
525     /// #
526     /// impl Serialize for u8 {
527     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
528     ///     where
529     ///         S: Serializer,
530     ///     {
531     ///         serializer.serialize_u8(*self)
532     ///     }
533     /// }
534     /// ```
serialize_u8(self, v: u8) -> Result<Self::Ok, Self::Error>535     fn serialize_u8(self, v: u8) -> Result<Self::Ok, Self::Error>;
536 
537     /// Serialize a `u16` value.
538     ///
539     /// If the format does not differentiate between `u16` and `u64`, a
540     /// reasonable implementation would be to cast the value to `u64` and
541     /// forward to `serialize_u64`.
542     ///
543     /// ```edition2018
544     /// # use serde::Serializer;
545     /// #
546     /// # serde::__private_serialize!();
547     /// #
548     /// impl Serialize for u16 {
549     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
550     ///     where
551     ///         S: Serializer,
552     ///     {
553     ///         serializer.serialize_u16(*self)
554     ///     }
555     /// }
556     /// ```
serialize_u16(self, v: u16) -> Result<Self::Ok, Self::Error>557     fn serialize_u16(self, v: u16) -> Result<Self::Ok, Self::Error>;
558 
559     /// Serialize a `u32` value.
560     ///
561     /// If the format does not differentiate between `u32` and `u64`, a
562     /// reasonable implementation would be to cast the value to `u64` and
563     /// forward to `serialize_u64`.
564     ///
565     /// ```edition2018
566     /// # use serde::Serializer;
567     /// #
568     /// # serde::__private_serialize!();
569     /// #
570     /// impl Serialize for u32 {
571     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
572     ///     where
573     ///         S: Serializer,
574     ///     {
575     ///         serializer.serialize_u32(*self)
576     ///     }
577     /// }
578     /// ```
serialize_u32(self, v: u32) -> Result<Self::Ok, Self::Error>579     fn serialize_u32(self, v: u32) -> Result<Self::Ok, Self::Error>;
580 
581     /// Serialize a `u64` value.
582     ///
583     /// ```edition2018
584     /// # use serde::Serializer;
585     /// #
586     /// # serde::__private_serialize!();
587     /// #
588     /// impl Serialize for u64 {
589     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
590     ///     where
591     ///         S: Serializer,
592     ///     {
593     ///         serializer.serialize_u64(*self)
594     ///     }
595     /// }
596     /// ```
serialize_u64(self, v: u64) -> Result<Self::Ok, Self::Error>597     fn serialize_u64(self, v: u64) -> Result<Self::Ok, Self::Error>;
598 
599     serde_if_integer128! {
600         /// Serialize a `u128` value.
601         ///
602         /// ```edition2018
603         /// # use serde::Serializer;
604         /// #
605         /// # serde::__private_serialize!();
606         /// #
607         /// impl Serialize for u128 {
608         ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
609         ///     where
610         ///         S: Serializer,
611         ///     {
612         ///         serializer.serialize_u128(*self)
613         ///     }
614         /// }
615         /// ```
616         ///
617         /// This method is available only on Rust compiler versions >=1.26. The
618         /// default behavior unconditionally returns an error.
619         fn serialize_u128(self, v: u128) -> Result<Self::Ok, Self::Error> {
620             let _ = v;
621             Err(Error::custom("u128 is not supported"))
622         }
623     }
624 
625     /// Serialize an `f32` value.
626     ///
627     /// If the format does not differentiate between `f32` and `f64`, a
628     /// reasonable implementation would be to cast the value to `f64` and
629     /// forward to `serialize_f64`.
630     ///
631     /// ```edition2018
632     /// # use serde::Serializer;
633     /// #
634     /// # serde::__private_serialize!();
635     /// #
636     /// impl Serialize for f32 {
637     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
638     ///     where
639     ///         S: Serializer,
640     ///     {
641     ///         serializer.serialize_f32(*self)
642     ///     }
643     /// }
644     /// ```
serialize_f32(self, v: f32) -> Result<Self::Ok, Self::Error>645     fn serialize_f32(self, v: f32) -> Result<Self::Ok, Self::Error>;
646 
647     /// Serialize an `f64` value.
648     ///
649     /// ```edition2018
650     /// # use serde::Serializer;
651     /// #
652     /// # serde::__private_serialize!();
653     /// #
654     /// impl Serialize for f64 {
655     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
656     ///     where
657     ///         S: Serializer,
658     ///     {
659     ///         serializer.serialize_f64(*self)
660     ///     }
661     /// }
662     /// ```
serialize_f64(self, v: f64) -> Result<Self::Ok, Self::Error>663     fn serialize_f64(self, v: f64) -> Result<Self::Ok, Self::Error>;
664 
665     /// Serialize a character.
666     ///
667     /// If the format does not support characters, it is reasonable to serialize
668     /// it as a single element `str` or a `u32`.
669     ///
670     /// ```edition2018
671     /// # use serde::Serializer;
672     /// #
673     /// # serde::__private_serialize!();
674     /// #
675     /// impl Serialize for char {
676     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
677     ///     where
678     ///         S: Serializer,
679     ///     {
680     ///         serializer.serialize_char(*self)
681     ///     }
682     /// }
683     /// ```
serialize_char(self, v: char) -> Result<Self::Ok, Self::Error>684     fn serialize_char(self, v: char) -> Result<Self::Ok, Self::Error>;
685 
686     /// Serialize a `&str`.
687     ///
688     /// ```edition2018
689     /// # use serde::Serializer;
690     /// #
691     /// # serde::__private_serialize!();
692     /// #
693     /// impl Serialize for str {
694     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
695     ///     where
696     ///         S: Serializer,
697     ///     {
698     ///         serializer.serialize_str(self)
699     ///     }
700     /// }
701     /// ```
serialize_str(self, v: &str) -> Result<Self::Ok, Self::Error>702     fn serialize_str(self, v: &str) -> Result<Self::Ok, Self::Error>;
703 
704     /// Serialize a chunk of raw byte data.
705     ///
706     /// Enables serializers to serialize byte slices more compactly or more
707     /// efficiently than other types of slices. If no efficient implementation
708     /// is available, a reasonable implementation would be to forward to
709     /// `serialize_seq`. If forwarded, the implementation looks usually just
710     /// like this:
711     ///
712     /// ```edition2018
713     /// # use serde::ser::{Serializer, SerializeSeq};
714     /// # use serde::__private::doc::Error;
715     /// #
716     /// # struct MySerializer;
717     /// #
718     /// # impl Serializer for MySerializer {
719     /// #     type Ok = ();
720     /// #     type Error = Error;
721     /// #
722     /// fn serialize_bytes(self, v: &[u8]) -> Result<Self::Ok, Self::Error> {
723     ///     let mut seq = self.serialize_seq(Some(v.len()))?;
724     ///     for b in v {
725     ///         seq.serialize_element(b)?;
726     ///     }
727     ///     seq.end()
728     /// }
729     /// #
730     /// #     serde::__serialize_unimplemented! {
731     /// #         bool i8 i16 i32 i64 u8 u16 u32 u64 f32 f64 char str none some
732     /// #         unit unit_struct unit_variant newtype_struct newtype_variant
733     /// #         seq tuple tuple_struct tuple_variant map struct struct_variant
734     /// #     }
735     /// # }
736     /// ```
serialize_bytes(self, v: &[u8]) -> Result<Self::Ok, Self::Error>737     fn serialize_bytes(self, v: &[u8]) -> Result<Self::Ok, Self::Error>;
738 
739     /// Serialize a [`None`] value.
740     ///
741     /// ```edition2018
742     /// # use serde::{Serialize, Serializer};
743     /// #
744     /// # enum Option<T> {
745     /// #     Some(T),
746     /// #     None,
747     /// # }
748     /// #
749     /// # use self::Option::{Some, None};
750     /// #
751     /// impl<T> Serialize for Option<T>
752     /// where
753     ///     T: Serialize,
754     /// {
755     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
756     ///     where
757     ///         S: Serializer,
758     ///     {
759     ///         match *self {
760     ///             Some(ref value) => serializer.serialize_some(value),
761     ///             None => serializer.serialize_none(),
762     ///         }
763     ///     }
764     /// }
765     /// #
766     /// # fn main() {}
767     /// ```
768     ///
769     /// [`None`]: https://doc.rust-lang.org/std/option/enum.Option.html#variant.None
serialize_none(self) -> Result<Self::Ok, Self::Error>770     fn serialize_none(self) -> Result<Self::Ok, Self::Error>;
771 
772     /// Serialize a [`Some(T)`] value.
773     ///
774     /// ```edition2018
775     /// # use serde::{Serialize, Serializer};
776     /// #
777     /// # enum Option<T> {
778     /// #     Some(T),
779     /// #     None,
780     /// # }
781     /// #
782     /// # use self::Option::{Some, None};
783     /// #
784     /// impl<T> Serialize for Option<T>
785     /// where
786     ///     T: Serialize,
787     /// {
788     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
789     ///     where
790     ///         S: Serializer,
791     ///     {
792     ///         match *self {
793     ///             Some(ref value) => serializer.serialize_some(value),
794     ///             None => serializer.serialize_none(),
795     ///         }
796     ///     }
797     /// }
798     /// #
799     /// # fn main() {}
800     /// ```
801     ///
802     /// [`Some(T)`]: https://doc.rust-lang.org/std/option/enum.Option.html#variant.Some
serialize_some<T: ?Sized>(self, value: &T) -> Result<Self::Ok, Self::Error> where T: Serialize803     fn serialize_some<T: ?Sized>(self, value: &T) -> Result<Self::Ok, Self::Error>
804     where
805         T: Serialize;
806 
807     /// Serialize a `()` value.
808     ///
809     /// ```edition2018
810     /// # use serde::Serializer;
811     /// #
812     /// # serde::__private_serialize!();
813     /// #
814     /// impl Serialize for () {
815     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
816     ///     where
817     ///         S: Serializer,
818     ///     {
819     ///         serializer.serialize_unit()
820     ///     }
821     /// }
822     /// ```
serialize_unit(self) -> Result<Self::Ok, Self::Error>823     fn serialize_unit(self) -> Result<Self::Ok, Self::Error>;
824 
825     /// Serialize a unit struct like `struct Unit` or `PhantomData<T>`.
826     ///
827     /// A reasonable implementation would be to forward to `serialize_unit`.
828     ///
829     /// ```edition2018
830     /// use serde::{Serialize, Serializer};
831     ///
832     /// struct Nothing;
833     ///
834     /// impl Serialize for Nothing {
835     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
836     ///     where
837     ///         S: Serializer,
838     ///     {
839     ///         serializer.serialize_unit_struct("Nothing")
840     ///     }
841     /// }
842     /// ```
serialize_unit_struct(self, name: &'static str) -> Result<Self::Ok, Self::Error>843     fn serialize_unit_struct(self, name: &'static str) -> Result<Self::Ok, Self::Error>;
844 
845     /// Serialize a unit variant like `E::A` in `enum E { A, B }`.
846     ///
847     /// The `name` is the name of the enum, the `variant_index` is the index of
848     /// this variant within the enum, and the `variant` is the name of the
849     /// variant.
850     ///
851     /// ```edition2018
852     /// use serde::{Serialize, Serializer};
853     ///
854     /// enum E {
855     ///     A,
856     ///     B,
857     /// }
858     ///
859     /// impl Serialize for E {
860     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
861     ///     where
862     ///         S: Serializer,
863     ///     {
864     ///         match *self {
865     ///             E::A => serializer.serialize_unit_variant("E", 0, "A"),
866     ///             E::B => serializer.serialize_unit_variant("E", 1, "B"),
867     ///         }
868     ///     }
869     /// }
870     /// ```
serialize_unit_variant( self, name: &'static str, variant_index: u32, variant: &'static str, ) -> Result<Self::Ok, Self::Error>871     fn serialize_unit_variant(
872         self,
873         name: &'static str,
874         variant_index: u32,
875         variant: &'static str,
876     ) -> Result<Self::Ok, Self::Error>;
877 
878     /// Serialize a newtype struct like `struct Millimeters(u8)`.
879     ///
880     /// Serializers are encouraged to treat newtype structs as insignificant
881     /// wrappers around the data they contain. A reasonable implementation would
882     /// be to forward to `value.serialize(self)`.
883     ///
884     /// ```edition2018
885     /// use serde::{Serialize, Serializer};
886     ///
887     /// struct Millimeters(u8);
888     ///
889     /// impl Serialize for Millimeters {
890     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
891     ///     where
892     ///         S: Serializer,
893     ///     {
894     ///         serializer.serialize_newtype_struct("Millimeters", &self.0)
895     ///     }
896     /// }
897     /// ```
serialize_newtype_struct<T: ?Sized>( self, name: &'static str, value: &T, ) -> Result<Self::Ok, Self::Error> where T: Serialize898     fn serialize_newtype_struct<T: ?Sized>(
899         self,
900         name: &'static str,
901         value: &T,
902     ) -> Result<Self::Ok, Self::Error>
903     where
904         T: Serialize;
905 
906     /// Serialize a newtype variant like `E::N` in `enum E { N(u8) }`.
907     ///
908     /// The `name` is the name of the enum, the `variant_index` is the index of
909     /// this variant within the enum, and the `variant` is the name of the
910     /// variant. The `value` is the data contained within this newtype variant.
911     ///
912     /// ```edition2018
913     /// use serde::{Serialize, Serializer};
914     ///
915     /// enum E {
916     ///     M(String),
917     ///     N(u8),
918     /// }
919     ///
920     /// impl Serialize for E {
921     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
922     ///     where
923     ///         S: Serializer,
924     ///     {
925     ///         match *self {
926     ///             E::M(ref s) => serializer.serialize_newtype_variant("E", 0, "M", s),
927     ///             E::N(n) => serializer.serialize_newtype_variant("E", 1, "N", &n),
928     ///         }
929     ///     }
930     /// }
931     /// ```
serialize_newtype_variant<T: ?Sized>( self, name: &'static str, variant_index: u32, variant: &'static str, value: &T, ) -> Result<Self::Ok, Self::Error> where T: Serialize932     fn serialize_newtype_variant<T: ?Sized>(
933         self,
934         name: &'static str,
935         variant_index: u32,
936         variant: &'static str,
937         value: &T,
938     ) -> Result<Self::Ok, Self::Error>
939     where
940         T: Serialize;
941 
942     /// Begin to serialize a variably sized sequence. This call must be
943     /// followed by zero or more calls to `serialize_element`, then a call to
944     /// `end`.
945     ///
946     /// The argument is the number of elements in the sequence, which may or may
947     /// not be computable before the sequence is iterated. Some serializers only
948     /// support sequences whose length is known up front.
949     ///
950     /// ```edition2018
951     /// # use std::marker::PhantomData;
952     /// #
953     /// # struct Vec<T>(PhantomData<T>);
954     /// #
955     /// # impl<T> Vec<T> {
956     /// #     fn len(&self) -> usize {
957     /// #         unimplemented!()
958     /// #     }
959     /// # }
960     /// #
961     /// # impl<'a, T> IntoIterator for &'a Vec<T> {
962     /// #     type Item = &'a T;
963     /// #     type IntoIter = Box<Iterator<Item = &'a T>>;
964     /// #
965     /// #     fn into_iter(self) -> Self::IntoIter {
966     /// #         unimplemented!()
967     /// #     }
968     /// # }
969     /// #
970     /// use serde::ser::{Serialize, Serializer, SerializeSeq};
971     ///
972     /// impl<T> Serialize for Vec<T>
973     /// where
974     ///     T: Serialize,
975     /// {
976     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
977     ///     where
978     ///         S: Serializer,
979     ///     {
980     ///         let mut seq = serializer.serialize_seq(Some(self.len()))?;
981     ///         for element in self {
982     ///             seq.serialize_element(element)?;
983     ///         }
984     ///         seq.end()
985     ///     }
986     /// }
987     /// ```
serialize_seq(self, len: Option<usize>) -> Result<Self::SerializeSeq, Self::Error>988     fn serialize_seq(self, len: Option<usize>) -> Result<Self::SerializeSeq, Self::Error>;
989 
990     /// Begin to serialize a statically sized sequence whose length will be
991     /// known at deserialization time without looking at the serialized data.
992     /// This call must be followed by zero or more calls to `serialize_element`,
993     /// then a call to `end`.
994     ///
995     /// ```edition2018
996     /// use serde::ser::{Serialize, Serializer, SerializeTuple};
997     ///
998     /// # mod fool {
999     /// #     trait Serialize {}
1000     /// impl<A, B, C> Serialize for (A, B, C)
1001     /// #     {}
1002     /// # }
1003     /// #
1004     /// # struct Tuple3<A, B, C>(A, B, C);
1005     /// #
1006     /// # impl<A, B, C> Serialize for Tuple3<A, B, C>
1007     /// where
1008     ///     A: Serialize,
1009     ///     B: Serialize,
1010     ///     C: Serialize,
1011     /// {
1012     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1013     ///     where
1014     ///         S: Serializer,
1015     ///     {
1016     ///         let mut tup = serializer.serialize_tuple(3)?;
1017     ///         tup.serialize_element(&self.0)?;
1018     ///         tup.serialize_element(&self.1)?;
1019     ///         tup.serialize_element(&self.2)?;
1020     ///         tup.end()
1021     ///     }
1022     /// }
1023     /// ```
1024     ///
1025     /// ```edition2018
1026     /// use serde::ser::{Serialize, SerializeTuple, Serializer};
1027     ///
1028     /// const VRAM_SIZE: usize = 386;
1029     /// struct Vram([u16; VRAM_SIZE]);
1030     ///
1031     /// impl Serialize for Vram {
1032     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1033     ///     where
1034     ///         S: Serializer,
1035     ///     {
1036     ///         let mut seq = serializer.serialize_tuple(VRAM_SIZE)?;
1037     ///         for element in &self.0[..] {
1038     ///             seq.serialize_element(element)?;
1039     ///         }
1040     ///         seq.end()
1041     ///     }
1042     /// }
1043     /// ```
serialize_tuple(self, len: usize) -> Result<Self::SerializeTuple, Self::Error>1044     fn serialize_tuple(self, len: usize) -> Result<Self::SerializeTuple, Self::Error>;
1045 
1046     /// Begin to serialize a tuple struct like `struct Rgb(u8, u8, u8)`. This
1047     /// call must be followed by zero or more calls to `serialize_field`, then a
1048     /// call to `end`.
1049     ///
1050     /// The `name` is the name of the tuple struct and the `len` is the number
1051     /// of data fields that will be serialized.
1052     ///
1053     /// ```edition2018
1054     /// use serde::ser::{Serialize, SerializeTupleStruct, Serializer};
1055     ///
1056     /// struct Rgb(u8, u8, u8);
1057     ///
1058     /// impl Serialize for Rgb {
1059     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1060     ///     where
1061     ///         S: Serializer,
1062     ///     {
1063     ///         let mut ts = serializer.serialize_tuple_struct("Rgb", 3)?;
1064     ///         ts.serialize_field(&self.0)?;
1065     ///         ts.serialize_field(&self.1)?;
1066     ///         ts.serialize_field(&self.2)?;
1067     ///         ts.end()
1068     ///     }
1069     /// }
1070     /// ```
serialize_tuple_struct( self, name: &'static str, len: usize, ) -> Result<Self::SerializeTupleStruct, Self::Error>1071     fn serialize_tuple_struct(
1072         self,
1073         name: &'static str,
1074         len: usize,
1075     ) -> Result<Self::SerializeTupleStruct, Self::Error>;
1076 
1077     /// Begin to serialize a tuple variant like `E::T` in `enum E { T(u8, u8)
1078     /// }`. This call must be followed by zero or more calls to
1079     /// `serialize_field`, then a call to `end`.
1080     ///
1081     /// The `name` is the name of the enum, the `variant_index` is the index of
1082     /// this variant within the enum, the `variant` is the name of the variant,
1083     /// and the `len` is the number of data fields that will be serialized.
1084     ///
1085     /// ```edition2018
1086     /// use serde::ser::{Serialize, SerializeTupleVariant, Serializer};
1087     ///
1088     /// enum E {
1089     ///     T(u8, u8),
1090     ///     U(String, u32, u32),
1091     /// }
1092     ///
1093     /// impl Serialize for E {
1094     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1095     ///     where
1096     ///         S: Serializer,
1097     ///     {
1098     ///         match *self {
1099     ///             E::T(ref a, ref b) => {
1100     ///                 let mut tv = serializer.serialize_tuple_variant("E", 0, "T", 2)?;
1101     ///                 tv.serialize_field(a)?;
1102     ///                 tv.serialize_field(b)?;
1103     ///                 tv.end()
1104     ///             }
1105     ///             E::U(ref a, ref b, ref c) => {
1106     ///                 let mut tv = serializer.serialize_tuple_variant("E", 1, "U", 3)?;
1107     ///                 tv.serialize_field(a)?;
1108     ///                 tv.serialize_field(b)?;
1109     ///                 tv.serialize_field(c)?;
1110     ///                 tv.end()
1111     ///             }
1112     ///         }
1113     ///     }
1114     /// }
1115     /// ```
serialize_tuple_variant( self, name: &'static str, variant_index: u32, variant: &'static str, len: usize, ) -> Result<Self::SerializeTupleVariant, Self::Error>1116     fn serialize_tuple_variant(
1117         self,
1118         name: &'static str,
1119         variant_index: u32,
1120         variant: &'static str,
1121         len: usize,
1122     ) -> Result<Self::SerializeTupleVariant, Self::Error>;
1123 
1124     /// Begin to serialize a map. This call must be followed by zero or more
1125     /// calls to `serialize_key` and `serialize_value`, then a call to `end`.
1126     ///
1127     /// The argument is the number of elements in the map, which may or may not
1128     /// be computable before the map is iterated. Some serializers only support
1129     /// maps whose length is known up front.
1130     ///
1131     /// ```edition2018
1132     /// # use std::marker::PhantomData;
1133     /// #
1134     /// # struct HashMap<K, V>(PhantomData<K>, PhantomData<V>);
1135     /// #
1136     /// # impl<K, V> HashMap<K, V> {
1137     /// #     fn len(&self) -> usize {
1138     /// #         unimplemented!()
1139     /// #     }
1140     /// # }
1141     /// #
1142     /// # impl<'a, K, V> IntoIterator for &'a HashMap<K, V> {
1143     /// #     type Item = (&'a K, &'a V);
1144     /// #     type IntoIter = Box<Iterator<Item = (&'a K, &'a V)>>;
1145     /// #
1146     /// #     fn into_iter(self) -> Self::IntoIter {
1147     /// #         unimplemented!()
1148     /// #     }
1149     /// # }
1150     /// #
1151     /// use serde::ser::{Serialize, Serializer, SerializeMap};
1152     ///
1153     /// impl<K, V> Serialize for HashMap<K, V>
1154     /// where
1155     ///     K: Serialize,
1156     ///     V: Serialize,
1157     /// {
1158     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1159     ///     where
1160     ///         S: Serializer,
1161     ///     {
1162     ///         let mut map = serializer.serialize_map(Some(self.len()))?;
1163     ///         for (k, v) in self {
1164     ///             map.serialize_entry(k, v)?;
1165     ///         }
1166     ///         map.end()
1167     ///     }
1168     /// }
1169     /// ```
serialize_map(self, len: Option<usize>) -> Result<Self::SerializeMap, Self::Error>1170     fn serialize_map(self, len: Option<usize>) -> Result<Self::SerializeMap, Self::Error>;
1171 
1172     /// Begin to serialize a struct like `struct Rgb { r: u8, g: u8, b: u8 }`.
1173     /// This call must be followed by zero or more calls to `serialize_field`,
1174     /// then a call to `end`.
1175     ///
1176     /// The `name` is the name of the struct and the `len` is the number of
1177     /// data fields that will be serialized.
1178     ///
1179     /// ```edition2018
1180     /// use serde::ser::{Serialize, SerializeStruct, Serializer};
1181     ///
1182     /// struct Rgb {
1183     ///     r: u8,
1184     ///     g: u8,
1185     ///     b: u8,
1186     /// }
1187     ///
1188     /// impl Serialize for Rgb {
1189     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1190     ///     where
1191     ///         S: Serializer,
1192     ///     {
1193     ///         let mut rgb = serializer.serialize_struct("Rgb", 3)?;
1194     ///         rgb.serialize_field("r", &self.r)?;
1195     ///         rgb.serialize_field("g", &self.g)?;
1196     ///         rgb.serialize_field("b", &self.b)?;
1197     ///         rgb.end()
1198     ///     }
1199     /// }
1200     /// ```
serialize_struct( self, name: &'static str, len: usize, ) -> Result<Self::SerializeStruct, Self::Error>1201     fn serialize_struct(
1202         self,
1203         name: &'static str,
1204         len: usize,
1205     ) -> Result<Self::SerializeStruct, Self::Error>;
1206 
1207     /// Begin to serialize a struct variant like `E::S` in `enum E { S { r: u8,
1208     /// g: u8, b: u8 } }`. This call must be followed by zero or more calls to
1209     /// `serialize_field`, then a call to `end`.
1210     ///
1211     /// The `name` is the name of the enum, the `variant_index` is the index of
1212     /// this variant within the enum, the `variant` is the name of the variant,
1213     /// and the `len` is the number of data fields that will be serialized.
1214     ///
1215     /// ```edition2018
1216     /// use serde::ser::{Serialize, SerializeStructVariant, Serializer};
1217     ///
1218     /// enum E {
1219     ///     S { r: u8, g: u8, b: u8 },
1220     /// }
1221     ///
1222     /// impl Serialize for E {
1223     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1224     ///     where
1225     ///         S: Serializer,
1226     ///     {
1227     ///         match *self {
1228     ///             E::S {
1229     ///                 ref r,
1230     ///                 ref g,
1231     ///                 ref b,
1232     ///             } => {
1233     ///                 let mut sv = serializer.serialize_struct_variant("E", 0, "S", 3)?;
1234     ///                 sv.serialize_field("r", r)?;
1235     ///                 sv.serialize_field("g", g)?;
1236     ///                 sv.serialize_field("b", b)?;
1237     ///                 sv.end()
1238     ///             }
1239     ///         }
1240     ///     }
1241     /// }
1242     /// ```
serialize_struct_variant( self, name: &'static str, variant_index: u32, variant: &'static str, len: usize, ) -> Result<Self::SerializeStructVariant, Self::Error>1243     fn serialize_struct_variant(
1244         self,
1245         name: &'static str,
1246         variant_index: u32,
1247         variant: &'static str,
1248         len: usize,
1249     ) -> Result<Self::SerializeStructVariant, Self::Error>;
1250 
1251     /// Collect an iterator as a sequence.
1252     ///
1253     /// The default implementation serializes each item yielded by the iterator
1254     /// using [`serialize_seq`]. Implementors should not need to override this
1255     /// method.
1256     ///
1257     /// ```edition2018
1258     /// use serde::{Serialize, Serializer};
1259     ///
1260     /// struct SecretlyOneHigher {
1261     ///     data: Vec<i32>,
1262     /// }
1263     ///
1264     /// impl Serialize for SecretlyOneHigher {
1265     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1266     ///     where
1267     ///         S: Serializer,
1268     ///     {
1269     ///         serializer.collect_seq(self.data.iter().map(|x| x + 1))
1270     ///     }
1271     /// }
1272     /// ```
1273     ///
1274     /// [`serialize_seq`]: #tymethod.serialize_seq
collect_seq<I>(self, iter: I) -> Result<Self::Ok, Self::Error> where I: IntoIterator, <I as IntoIterator>::Item: Serialize,1275     fn collect_seq<I>(self, iter: I) -> Result<Self::Ok, Self::Error>
1276     where
1277         I: IntoIterator,
1278         <I as IntoIterator>::Item: Serialize,
1279     {
1280         let iter = iter.into_iter();
1281         let mut serializer = try!(self.serialize_seq(iterator_len_hint(&iter)));
1282 
1283         #[cfg(not(no_iterator_try_fold))]
1284         {
1285             let mut iter = iter;
1286             try!(iter.try_for_each(|item| serializer.serialize_element(&item)));
1287         }
1288 
1289         #[cfg(no_iterator_try_fold)]
1290         {
1291             for item in iter {
1292                 try!(serializer.serialize_element(&item));
1293             }
1294         }
1295 
1296         serializer.end()
1297     }
1298 
1299     /// Collect an iterator as a map.
1300     ///
1301     /// The default implementation serializes each pair yielded by the iterator
1302     /// using [`serialize_map`]. Implementors should not need to override this
1303     /// method.
1304     ///
1305     /// ```edition2018
1306     /// use serde::{Serialize, Serializer};
1307     /// use std::collections::BTreeSet;
1308     ///
1309     /// struct MapToUnit {
1310     ///     keys: BTreeSet<i32>,
1311     /// }
1312     ///
1313     /// // Serializes as a map in which the values are all unit.
1314     /// impl Serialize for MapToUnit {
1315     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1316     ///     where
1317     ///         S: Serializer,
1318     ///     {
1319     ///         serializer.collect_map(self.keys.iter().map(|k| (k, ())))
1320     ///     }
1321     /// }
1322     /// ```
1323     ///
1324     /// [`serialize_map`]: #tymethod.serialize_map
collect_map<K, V, I>(self, iter: I) -> Result<Self::Ok, Self::Error> where K: Serialize, V: Serialize, I: IntoIterator<Item = (K, V)>,1325     fn collect_map<K, V, I>(self, iter: I) -> Result<Self::Ok, Self::Error>
1326     where
1327         K: Serialize,
1328         V: Serialize,
1329         I: IntoIterator<Item = (K, V)>,
1330     {
1331         let iter = iter.into_iter();
1332         let mut serializer = try!(self.serialize_map(iterator_len_hint(&iter)));
1333 
1334         #[cfg(not(no_iterator_try_fold))]
1335         {
1336             let mut iter = iter;
1337             try!(iter.try_for_each(|(key, value)| serializer.serialize_entry(&key, &value)));
1338         }
1339 
1340         #[cfg(no_iterator_try_fold)]
1341         {
1342             for (key, value) in iter {
1343                 try!(serializer.serialize_entry(&key, &value));
1344             }
1345         }
1346 
1347         serializer.end()
1348     }
1349 
1350     /// Serialize a string produced by an implementation of `Display`.
1351     ///
1352     /// The default implementation builds a heap-allocated [`String`] and
1353     /// delegates to [`serialize_str`]. Serializers are encouraged to provide a
1354     /// more efficient implementation if possible.
1355     ///
1356     /// ```edition2018
1357     /// # struct DateTime;
1358     /// #
1359     /// # impl DateTime {
1360     /// #     fn naive_local(&self) -> () { () }
1361     /// #     fn offset(&self) -> () { () }
1362     /// # }
1363     /// #
1364     /// use serde::{Serialize, Serializer};
1365     ///
1366     /// impl Serialize for DateTime {
1367     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1368     ///     where
1369     ///         S: Serializer,
1370     ///     {
1371     ///         serializer.collect_str(&format_args!("{:?}{:?}",
1372     ///                                              self.naive_local(),
1373     ///                                              self.offset()))
1374     ///     }
1375     /// }
1376     /// ```
1377     ///
1378     /// [`String`]: https://doc.rust-lang.org/std/string/struct.String.html
1379     /// [`serialize_str`]: #tymethod.serialize_str
1380     #[cfg(any(feature = "std", feature = "alloc"))]
collect_str<T: ?Sized>(self, value: &T) -> Result<Self::Ok, Self::Error> where T: Display,1381     fn collect_str<T: ?Sized>(self, value: &T) -> Result<Self::Ok, Self::Error>
1382     where
1383         T: Display,
1384     {
1385         self.serialize_str(&value.to_string())
1386     }
1387 
1388     /// Serialize a string produced by an implementation of `Display`.
1389     ///
1390     /// Serializers that use `no_std` are required to provide an implementation
1391     /// of this method. If no more sensible behavior is possible, the
1392     /// implementation is expected to return an error.
1393     ///
1394     /// ```edition2018
1395     /// # struct DateTime;
1396     /// #
1397     /// # impl DateTime {
1398     /// #     fn naive_local(&self) -> () { () }
1399     /// #     fn offset(&self) -> () { () }
1400     /// # }
1401     /// #
1402     /// use serde::{Serialize, Serializer};
1403     ///
1404     /// impl Serialize for DateTime {
1405     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1406     ///     where
1407     ///         S: Serializer,
1408     ///     {
1409     ///         serializer.collect_str(&format_args!("{:?}{:?}",
1410     ///                                              self.naive_local(),
1411     ///                                              self.offset()))
1412     ///     }
1413     /// }
1414     /// ```
1415     #[cfg(not(any(feature = "std", feature = "alloc")))]
collect_str<T: ?Sized>(self, value: &T) -> Result<Self::Ok, Self::Error> where T: Display1416     fn collect_str<T: ?Sized>(self, value: &T) -> Result<Self::Ok, Self::Error>
1417     where
1418         T: Display;
1419 
1420     /// Determine whether `Serialize` implementations should serialize in
1421     /// human-readable form.
1422     ///
1423     /// Some types have a human-readable form that may be somewhat expensive to
1424     /// construct, as well as a binary form that is compact and efficient.
1425     /// Generally text-based formats like JSON and YAML will prefer to use the
1426     /// human-readable one and binary formats like Bincode will prefer the
1427     /// compact one.
1428     ///
1429     /// ```edition2018
1430     /// # use std::fmt::{self, Display};
1431     /// #
1432     /// # struct Timestamp;
1433     /// #
1434     /// # impl Timestamp {
1435     /// #     fn seconds_since_epoch(&self) -> u64 { unimplemented!() }
1436     /// # }
1437     /// #
1438     /// # impl Display for Timestamp {
1439     /// #     fn fmt(&self, formatter: &mut fmt::Formatter) -> fmt::Result {
1440     /// #         unimplemented!()
1441     /// #     }
1442     /// # }
1443     /// #
1444     /// use serde::{Serialize, Serializer};
1445     ///
1446     /// impl Serialize for Timestamp {
1447     ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1448     ///     where
1449     ///         S: Serializer,
1450     ///     {
1451     ///         if serializer.is_human_readable() {
1452     ///             // Serialize to a human-readable string "2015-05-15T17:01:00Z".
1453     ///             self.to_string().serialize(serializer)
1454     ///         } else {
1455     ///             // Serialize to a compact binary representation.
1456     ///             self.seconds_since_epoch().serialize(serializer)
1457     ///         }
1458     ///     }
1459     /// }
1460     /// ```
1461     ///
1462     /// The default implementation of this method returns `true`. Data formats
1463     /// may override this to `false` to request a compact form for types that
1464     /// support one. Note that modifying this method to change a format from
1465     /// human-readable to compact or vice versa should be regarded as a breaking
1466     /// change, as a value serialized in human-readable mode is not required to
1467     /// deserialize from the same data in compact mode.
1468     #[inline]
is_human_readable(&self) -> bool1469     fn is_human_readable(&self) -> bool {
1470         true
1471     }
1472 }
1473 
1474 /// Returned from `Serializer::serialize_seq`.
1475 ///
1476 /// # Example use
1477 ///
1478 /// ```edition2018
1479 /// # use std::marker::PhantomData;
1480 /// #
1481 /// # struct Vec<T>(PhantomData<T>);
1482 /// #
1483 /// # impl<T> Vec<T> {
1484 /// #     fn len(&self) -> usize {
1485 /// #         unimplemented!()
1486 /// #     }
1487 /// # }
1488 /// #
1489 /// # impl<'a, T> IntoIterator for &'a Vec<T> {
1490 /// #     type Item = &'a T;
1491 /// #     type IntoIter = Box<Iterator<Item = &'a T>>;
1492 /// #     fn into_iter(self) -> Self::IntoIter {
1493 /// #         unimplemented!()
1494 /// #     }
1495 /// # }
1496 /// #
1497 /// use serde::ser::{Serialize, Serializer, SerializeSeq};
1498 ///
1499 /// impl<T> Serialize for Vec<T>
1500 /// where
1501 ///     T: Serialize,
1502 /// {
1503 ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1504 ///     where
1505 ///         S: Serializer,
1506 ///     {
1507 ///         let mut seq = serializer.serialize_seq(Some(self.len()))?;
1508 ///         for element in self {
1509 ///             seq.serialize_element(element)?;
1510 ///         }
1511 ///         seq.end()
1512 ///     }
1513 /// }
1514 /// ```
1515 ///
1516 /// # Example implementation
1517 ///
1518 /// The [example data format] presented on the website demonstrates an
1519 /// implementation of `SerializeSeq` for a basic JSON data format.
1520 ///
1521 /// [example data format]: https://serde.rs/data-format.html
1522 pub trait SerializeSeq {
1523     /// Must match the `Ok` type of our `Serializer`.
1524     type Ok;
1525 
1526     /// Must match the `Error` type of our `Serializer`.
1527     type Error: Error;
1528 
1529     /// Serialize a sequence element.
serialize_element<T: ?Sized>(&mut self, value: &T) -> Result<(), Self::Error> where T: Serialize1530     fn serialize_element<T: ?Sized>(&mut self, value: &T) -> Result<(), Self::Error>
1531     where
1532         T: Serialize;
1533 
1534     /// Finish serializing a sequence.
end(self) -> Result<Self::Ok, Self::Error>1535     fn end(self) -> Result<Self::Ok, Self::Error>;
1536 }
1537 
1538 /// Returned from `Serializer::serialize_tuple`.
1539 ///
1540 /// # Example use
1541 ///
1542 /// ```edition2018
1543 /// use serde::ser::{Serialize, Serializer, SerializeTuple};
1544 ///
1545 /// # mod fool {
1546 /// #     trait Serialize {}
1547 /// impl<A, B, C> Serialize for (A, B, C)
1548 /// #     {}
1549 /// # }
1550 /// #
1551 /// # struct Tuple3<A, B, C>(A, B, C);
1552 /// #
1553 /// # impl<A, B, C> Serialize for Tuple3<A, B, C>
1554 /// where
1555 ///     A: Serialize,
1556 ///     B: Serialize,
1557 ///     C: Serialize,
1558 /// {
1559 ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1560 ///     where
1561 ///         S: Serializer,
1562 ///     {
1563 ///         let mut tup = serializer.serialize_tuple(3)?;
1564 ///         tup.serialize_element(&self.0)?;
1565 ///         tup.serialize_element(&self.1)?;
1566 ///         tup.serialize_element(&self.2)?;
1567 ///         tup.end()
1568 ///     }
1569 /// }
1570 /// ```
1571 ///
1572 /// ```edition2018
1573 /// # use std::marker::PhantomData;
1574 /// #
1575 /// # struct Array<T>(PhantomData<T>);
1576 /// #
1577 /// # impl<T> Array<T> {
1578 /// #     fn len(&self) -> usize {
1579 /// #         unimplemented!()
1580 /// #     }
1581 /// # }
1582 /// #
1583 /// # impl<'a, T> IntoIterator for &'a Array<T> {
1584 /// #     type Item = &'a T;
1585 /// #     type IntoIter = Box<Iterator<Item = &'a T>>;
1586 /// #     fn into_iter(self) -> Self::IntoIter {
1587 /// #         unimplemented!()
1588 /// #     }
1589 /// # }
1590 /// #
1591 /// use serde::ser::{Serialize, Serializer, SerializeTuple};
1592 ///
1593 /// # mod fool {
1594 /// #     trait Serialize {}
1595 /// impl<T> Serialize for [T; 16]
1596 /// #     {}
1597 /// # }
1598 /// #
1599 /// # impl<T> Serialize for Array<T>
1600 /// where
1601 ///     T: Serialize,
1602 /// {
1603 ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1604 ///     where
1605 ///         S: Serializer,
1606 ///     {
1607 ///         let mut seq = serializer.serialize_tuple(16)?;
1608 ///         for element in self {
1609 ///             seq.serialize_element(element)?;
1610 ///         }
1611 ///         seq.end()
1612 ///     }
1613 /// }
1614 /// ```
1615 ///
1616 /// # Example implementation
1617 ///
1618 /// The [example data format] presented on the website demonstrates an
1619 /// implementation of `SerializeTuple` for a basic JSON data format.
1620 ///
1621 /// [example data format]: https://serde.rs/data-format.html
1622 pub trait SerializeTuple {
1623     /// Must match the `Ok` type of our `Serializer`.
1624     type Ok;
1625 
1626     /// Must match the `Error` type of our `Serializer`.
1627     type Error: Error;
1628 
1629     /// Serialize a tuple element.
serialize_element<T: ?Sized>(&mut self, value: &T) -> Result<(), Self::Error> where T: Serialize1630     fn serialize_element<T: ?Sized>(&mut self, value: &T) -> Result<(), Self::Error>
1631     where
1632         T: Serialize;
1633 
1634     /// Finish serializing a tuple.
end(self) -> Result<Self::Ok, Self::Error>1635     fn end(self) -> Result<Self::Ok, Self::Error>;
1636 }
1637 
1638 /// Returned from `Serializer::serialize_tuple_struct`.
1639 ///
1640 /// # Example use
1641 ///
1642 /// ```edition2018
1643 /// use serde::ser::{Serialize, SerializeTupleStruct, Serializer};
1644 ///
1645 /// struct Rgb(u8, u8, u8);
1646 ///
1647 /// impl Serialize for Rgb {
1648 ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1649 ///     where
1650 ///         S: Serializer,
1651 ///     {
1652 ///         let mut ts = serializer.serialize_tuple_struct("Rgb", 3)?;
1653 ///         ts.serialize_field(&self.0)?;
1654 ///         ts.serialize_field(&self.1)?;
1655 ///         ts.serialize_field(&self.2)?;
1656 ///         ts.end()
1657 ///     }
1658 /// }
1659 /// ```
1660 ///
1661 /// # Example implementation
1662 ///
1663 /// The [example data format] presented on the website demonstrates an
1664 /// implementation of `SerializeTupleStruct` for a basic JSON data format.
1665 ///
1666 /// [example data format]: https://serde.rs/data-format.html
1667 pub trait SerializeTupleStruct {
1668     /// Must match the `Ok` type of our `Serializer`.
1669     type Ok;
1670 
1671     /// Must match the `Error` type of our `Serializer`.
1672     type Error: Error;
1673 
1674     /// Serialize a tuple struct field.
serialize_field<T: ?Sized>(&mut self, value: &T) -> Result<(), Self::Error> where T: Serialize1675     fn serialize_field<T: ?Sized>(&mut self, value: &T) -> Result<(), Self::Error>
1676     where
1677         T: Serialize;
1678 
1679     /// Finish serializing a tuple struct.
end(self) -> Result<Self::Ok, Self::Error>1680     fn end(self) -> Result<Self::Ok, Self::Error>;
1681 }
1682 
1683 /// Returned from `Serializer::serialize_tuple_variant`.
1684 ///
1685 /// # Example use
1686 ///
1687 /// ```edition2018
1688 /// use serde::ser::{Serialize, SerializeTupleVariant, Serializer};
1689 ///
1690 /// enum E {
1691 ///     T(u8, u8),
1692 ///     U(String, u32, u32),
1693 /// }
1694 ///
1695 /// impl Serialize for E {
1696 ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1697 ///     where
1698 ///         S: Serializer,
1699 ///     {
1700 ///         match *self {
1701 ///             E::T(ref a, ref b) => {
1702 ///                 let mut tv = serializer.serialize_tuple_variant("E", 0, "T", 2)?;
1703 ///                 tv.serialize_field(a)?;
1704 ///                 tv.serialize_field(b)?;
1705 ///                 tv.end()
1706 ///             }
1707 ///             E::U(ref a, ref b, ref c) => {
1708 ///                 let mut tv = serializer.serialize_tuple_variant("E", 1, "U", 3)?;
1709 ///                 tv.serialize_field(a)?;
1710 ///                 tv.serialize_field(b)?;
1711 ///                 tv.serialize_field(c)?;
1712 ///                 tv.end()
1713 ///             }
1714 ///         }
1715 ///     }
1716 /// }
1717 /// ```
1718 ///
1719 /// # Example implementation
1720 ///
1721 /// The [example data format] presented on the website demonstrates an
1722 /// implementation of `SerializeTupleVariant` for a basic JSON data format.
1723 ///
1724 /// [example data format]: https://serde.rs/data-format.html
1725 pub trait SerializeTupleVariant {
1726     /// Must match the `Ok` type of our `Serializer`.
1727     type Ok;
1728 
1729     /// Must match the `Error` type of our `Serializer`.
1730     type Error: Error;
1731 
1732     /// Serialize a tuple variant field.
serialize_field<T: ?Sized>(&mut self, value: &T) -> Result<(), Self::Error> where T: Serialize1733     fn serialize_field<T: ?Sized>(&mut self, value: &T) -> Result<(), Self::Error>
1734     where
1735         T: Serialize;
1736 
1737     /// Finish serializing a tuple variant.
end(self) -> Result<Self::Ok, Self::Error>1738     fn end(self) -> Result<Self::Ok, Self::Error>;
1739 }
1740 
1741 /// Returned from `Serializer::serialize_map`.
1742 ///
1743 /// # Example use
1744 ///
1745 /// ```edition2018
1746 /// # use std::marker::PhantomData;
1747 /// #
1748 /// # struct HashMap<K, V>(PhantomData<K>, PhantomData<V>);
1749 /// #
1750 /// # impl<K, V> HashMap<K, V> {
1751 /// #     fn len(&self) -> usize {
1752 /// #         unimplemented!()
1753 /// #     }
1754 /// # }
1755 /// #
1756 /// # impl<'a, K, V> IntoIterator for &'a HashMap<K, V> {
1757 /// #     type Item = (&'a K, &'a V);
1758 /// #     type IntoIter = Box<Iterator<Item = (&'a K, &'a V)>>;
1759 /// #
1760 /// #     fn into_iter(self) -> Self::IntoIter {
1761 /// #         unimplemented!()
1762 /// #     }
1763 /// # }
1764 /// #
1765 /// use serde::ser::{Serialize, Serializer, SerializeMap};
1766 ///
1767 /// impl<K, V> Serialize for HashMap<K, V>
1768 /// where
1769 ///     K: Serialize,
1770 ///     V: Serialize,
1771 /// {
1772 ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1773 ///     where
1774 ///         S: Serializer,
1775 ///     {
1776 ///         let mut map = serializer.serialize_map(Some(self.len()))?;
1777 ///         for (k, v) in self {
1778 ///             map.serialize_entry(k, v)?;
1779 ///         }
1780 ///         map.end()
1781 ///     }
1782 /// }
1783 /// ```
1784 ///
1785 /// # Example implementation
1786 ///
1787 /// The [example data format] presented on the website demonstrates an
1788 /// implementation of `SerializeMap` for a basic JSON data format.
1789 ///
1790 /// [example data format]: https://serde.rs/data-format.html
1791 pub trait SerializeMap {
1792     /// Must match the `Ok` type of our `Serializer`.
1793     type Ok;
1794 
1795     /// Must match the `Error` type of our `Serializer`.
1796     type Error: Error;
1797 
1798     /// Serialize a map key.
1799     ///
1800     /// If possible, `Serialize` implementations are encouraged to use
1801     /// `serialize_entry` instead as it may be implemented more efficiently in
1802     /// some formats compared to a pair of calls to `serialize_key` and
1803     /// `serialize_value`.
serialize_key<T: ?Sized>(&mut self, key: &T) -> Result<(), Self::Error> where T: Serialize1804     fn serialize_key<T: ?Sized>(&mut self, key: &T) -> Result<(), Self::Error>
1805     where
1806         T: Serialize;
1807 
1808     /// Serialize a map value.
1809     ///
1810     /// # Panics
1811     ///
1812     /// Calling `serialize_value` before `serialize_key` is incorrect and is
1813     /// allowed to panic or produce bogus results.
serialize_value<T: ?Sized>(&mut self, value: &T) -> Result<(), Self::Error> where T: Serialize1814     fn serialize_value<T: ?Sized>(&mut self, value: &T) -> Result<(), Self::Error>
1815     where
1816         T: Serialize;
1817 
1818     /// Serialize a map entry consisting of a key and a value.
1819     ///
1820     /// Some [`Serialize`] types are not able to hold a key and value in memory
1821     /// at the same time so `SerializeMap` implementations are required to
1822     /// support [`serialize_key`] and [`serialize_value`] individually. The
1823     /// `serialize_entry` method allows serializers to optimize for the case
1824     /// where key and value are both available. [`Serialize`] implementations
1825     /// are encouraged to use `serialize_entry` if possible.
1826     ///
1827     /// The default implementation delegates to [`serialize_key`] and
1828     /// [`serialize_value`]. This is appropriate for serializers that do not
1829     /// care about performance or are not able to optimize `serialize_entry` any
1830     /// better than this.
1831     ///
1832     /// [`Serialize`]: ../trait.Serialize.html
1833     /// [`serialize_key`]: #tymethod.serialize_key
1834     /// [`serialize_value`]: #tymethod.serialize_value
serialize_entry<K: ?Sized, V: ?Sized>( &mut self, key: &K, value: &V, ) -> Result<(), Self::Error> where K: Serialize, V: Serialize,1835     fn serialize_entry<K: ?Sized, V: ?Sized>(
1836         &mut self,
1837         key: &K,
1838         value: &V,
1839     ) -> Result<(), Self::Error>
1840     where
1841         K: Serialize,
1842         V: Serialize,
1843     {
1844         try!(self.serialize_key(key));
1845         self.serialize_value(value)
1846     }
1847 
1848     /// Finish serializing a map.
end(self) -> Result<Self::Ok, Self::Error>1849     fn end(self) -> Result<Self::Ok, Self::Error>;
1850 }
1851 
1852 /// Returned from `Serializer::serialize_struct`.
1853 ///
1854 /// # Example use
1855 ///
1856 /// ```edition2018
1857 /// use serde::ser::{Serialize, SerializeStruct, Serializer};
1858 ///
1859 /// struct Rgb {
1860 ///     r: u8,
1861 ///     g: u8,
1862 ///     b: u8,
1863 /// }
1864 ///
1865 /// impl Serialize for Rgb {
1866 ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1867 ///     where
1868 ///         S: Serializer,
1869 ///     {
1870 ///         let mut rgb = serializer.serialize_struct("Rgb", 3)?;
1871 ///         rgb.serialize_field("r", &self.r)?;
1872 ///         rgb.serialize_field("g", &self.g)?;
1873 ///         rgb.serialize_field("b", &self.b)?;
1874 ///         rgb.end()
1875 ///     }
1876 /// }
1877 /// ```
1878 ///
1879 /// # Example implementation
1880 ///
1881 /// The [example data format] presented on the website demonstrates an
1882 /// implementation of `SerializeStruct` for a basic JSON data format.
1883 ///
1884 /// [example data format]: https://serde.rs/data-format.html
1885 pub trait SerializeStruct {
1886     /// Must match the `Ok` type of our `Serializer`.
1887     type Ok;
1888 
1889     /// Must match the `Error` type of our `Serializer`.
1890     type Error: Error;
1891 
1892     /// Serialize a struct field.
serialize_field<T: ?Sized>( &mut self, key: &'static str, value: &T, ) -> Result<(), Self::Error> where T: Serialize1893     fn serialize_field<T: ?Sized>(
1894         &mut self,
1895         key: &'static str,
1896         value: &T,
1897     ) -> Result<(), Self::Error>
1898     where
1899         T: Serialize;
1900 
1901     /// Indicate that a struct field has been skipped.
1902     #[inline]
skip_field(&mut self, key: &'static str) -> Result<(), Self::Error>1903     fn skip_field(&mut self, key: &'static str) -> Result<(), Self::Error> {
1904         let _ = key;
1905         Ok(())
1906     }
1907 
1908     /// Finish serializing a struct.
end(self) -> Result<Self::Ok, Self::Error>1909     fn end(self) -> Result<Self::Ok, Self::Error>;
1910 }
1911 
1912 /// Returned from `Serializer::serialize_struct_variant`.
1913 ///
1914 /// # Example use
1915 ///
1916 /// ```edition2018
1917 /// use serde::ser::{Serialize, SerializeStructVariant, Serializer};
1918 ///
1919 /// enum E {
1920 ///     S { r: u8, g: u8, b: u8 },
1921 /// }
1922 ///
1923 /// impl Serialize for E {
1924 ///     fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
1925 ///     where
1926 ///         S: Serializer,
1927 ///     {
1928 ///         match *self {
1929 ///             E::S {
1930 ///                 ref r,
1931 ///                 ref g,
1932 ///                 ref b,
1933 ///             } => {
1934 ///                 let mut sv = serializer.serialize_struct_variant("E", 0, "S", 3)?;
1935 ///                 sv.serialize_field("r", r)?;
1936 ///                 sv.serialize_field("g", g)?;
1937 ///                 sv.serialize_field("b", b)?;
1938 ///                 sv.end()
1939 ///             }
1940 ///         }
1941 ///     }
1942 /// }
1943 /// ```
1944 ///
1945 /// # Example implementation
1946 ///
1947 /// The [example data format] presented on the website demonstrates an
1948 /// implementation of `SerializeStructVariant` for a basic JSON data format.
1949 ///
1950 /// [example data format]: https://serde.rs/data-format.html
1951 pub trait SerializeStructVariant {
1952     /// Must match the `Ok` type of our `Serializer`.
1953     type Ok;
1954 
1955     /// Must match the `Error` type of our `Serializer`.
1956     type Error: Error;
1957 
1958     /// Serialize a struct variant field.
serialize_field<T: ?Sized>( &mut self, key: &'static str, value: &T, ) -> Result<(), Self::Error> where T: Serialize1959     fn serialize_field<T: ?Sized>(
1960         &mut self,
1961         key: &'static str,
1962         value: &T,
1963     ) -> Result<(), Self::Error>
1964     where
1965         T: Serialize;
1966 
1967     /// Indicate that a struct variant field has been skipped.
1968     #[inline]
skip_field(&mut self, key: &'static str) -> Result<(), Self::Error>1969     fn skip_field(&mut self, key: &'static str) -> Result<(), Self::Error> {
1970         let _ = key;
1971         Ok(())
1972     }
1973 
1974     /// Finish serializing a struct variant.
end(self) -> Result<Self::Ok, Self::Error>1975     fn end(self) -> Result<Self::Ok, Self::Error>;
1976 }
1977 
iterator_len_hint<I>(iter: &I) -> Option<usize> where I: Iterator,1978 fn iterator_len_hint<I>(iter: &I) -> Option<usize>
1979 where
1980     I: Iterator,
1981 {
1982     match iter.size_hint() {
1983         (lo, Some(hi)) if lo == hi => Some(lo),
1984         _ => None,
1985     }
1986 }
1987