diff --git a/src/valid/handles.rs b/src/valid/handles.rs index da95f60842..6868d14494 100644 --- a/src/valid/handles.rs +++ b/src/valid/handles.rs @@ -4,17 +4,10 @@ use crate::{ arena::{BadHandle, BadRangeError}, Handle, }; - -#[cfg(feature = "validate")] use crate::{Arena, UniqueArena}; - -#[cfg(feature = "validate")] -use super::ValidationError; - -#[cfg(feature = "validate")] +use super::{ValidationError, InvalidHandleError, FwdDepError}; use std::{convert::TryInto, hash::Hash, num::NonZeroU32}; -#[cfg(feature = "validate")] impl super::Validator { /// Validates that all handles within `module` are: /// @@ -547,52 +540,24 @@ impl super::Validator { } } -#[cfg(feature = "validate")] impl From for ValidationError { fn from(source: BadHandle) -> Self { Self::InvalidHandle(source.into()) } } -#[cfg(feature = "validate")] impl From for ValidationError { fn from(source: FwdDepError) -> Self { Self::InvalidHandle(source.into()) } } -#[cfg(feature = "validate")] impl From for ValidationError { fn from(source: BadRangeError) -> Self { Self::InvalidHandle(source.into()) } } -#[derive(Clone, Debug, thiserror::Error)] -pub enum InvalidHandleError { - #[error(transparent)] - BadHandle(#[from] BadHandle), - #[error(transparent)] - ForwardDependency(#[from] FwdDepError), - #[error(transparent)] - BadRange(#[from] BadRangeError), -} - -#[derive(Clone, Debug, thiserror::Error)] -#[error( - "{subject:?} of kind {subject_kind:?} depends on {depends_on:?} of kind {depends_on_kind}, \ - which has not been processed yet" -)] -pub struct FwdDepError { - // This error is used for many `Handle` types, but there's no point in making this generic, so - // we just flatten them all to `Handle<()>` here. - subject: Handle<()>, - subject_kind: &'static str, - depends_on: Handle<()>, - depends_on_kind: &'static str, -} - -#[cfg(feature = "validate")] impl Handle { /// Check that `self` is valid within `arena` using [`Arena::check_contains_handle`]. pub(self) fn check_valid_for(self, arena: &Arena) -> Result<(), InvalidHandleError> { @@ -656,7 +621,6 @@ impl Handle { } } -#[cfg(feature = "validate")] impl crate::arena::Range { pub(self) fn check_valid_for(&self, arena: &Arena) -> Result<(), BadRangeError> { arena.check_contains_range(self) @@ -664,7 +628,6 @@ impl crate::arena::Range { } #[test] -#[cfg(feature = "validate")] fn constant_deps() { use crate::{Constant, Expression, Literal, Span, Type, TypeInner}; diff --git a/src/valid/mod.rs b/src/valid/mod.rs index 5351287725..fb7fb16f2f 100644 --- a/src/valid/mod.rs +++ b/src/valid/mod.rs @@ -6,6 +6,7 @@ mod analyzer; mod compose; mod expression; mod function; +#[cfg(feature = "validate")] mod handles; mod interface; mod r#type; @@ -29,7 +30,29 @@ pub use function::{CallError, FunctionError, LocalVariableError}; pub use interface::{EntryPointError, GlobalVariableError, VaryingError}; pub use r#type::{Disalignment, TypeError, TypeFlags}; -use self::handles::InvalidHandleError; +#[derive(Clone, Debug, thiserror::Error)] +pub enum InvalidHandleError { + #[error(transparent)] + BadHandle(#[from] crate::arena::BadHandle), + #[error(transparent)] + ForwardDependency(#[from] FwdDepError), + #[error(transparent)] + BadRange(#[from] crate::arena::BadRangeError), +} + +#[derive(Clone, Debug, thiserror::Error)] +#[error( + "{subject:?} of kind {subject_kind:?} depends on {depends_on:?} of kind {depends_on_kind}, \ + which has not been processed yet" +)] +pub struct FwdDepError { + // This error is used for many `Handle` types, but there's no point in making this generic, so + // we just flatten them all to `Handle<()>` here. + subject: Handle<()>, + subject_kind: &'static str, + depends_on: Handle<()>, + depends_on_kind: &'static str, +} bitflags::bitflags! { /// Validation flags.