module Rattletrap.Type.Attribute.Title where import qualified Rattletrap.BitGet as BitGet import qualified Rattletrap.BitPut as BitPut import qualified Rattletrap.Schema as Schema import qualified Rattletrap.Type.U32 as U32 import qualified Rattletrap.Utility.Json as Json data Title = Title { Title -> Bool unknown1 :: Bool, Title -> Bool unknown2 :: Bool, Title -> U32 unknown3 :: U32.U32, Title -> U32 unknown4 :: U32.U32, Title -> U32 unknown5 :: U32.U32, Title -> U32 unknown6 :: U32.U32, Title -> U32 unknown7 :: U32.U32, Title -> Bool unknown8 :: Bool } deriving (Title -> Title -> Bool (Title -> Title -> Bool) -> (Title -> Title -> Bool) -> Eq Title forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a $c== :: Title -> Title -> Bool == :: Title -> Title -> Bool $c/= :: Title -> Title -> Bool /= :: Title -> Title -> Bool Eq, Int -> Title -> ShowS [Title] -> ShowS Title -> String (Int -> Title -> ShowS) -> (Title -> String) -> ([Title] -> ShowS) -> Show Title forall a. (Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a $cshowsPrec :: Int -> Title -> ShowS showsPrec :: Int -> Title -> ShowS $cshow :: Title -> String show :: Title -> String $cshowList :: [Title] -> ShowS showList :: [Title] -> ShowS Show) instance Json.FromJSON Title where parseJSON :: Value -> Parser Title parseJSON = String -> (Object -> Parser Title) -> Value -> Parser Title forall a. String -> (Object -> Parser a) -> Value -> Parser a Json.withObject String "Title" ((Object -> Parser Title) -> Value -> Parser Title) -> (Object -> Parser Title) -> Value -> Parser Title forall a b. (a -> b) -> a -> b $ \Object object -> do unknown1 <- Object -> String -> Parser Bool forall value. FromJSON value => Object -> String -> Parser value Json.required Object object String "unknown1" unknown2 <- Json.required object "unknown2" unknown3 <- Json.required object "unknown3" unknown4 <- Json.required object "unknown4" unknown5 <- Json.required object "unknown5" unknown6 <- Json.required object "unknown6" unknown7 <- Json.required object "unknown7" unknown8 <- Json.required object "unknown8" pure Title { unknown1, unknown2, unknown3, unknown4, unknown5, unknown6, unknown7, unknown8 } instance Json.ToJSON Title where toJSON :: Title -> Value toJSON Title x = [(Key, Value)] -> Value Json.object [ String -> Bool -> (Key, Value) forall value e p. (ToJSON value, KeyValue e p) => String -> value -> p Json.pair String "unknown1" (Bool -> (Key, Value)) -> Bool -> (Key, Value) forall a b. (a -> b) -> a -> b $ Title -> Bool unknown1 Title x, String -> Bool -> (Key, Value) forall value e p. (ToJSON value, KeyValue e p) => String -> value -> p Json.pair String "unknown2" (Bool -> (Key, Value)) -> Bool -> (Key, Value) forall a b. (a -> b) -> a -> b $ Title -> Bool unknown2 Title x, String -> U32 -> (Key, Value) forall value e p. (ToJSON value, KeyValue e p) => String -> value -> p Json.pair String "unknown3" (U32 -> (Key, Value)) -> U32 -> (Key, Value) forall a b. (a -> b) -> a -> b $ Title -> U32 unknown3 Title x, String -> U32 -> (Key, Value) forall value e p. (ToJSON value, KeyValue e p) => String -> value -> p Json.pair String "unknown4" (U32 -> (Key, Value)) -> U32 -> (Key, Value) forall a b. (a -> b) -> a -> b $ Title -> U32 unknown4 Title x, String -> U32 -> (Key, Value) forall value e p. (ToJSON value, KeyValue e p) => String -> value -> p Json.pair String "unknown5" (U32 -> (Key, Value)) -> U32 -> (Key, Value) forall a b. (a -> b) -> a -> b $ Title -> U32 unknown5 Title x, String -> U32 -> (Key, Value) forall value e p. (ToJSON value, KeyValue e p) => String -> value -> p Json.pair String "unknown6" (U32 -> (Key, Value)) -> U32 -> (Key, Value) forall a b. (a -> b) -> a -> b $ Title -> U32 unknown6 Title x, String -> U32 -> (Key, Value) forall value e p. (ToJSON value, KeyValue e p) => String -> value -> p Json.pair String "unknown7" (U32 -> (Key, Value)) -> U32 -> (Key, Value) forall a b. (a -> b) -> a -> b $ Title -> U32 unknown7 Title x, String -> Bool -> (Key, Value) forall value e p. (ToJSON value, KeyValue e p) => String -> value -> p Json.pair String "unknown8" (Bool -> (Key, Value)) -> Bool -> (Key, Value) forall a b. (a -> b) -> a -> b $ Title -> Bool unknown8 Title x ] schema :: Schema.Schema schema :: Schema schema = String -> Value -> Schema Schema.named String "attribute-title" (Value -> Schema) -> Value -> Schema forall a b. (a -> b) -> a -> b $ [((Key, Value), Bool)] -> Value Schema.object [ (String -> Value -> (Key, Value) forall value e p. (ToJSON value, KeyValue e p) => String -> value -> p Json.pair String "unknown1" (Value -> (Key, Value)) -> Value -> (Key, Value) forall a b. (a -> b) -> a -> b $ Schema -> Value Schema.ref Schema Schema.boolean, Bool True), (String -> Value -> (Key, Value) forall value e p. (ToJSON value, KeyValue e p) => String -> value -> p Json.pair String "unknown2" (Value -> (Key, Value)) -> Value -> (Key, Value) forall a b. (a -> b) -> a -> b $ Schema -> Value Schema.ref Schema Schema.boolean, Bool True), (String -> Value -> (Key, Value) forall value e p. (ToJSON value, KeyValue e p) => String -> value -> p Json.pair String "unknown3" (Value -> (Key, Value)) -> Value -> (Key, Value) forall a b. (a -> b) -> a -> b $ Schema -> Value Schema.ref Schema U32.schema, Bool True), (String -> Value -> (Key, Value) forall value e p. (ToJSON value, KeyValue e p) => String -> value -> p Json.pair String "unknown4" (Value -> (Key, Value)) -> Value -> (Key, Value) forall a b. (a -> b) -> a -> b $ Schema -> Value Schema.ref Schema U32.schema, Bool True), (String -> Value -> (Key, Value) forall value e p. (ToJSON value, KeyValue e p) => String -> value -> p Json.pair String "unknown5" (Value -> (Key, Value)) -> Value -> (Key, Value) forall a b. (a -> b) -> a -> b $ Schema -> Value Schema.ref Schema U32.schema, Bool True), (String -> Value -> (Key, Value) forall value e p. (ToJSON value, KeyValue e p) => String -> value -> p Json.pair String "unknown6" (Value -> (Key, Value)) -> Value -> (Key, Value) forall a b. (a -> b) -> a -> b $ Schema -> Value Schema.ref Schema U32.schema, Bool True), (String -> Value -> (Key, Value) forall value e p. (ToJSON value, KeyValue e p) => String -> value -> p Json.pair String "unknown7" (Value -> (Key, Value)) -> Value -> (Key, Value) forall a b. (a -> b) -> a -> b $ Schema -> Value Schema.ref Schema U32.schema, Bool True), (String -> Value -> (Key, Value) forall value e p. (ToJSON value, KeyValue e p) => String -> value -> p Json.pair String "unknown8" (Value -> (Key, Value)) -> Value -> (Key, Value) forall a b. (a -> b) -> a -> b $ Schema -> Value Schema.ref Schema Schema.boolean, Bool True) ] bitPut :: Title -> BitPut.BitPut bitPut :: Title -> BitPut bitPut Title titleAttribute = Bool -> BitPut BitPut.bool (Title -> Bool unknown1 Title titleAttribute) BitPut -> BitPut -> BitPut forall a. Semigroup a => a -> a -> a <> Bool -> BitPut BitPut.bool (Title -> Bool unknown2 Title titleAttribute) BitPut -> BitPut -> BitPut forall a. Semigroup a => a -> a -> a <> U32 -> BitPut U32.bitPut (Title -> U32 unknown3 Title titleAttribute) BitPut -> BitPut -> BitPut forall a. Semigroup a => a -> a -> a <> U32 -> BitPut U32.bitPut (Title -> U32 unknown4 Title titleAttribute) BitPut -> BitPut -> BitPut forall a. Semigroup a => a -> a -> a <> U32 -> BitPut U32.bitPut (Title -> U32 unknown5 Title titleAttribute) BitPut -> BitPut -> BitPut forall a. Semigroup a => a -> a -> a <> U32 -> BitPut U32.bitPut (Title -> U32 unknown6 Title titleAttribute) BitPut -> BitPut -> BitPut forall a. Semigroup a => a -> a -> a <> U32 -> BitPut U32.bitPut (Title -> U32 unknown7 Title titleAttribute) BitPut -> BitPut -> BitPut forall a. Semigroup a => a -> a -> a <> Bool -> BitPut BitPut.bool (Title -> Bool unknown8 Title titleAttribute) bitGet :: BitGet.BitGet Title bitGet :: BitGet Title bitGet = String -> BitGet Title -> BitGet Title forall a. String -> BitGet a -> BitGet a BitGet.label String "Title" (BitGet Title -> BitGet Title) -> BitGet Title -> BitGet Title forall a b. (a -> b) -> a -> b $ do unknown1 <- String -> BitGet Bool -> BitGet Bool forall a. String -> BitGet a -> BitGet a BitGet.label String "unknown1" BitGet Bool BitGet.bool unknown2 <- BitGet.label "unknown2" BitGet.bool unknown3 <- BitGet.label "unknown3" U32.bitGet unknown4 <- BitGet.label "unknown4" U32.bitGet unknown5 <- BitGet.label "unknown5" U32.bitGet unknown6 <- BitGet.label "unknown6" U32.bitGet unknown7 <- BitGet.label "unknown7" U32.bitGet unknown8 <- BitGet.label "unknown8" BitGet.bool pure Title { unknown1, unknown2, unknown3, unknown4, unknown5, unknown6, unknown7, unknown8 }