From 8c1565d4d58c7a7d604d7e4303f7aafb1a2d97f9 Mon Sep 17 00:00:00 2001 From: Jack Wrenn Date: Fri, 17 May 2024 19:08:10 +0000 Subject: [PATCH] Make `ConvertError` and variants public This permits matching on the error variant, and ensures that the variants are rendered in rustdoc. Makes progress on #1139. --- src/error.rs | 68 ++++++++++++++++++++++------------------------------ 1 file changed, 28 insertions(+), 40 deletions(-) diff --git a/src/error.rs b/src/error.rs index 17a7078584..fff9e4d36e 100644 --- a/src/error.rs +++ b/src/error.rs @@ -29,48 +29,36 @@ use crate::TryFromBytes; #[cfg(doc)] use crate::{FromBytes, Ref}; -// This is private to remove `ConvertError` from our SemVer obligations for the -// time being. -// TODO(#1139): Remove this wrapping `private` module. -mod private { - #[cfg(doc)] - use super::*; - - /// Zerocopy's generic error type. - /// - /// Generally speaking, zerocopy's conversions may fail for one of up to three reasons: - /// - [`AlignmentError`]: the conversion source was improperly aligned - /// - [`SizeError`]: the conversion source was of incorrect size - /// - [`ValidityError`]: the conversion source contained invalid data - /// - /// However, not all conversions produce all errors. For instance, - /// [`FromBytes::ref_from_bytes`] may fail due to alignment or size issues, - /// but not validity issues. This generic error type captures these - /// (im)possibilities via parameterization: `A` is parameterized with - /// [`AlignmentError`], `S` is parameterized with [`SizeError`], and `V` is - /// parameterized with [`Infallible`]. - /// - /// Zerocopy never uses this type directly in its API. Rather, we provide three - /// pre-parameterized aliases: - /// - [`CastError`]: the error type of reference conversions - /// - [`TryCastError`]: the error type of fallible reference conversions - /// - [`TryReadError`]: the error type of fallible read conversions - #[derive(PartialEq, Eq)] - pub enum ConvertError { - /// The conversion source was improperly aligned. - #[doc(hidden)] - Alignment(A), - /// The conversion source was of incorrect size. - #[doc(hidden)] - Size(S), - /// The conversion source contained invalid data. - #[doc(hidden)] - Validity(V), - } +/// Zerocopy's generic error type. +/// +/// Generally speaking, zerocopy's conversions may fail for one of up to three +/// reasons: +/// - [`AlignmentError`]: the conversion source was improperly aligned +/// - [`SizeError`]: the conversion source was of incorrect size +/// - [`ValidityError`]: the conversion source contained invalid data +/// +/// However, not all conversions produce all errors. For instance, +/// [`FromBytes::ref_from_bytes`] may fail due to alignment or size issues, but +/// not validity issues. This generic error type captures these +/// (im)possibilities via parameterization: `A` is parameterized with +/// [`AlignmentError`], `S` is parameterized with [`SizeError`], and `V` is +/// parameterized with [`Infallible`]. +/// +/// Zerocopy never uses this type directly in its API. Rather, we provide three +/// pre-parameterized aliases: +/// - [`CastError`]: the error type of reference conversions +/// - [`TryCastError`]: the error type of fallible reference conversions +/// - [`TryReadError`]: the error type of fallible read conversions +#[derive(PartialEq, Eq)] +pub enum ConvertError { + /// The conversion source was improperly aligned. + Alignment(A), + /// The conversion source was of incorrect size. + Size(S), + /// The conversion source contained invalid data. + Validity(V), } -use private::ConvertError; - impl fmt::Debug for ConvertError { #[inline] fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {