module Network.XmlRpc.DTD_XMLRPC where import Text.XML.HaXml.Xml2Haskell import Text.XML.HaXml.OneOfN import Data.Char (isSpace) import Prelude hiding (String, Int, Double) import qualified Prelude {-Type decls-} newtype I4 = I4 Prelude.String deriving (Prelude.Eq,Prelude.Show) newtype Int = Int Prelude.String deriving (Prelude.Eq,Prelude.Show) newtype Boolean = Boolean Prelude.String deriving (Prelude.Eq,Prelude.Show) newtype String = String Prelude.String deriving (Prelude.Eq,Prelude.Show) newtype Double = Double Prelude.String deriving (Prelude.Eq,Prelude.Show) newtype DateTime_iso8601 = DateTime_iso8601 Prelude.String deriving (Prelude.Eq,Prelude.Show) newtype Base64 = Base64 Prelude.String deriving (Prelude.Eq,Prelude.Show) newtype Data = Data [Value] deriving (Prelude.Eq,Prelude.Show) newtype Array = Array Data deriving (Prelude.Eq,Prelude.Show) newtype Name = Name Prelude.String deriving (Prelude.Eq,Prelude.Show) data Member = Member Name Value deriving (Prelude.Eq,Prelude.Show) newtype Struct = Struct [Member] deriving (Prelude.Eq,Prelude.Show) newtype Value = Value [Value_] deriving (Prelude.Eq,Prelude.Show) data Value_ = Value_Str Prelude.String | Value_I4 I4 | Value_Int Int | Value_Boolean Boolean | Value_String String | Value_DateTime_iso8601 DateTime_iso8601 | Value_Double Double | Value_Base64 Base64 | Value_Struct Struct | Value_Array Array deriving (Prelude.Eq,Prelude.Show) newtype Param = Param Value deriving (Prelude.Eq,Prelude.Show) newtype Params = Params [Param] deriving (Prelude.Eq,Prelude.Show) newtype MethodName = MethodName Prelude.String deriving (Prelude.Eq,Prelude.Show) data MethodCall = MethodCall MethodName (Prelude.Maybe Params) deriving (Prelude.Eq,Prelude.Show) newtype Fault = Fault Value deriving (Prelude.Eq,Prelude.Show) data MethodResponse = MethodResponseParams Params | MethodResponseFault Fault deriving (Prelude.Eq,Prelude.Show) {-Instance decls-} instance XmlContent I4 where fromElem (CElem (Elem "i4" [] c0):rest) = (\(a,ca)-> (Prelude.Just (I4 a), rest)) (definite fromText "text" "i4" c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (I4 a) = [CElem (Elem "i4" [] (toText a))] instance XmlContent Int where fromElem (CElem (Elem "int" [] c0):rest) = (\(a,ca)-> (Prelude.Just (Int a), rest)) (definite fromText "text" "int" c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (Int a) = [CElem (Elem "int" [] (toText a))] instance XmlContent Boolean where fromElem (CElem (Elem "boolean" [] c0):rest) = (\(a,ca)-> (Prelude.Just (Boolean a), rest)) (definite fromText "text" "boolean" c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (Boolean a) = [CElem (Elem "boolean" [] (toText a))] instance XmlContent String where fromElem (CElem (Elem "string" [] c0):rest) = (\(a,ca)-> (Prelude.Just (String a), rest)) (definite fromText "text" "string" c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (String a) = [CElem (Elem "string" [] (toText a))] instance XmlContent Double where fromElem (CElem (Elem "double" [] c0):rest) = (\(a,ca)-> (Prelude.Just (Double a), rest)) (definite fromText "text" "double" c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (Double a) = [CElem (Elem "double" [] (toText a))] instance XmlContent DateTime_iso8601 where fromElem (CElem (Elem "dateTime.iso8601" [] c0):rest) = (\(a,ca)-> (Prelude.Just (DateTime_iso8601 a), rest)) (definite fromText "text" "dateTime.iso8601" c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (DateTime_iso8601 a) = [CElem (Elem "dateTime.iso8601" [] (toText a))] instance XmlContent Base64 where fromElem (CElem (Elem "base64" [] c0):rest) = (\(a,ca)-> (Prelude.Just (Base64 a), rest)) (definite fromText "text" "base64" c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (Base64 a) = [CElem (Elem "base64" [] (toText a))] instance XmlContent Data where fromElem (CElem (Elem "data" [] c0):rest) = (\(a,ca)-> (Prelude.Just (Data a), rest)) (many fromElem c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (Data a) = [CElem (Elem "data" [] (concatMap toElem a))] instance XmlContent Array where fromElem (CElem (Elem "array" [] c0):rest) = (\(a,ca)-> (Prelude.Just (Array a), rest)) (definite fromElem "" "array" c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (Array a) = [CElem (Elem "array" [] (toElem a))] instance XmlContent Name where fromElem (CElem (Elem "name" [] c0):rest) = (\(a,ca)-> (Prelude.Just (Name a), rest)) (definite fromText "text" "name" c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (Name a) = [CElem (Elem "name" [] (toText a))] instance XmlContent Member where fromElem (CElem (Elem "member" [] c0):rest) = (\(a,ca)-> (\(b,cb)-> (Prelude.Just (Member a b), rest)) (definite fromElem "" "member" ca)) (definite fromElem "" "member" c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (Member a b) = [CElem (Elem "member" [] (toElem a ++ toElem b))] instance XmlContent Struct where fromElem (CElem (Elem "struct" [] c0):rest) = (\(a,ca)-> (Prelude.Just (Struct a), rest)) (many fromElem c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (Struct a) = [CElem (Elem "struct" [] (concatMap toElem a))] instance XmlContent Value where fromElem (CElem (Elem "value" [] c0):rest) = (\(a,ca)-> (Prelude.Just (Value a), rest)) (many fromElem c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (Value a) = [CElem (Elem "value" [] (concatMap toElem a))] instance XmlContent Value_ where fromElem c0 = case (fromText c0) of (Prelude.Just a,rest) -> (Prelude.Just (Value_Str a), rest) (_,_) -> case (fromElem c0) of (Prelude.Just a,rest) -> (Prelude.Just (Value_I4 a), rest) (_,_) -> case (fromElem c0) of (Prelude.Just a,rest) -> (Prelude.Just (Value_Int a), rest) (_,_) -> case (fromElem c0) of (Prelude.Just a,rest) -> (Prelude.Just (Value_Boolean a), rest) (_,_) -> case (fromElem c0) of (Prelude.Just a,rest) -> (Prelude.Just (Value_String a), rest) (_,_) -> case (fromElem c0) of (Prelude.Just a,rest) -> (Prelude.Just (Value_DateTime_iso8601 a), rest) (_,_) -> case (fromElem c0) of (Prelude.Just a,rest) -> (Prelude.Just (Value_Double a), rest) (_,_) -> case (fromElem c0) of (Prelude.Just a,rest) -> (Prelude.Just (Value_Base64 a), rest) (_,_) -> case (fromElem c0) of (Prelude.Just a,rest) -> (Prelude.Just (Value_Struct a), rest) (_,_) -> case (fromElem c0) of (Prelude.Just a,rest) -> (Prelude.Just (Value_Array a), rest) (_,_) -> (Prelude.Nothing, c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (Value_Str a) = toText a toElem (Value_I4 a) = toElem a toElem (Value_Int a) = toElem a toElem (Value_Boolean a) = toElem a toElem (Value_String a) = toElem a toElem (Value_DateTime_iso8601 a) = toElem a toElem (Value_Double a) = toElem a toElem (Value_Base64 a) = toElem a toElem (Value_Struct a) = toElem a toElem (Value_Array a) = toElem a instance XmlContent Param where fromElem (CElem (Elem "param" [] c0):rest) = (\(a,ca)-> (Prelude.Just (Param a), rest)) (definite fromElem "" "param" c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (Param a) = [CElem (Elem "param" [] (toElem a))] instance XmlContent Params where fromElem (CElem (Elem "params" [] c0):rest) = (\(a,ca)-> (Prelude.Just (Params a), rest)) (many fromElem c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (Params a) = [CElem (Elem "params" [] (concatMap toElem a))] instance XmlContent MethodName where fromElem (CElem (Elem "methodName" [] c0):rest) = (\(a,ca)-> (Prelude.Just (MethodName a), rest)) (definite fromText "text" "methodName" c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (MethodName a) = [CElem (Elem "methodName" [] (toText a))] instance XmlContent MethodCall where fromElem (CElem (Elem "methodCall" [] c0):rest) = (\(a,ca)-> (\(b,cb)-> (Prelude.Just (MethodCall a b), rest)) (fromElem ca)) (definite fromElem "" "methodCall" c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (MethodCall a b) = [CElem (Elem "methodCall" [] (toElem a ++ maybe [] toElem b))] instance XmlContent Fault where fromElem (CElem (Elem "fault" [] c0):rest) = (\(a,ca)-> (Prelude.Just (Fault a), rest)) (definite fromElem "" "fault" c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (Fault a) = [CElem (Elem "fault" [] (toElem a))] instance XmlContent MethodResponse where fromElem (CElem (Elem "methodResponse" [] c0):rest) = case (fromElem c0) of (Prelude.Just a,_) -> (Prelude.Just (MethodResponseParams a), rest) (_,_) -> case (fromElem c0) of (Prelude.Just a,_) -> (Prelude.Just (MethodResponseFault a), rest) (_,_) -> (Prelude.Nothing, c0) fromElem (CMisc _:rest) = fromElem rest fromElem (CString _ s:rest) | all isSpace s = fromElem rest fromElem rest = (Prelude.Nothing, rest) toElem (MethodResponseParams a) = [CElem (Elem "methodResponse" [] (toElem a) )] toElem (MethodResponseFault a) = [CElem (Elem "methodResponse" [] (toElem a) )] {-Done-}