{-# LANGUAGE FlexibleContexts #-} {-# LANGUAGE FlexibleInstances #-} {-# LANGUAGE MultiParamTypeClasses #-} {-# LANGUAGE PatternSynonyms #-} {-# LANGUAGE TypeFamilies #-} {-# OPTIONS_GHC -fno-warn-orphans #-} module Language.Symantic.Type.Ordering where import qualified Data.MonoTraversable as MT import Data.Proxy import Language.Symantic.Type.Root import Language.Symantic.Type.Type0 -- * Type 'Type_Ordering' -- | The 'Ordering' type. type Type_Ordering = Type_Type0 (Proxy Ordering) pattern Type_Ordering :: Type_Ordering root Ordering pattern Type_Ordering = Type_Type0 Proxy instance Constraint_Type Eq (Type_Ordering root) where constraint_type _c Type_Type0{} = Just Dict instance Constraint_Type Ord (Type_Ordering root) where constraint_type _c Type_Type0{} = Just Dict instance Constraint_Type Monoid (Type_Ordering root) instance Constraint_Type Num (Type_Ordering root) instance Constraint_Type Integral (Type_Ordering root) instance Constraint_Type MT.MonoFunctor (Type_Ordering root) instance String_from_Type (Type_Ordering root) where string_from_type _ = "Ordering" -- | Inject 'Type_Ordering' within a root type. type_ordering :: Lift_Type_Root Type_Ordering root => root Ordering type_ordering = type_type0