{-# LANGUAGE ScopedTypeVariables, DeriveDataTypeable, OverloadedStrings, DeriveGeneric #-} module Data.Bond.Schema.FieldDef (FieldDef(..)) where import qualified Data.Bond.Internal.Imports as B' import qualified Prelude as P' import qualified Data.Bond.Schema.Metadata import qualified Data.Bond.Schema.TypeDef import qualified GHC.Generics as P' data FieldDef = FieldDef{metadata :: Data.Bond.Schema.Metadata.Metadata, id :: B'.Word16, typedef :: Data.Bond.Schema.TypeDef.TypeDef} deriving (P'.Generic, P'.Show, P'.Eq, B'.Typeable) instance B'.Default FieldDef where defaultValue = FieldDef{metadata = B'.defaultValue, id = B'.defaultValue, typedef = B'.defaultValue} instance B'.BondType FieldDef where bondGet = B'.bondGetStruct bondPut = B'.bondPutStruct getName _ = "FieldDef" getQualifiedName _ = "bond.FieldDef" getElementType type'proxy = B'.ElementStruct (B'.getSchema type'proxy) instance B'.BondStruct FieldDef where bondStructPut self' = do B'.bondPutField (B'.Proxy :: B'.Proxy FieldDef) (B'.Ordinal 0) (metadata self') B'.bondPutField (B'.Proxy :: B'.Proxy FieldDef) (B'.Ordinal 1) (id self') B'.bondPutField (B'.Proxy :: B'.Proxy FieldDef) (B'.Ordinal 2) (typedef self') bondStructGetUntagged = P'.return FieldDef `B'.ap` B'.bondGet `B'.ap` B'.bondGet `B'.ap` B'.bondGet bondStructGetBase self' = P'.return self' bondStructGetField (B'.Ordinal 0) self' = do field'val <- B'.bondGet P'.return self'{metadata = field'val} bondStructGetField (B'.Ordinal 1) self' = do field'val <- B'.bondGet P'.return self'{id = field'val} bondStructGetField (B'.Ordinal 2) self' = do field'val <- B'.bondGet P'.return self'{typedef = field'val} bondStructGetField _ _ = P'.error "unknown field ordinal" getSchema type'proxy = B'.StructSchema{B'.structTag = B'.typeRep type'proxy, B'.structName = B'.getName type'proxy, B'.structQualifiedName = B'.getQualifiedName type'proxy, B'.structAttrs = B'.makeMap [], B'.structBase = P'.Nothing, B'.structFields = B'.makeMap [(B'.Ordinal 0, B'.FieldSchema{B'.fieldName = "metadata", B'.fieldAttrs = B'.makeMap [], B'.fieldModifier = B'.FieldOptional, B'.fieldType = B'.elementToFieldType (B'.getElementType (B'.Proxy :: B'.Proxy Data.Bond.Schema.Metadata.Metadata))}), (B'.Ordinal 1, B'.FieldSchema{B'.fieldName = "id", B'.fieldAttrs = B'.makeMap [], B'.fieldModifier = B'.FieldOptional, B'.fieldType = B'.FieldUInt16 (B'.DefaultValue (id (B'.defaultValue `B'.asProxyTypeOf` type'proxy)))}), (B'.Ordinal 2, B'.FieldSchema{B'.fieldName = "type", B'.fieldAttrs = B'.makeMap [("HaskellName", "typedef")], B'.fieldModifier = B'.FieldOptional, B'.fieldType = B'.elementToFieldType (B'.getElementType (B'.Proxy :: B'.Proxy Data.Bond.Schema.TypeDef.TypeDef))})], B'.structRequiredOrdinals = B'.fromOrdinalList []} instance B'.NFData FieldDef