-- Hoogle documentation, generated by Haddock
-- See Hoogle, http://www.haskell.org/hoogle/


-- | Extra goodies for aeson
--   
--   Package provides extra funcitonality on top of <tt>aeson</tt> and
--   <tt>aeson-compat</tt>
@package aeson-extra
@version 0.4.0.0


-- | Time tools
module Data.Aeson.Extra.Time

-- | A type to parse <a>UTCTime</a>
--   
--   <a>FromJSON</a> instance accepts for example:
--   
--   <pre>
--   2015-09-07T08:16:40.807Z
--   2015-09-07 11:16:40.807 +03:00
--   </pre>
--   
--   Latter format is accepted by <tt>aeson</tt> staring from version
--   <tt>0.10.0.0</tt>.
--   
--   See
--   <a>https://github.com/bos/aeson/blob/4667ef1029a373cf4510f7deca147c357c6d8947/Data/Aeson/Parser/Time.hs#L150</a>
--   
--   <i>Since: aeson-extra-0.2.2.0</i>
newtype U
U :: UTCTime -> U
[getU] :: U -> UTCTime

-- | A type to parse <a>ZonedTime</a>
--   
--   <i>Since: aeson-extra-0.2.2.0</i>
newtype Z
Z :: ZonedTime -> Z
[getZ] :: Z -> ZonedTime
instance GHC.Read.Read Data.Aeson.Extra.Time.Z
instance GHC.Show.Show Data.Aeson.Extra.Time.Z
instance GHC.Read.Read Data.Aeson.Extra.Time.U
instance GHC.Show.Show Data.Aeson.Extra.Time.U
instance GHC.Classes.Ord Data.Aeson.Extra.Time.U
instance GHC.Classes.Eq Data.Aeson.Extra.Time.U
instance Data.Aeson.Types.ToJSON.ToJSON Data.Aeson.Extra.Time.U
instance Data.Aeson.Types.FromJSON.FromJSON Data.Aeson.Extra.Time.U
instance Data.Aeson.Types.ToJSON.ToJSON Data.Aeson.Extra.Time.Z
instance Data.Aeson.Types.FromJSON.FromJSON Data.Aeson.Extra.Time.Z


-- | In addition to <a>mkValue</a> and <a>mkValue'</a> helpers, this module
--   exports <tt>Lift</tt> <a>Value</a> orphan instance for aeson &lt;0.11
module Data.Aeson.Extra.TH

-- | Create a <a>Value</a> from string representation.
--   
--   This is useful in tests.
--   
--   <i>Since: aeson-extra-0.3.1.0</i>
mkValue :: String -> Q Exp

-- | Like <a>mkValue</a>, but replace single quotes with double quotes
--   before.
--   
--   <pre>
--   &gt; $(mkValue' "{'a': 2 }")
--   Object (fromList [("a",Number 2.0)])
--   </pre>
--   
--   <i>Since: aeson-extra-0.3.1.0</i>
mkValue' :: String -> Q Exp


module Data.Aeson.Extra.SymTag

-- | Singleton string encoded and decoded as ifself.
--   
--   <pre>
--   λ&gt; encode (SymTag :: SymTag "foobar")
--   "\"foobar\""
--   </pre>
--   
--   <pre>
--   decode "\"foobar\"" :: Maybe (SymTag "foobar")
--   Just SymTag
--   </pre>
--   
--   <pre>
--   decode "\"foobar\"" :: Maybe (SymTag "barfoo")
--   Nothing
--   </pre>
--   
--   <i>Available with: base &gt;=4.7</i>
data SymTag (s :: Symbol)
SymTag :: SymTag
instance GHC.Enum.Bounded (Data.Aeson.Extra.SymTag.SymTag s)
instance GHC.Enum.Enum (Data.Aeson.Extra.SymTag.SymTag s)
instance GHC.Read.Read (Data.Aeson.Extra.SymTag.SymTag s)
instance GHC.Show.Show (Data.Aeson.Extra.SymTag.SymTag s)
instance GHC.Classes.Ord (Data.Aeson.Extra.SymTag.SymTag s)
instance GHC.Classes.Eq (Data.Aeson.Extra.SymTag.SymTag s)
instance GHC.TypeLits.KnownSymbol s => Data.Aeson.Types.FromJSON.FromJSON (Data.Aeson.Extra.SymTag.SymTag s)
instance GHC.TypeLits.KnownSymbol s => Data.Aeson.Types.ToJSON.ToJSON (Data.Aeson.Extra.SymTag.SymTag s)


module Data.Aeson.Extra.Stream

-- | Lazyly parse <a>ByteString</a> with top-level JSON array.
--   
--   <i>Note:</i> inspecting result's second field will force the list!
--   
--   <pre>
--   let ~(values, err) = <a>streamDecode</a> bs
--   traverse_ processValue values
--   maybe (pure ()) printError err
--   </pre>
streamDecode :: forall a. FromJSON a => ByteString -> ([a], Maybe String)


module Data.Aeson.Extra.SingObject

-- | Singleton value object
--   
--   <pre>
--   λ &gt; decode "{\"value\": 42 }" :: Maybe (SingObject "value" Int)
--   Just (SingObject 42)
--   </pre>
--   
--   <pre>
--   λ &gt; encode (SingObject 42 :: SingObject "value" Int)
--   "{\"value\":42}"
--   </pre>
--   
--   <i>Available with: base &gt;=4.7</i>
newtype SingObject (s :: Symbol) a
SingObject :: a -> SingObject a
mkSingObject :: Proxy s -> a -> SingObject s a
getSingObject :: Proxy s -> SingObject s a -> a
instance Data.Traversable.Traversable (Data.Aeson.Extra.SingObject.SingObject s)
instance Data.Foldable.Foldable (Data.Aeson.Extra.SingObject.SingObject s)
instance GHC.Base.Functor (Data.Aeson.Extra.SingObject.SingObject s)
instance GHC.Read.Read a => GHC.Read.Read (Data.Aeson.Extra.SingObject.SingObject s a)
instance GHC.Show.Show a => GHC.Show.Show (Data.Aeson.Extra.SingObject.SingObject s a)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Data.Aeson.Extra.SingObject.SingObject s a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Data.Aeson.Extra.SingObject.SingObject s a)
instance GHC.TypeLits.KnownSymbol s => Data.Aeson.Types.FromJSON.FromJSON1 (Data.Aeson.Extra.SingObject.SingObject s)
instance GHC.TypeLits.KnownSymbol s => Data.Aeson.Types.ToJSON.ToJSON1 (Data.Aeson.Extra.SingObject.SingObject s)
instance (GHC.TypeLits.KnownSymbol s, Data.Aeson.Types.FromJSON.FromJSON a) => Data.Aeson.Types.FromJSON.FromJSON (Data.Aeson.Extra.SingObject.SingObject s a)
instance (GHC.TypeLits.KnownSymbol s, Data.Aeson.Types.ToJSON.ToJSON a) => Data.Aeson.Types.ToJSON.ToJSON (Data.Aeson.Extra.SingObject.SingObject s a)


-- | More or less useful newtypes for writing <a>FromJSON</a> &amp;
--   <a>ToJSON</a> instances

-- | <i>Deprecated: Use aeson-1 TOJSONKey etc functionality</i>
module Data.Aeson.Extra.Map

-- | A wrapper type to parse arbitrary maps
--   
--   <pre>
--   λ &gt; decode "{\"1\": 1, \"2\": 2}" :: Maybe (M (H.HashMap Int Int))
--   Just (M {getMap = fromList [(1,1),(2,2)]})
--   </pre>
newtype M a
M :: a -> M a
[getMap] :: M a -> a
class FromJSONKey a
parseJSONKey :: FromJSONKey a => Text -> Parser a
parseIntegralJSONKey :: Integral a => Text -> Parser a
class FromJSONMap m k v | m -> k v
parseJSONMap :: FromJSONMap m k v => HashMap Text Value -> Parser m
class ToJSONKey a
toJSONKey :: ToJSONKey a => a -> Text
class ToJSONMap m k v | m -> k v
toJSONMap :: ToJSONMap m k v => m -> HashMap Text Value
instance Data.Traversable.Traversable Data.Aeson.Extra.Map.M
instance Data.Foldable.Foldable Data.Aeson.Extra.Map.M
instance GHC.Base.Functor Data.Aeson.Extra.Map.M
instance GHC.Read.Read a => GHC.Read.Read (Data.Aeson.Extra.Map.M a)
instance GHC.Show.Show a => GHC.Show.Show (Data.Aeson.Extra.Map.M a)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Data.Aeson.Extra.Map.M a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Data.Aeson.Extra.Map.M a)
instance Data.Aeson.Extra.Map.FromJSONKey Data.Text.Internal.Text
instance Data.Aeson.Extra.Map.FromJSONKey Data.Text.Internal.Lazy.Text
instance Data.Aeson.Extra.Map.FromJSONKey GHC.Base.String
instance Data.Aeson.Extra.Map.FromJSONKey GHC.Types.Int
instance Data.Aeson.Extra.Map.FromJSONKey GHC.Integer.Type.Integer
instance (GHC.Classes.Eq k, Data.Hashable.Class.Hashable k, Data.Aeson.Extra.Map.FromJSONKey k, Data.Aeson.Types.FromJSON.FromJSON v) => Data.Aeson.Extra.Map.FromJSONMap (Data.HashMap.Base.HashMap k v) k v
instance (GHC.Classes.Ord k, Data.Aeson.Extra.Map.FromJSONKey k, Data.Aeson.Types.FromJSON.FromJSON v) => Data.Aeson.Extra.Map.FromJSONMap (Data.Map.Base.Map k v) k v
instance Data.Aeson.Extra.Map.FromJSONMap m k v => Data.Aeson.Types.FromJSON.FromJSON (Data.Aeson.Extra.Map.M m)
instance Data.Aeson.Extra.Map.ToJSONKey Data.Text.Internal.Text
instance Data.Aeson.Extra.Map.ToJSONKey Data.Text.Internal.Lazy.Text
instance Data.Aeson.Extra.Map.ToJSONKey GHC.Base.String
instance Data.Aeson.Extra.Map.ToJSONKey GHC.Types.Int
instance Data.Aeson.Extra.Map.ToJSONKey GHC.Integer.Type.Integer
instance (Data.Aeson.Extra.Map.ToJSONKey k, Data.Aeson.Types.ToJSON.ToJSON v) => Data.Aeson.Extra.Map.ToJSONMap (Data.HashMap.Base.HashMap k v) k v
instance (Data.Aeson.Extra.Map.ToJSONKey k, Data.Aeson.Types.ToJSON.ToJSON v) => Data.Aeson.Extra.Map.ToJSONMap (Data.Map.Base.Map k v) k v
instance Data.Aeson.Extra.Map.ToJSONMap m k v => Data.Aeson.Types.ToJSON.ToJSON (Data.Aeson.Extra.Map.M m)


-- | Helps writing recursive algorithms on <a>Value</a>, for example:
--   
--   <pre>
--   stripNulls :: Value -&gt; Value
--   stripNulls = <a>cata</a> (<a>embed</a> . f)
--    where
--      f (ObjectF a) = ObjectF $ HM.filter (== Null) a
--      f x = x
--   </pre>
module Data.Aeson.Extra.Foldable

-- | An algebra of <a>Value</a>
--   
--   <i>Since: aeson-extra-0.3.1.0</i>
data ValueF a
ObjectF :: (ObjectF a) -> ValueF a
ArrayF :: !(ArrayF a) -> ValueF a
StringF :: !Text -> ValueF a
NumberF :: !Scientific -> ValueF a
BoolF :: !Bool -> ValueF a
NullF :: ValueF a

-- | A JSON "object" (key/value map).
--   
--   <i>Since: aeson-extra-0.3.1.0</i>
type ObjectF a = HashMap Text a

-- | A JSON "array" (sequence).
--   
--   <i>Since: aeson-extra-0.3.1.0</i>
type ArrayF a = Vector a
instance Data.Traversable.Traversable Data.Aeson.Extra.Foldable.ValueF
instance Data.Foldable.Foldable Data.Aeson.Extra.Foldable.ValueF
instance GHC.Base.Functor Data.Aeson.Extra.Foldable.ValueF
instance Data.Data.Data a => Data.Data.Data (Data.Aeson.Extra.Foldable.ValueF a)
instance GHC.Show.Show a => GHC.Show.Show (Data.Aeson.Extra.Foldable.ValueF a)
instance GHC.Read.Read a => GHC.Read.Read (Data.Aeson.Extra.Foldable.ValueF a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Data.Aeson.Extra.Foldable.ValueF a)
instance Data.Functor.Foldable.Recursive Data.Aeson.Types.Internal.Value
instance Data.Functor.Foldable.Corecursive Data.Aeson.Types.Internal.Value


module Data.Aeson.Extra.Merge

-- | Generic merge.
--   
--   For example <a>https://lodash.com/docs#merge</a>:
--   
--   <pre>
--   lodashMerge :: Value -&gt; Value -&gt; Value
--   lodashMerge x y = merge lodashMergeAlg x y
--   
--   lodashMergeAlg :: (a -&gt; a -&gt; a) -&gt; ValueF a -&gt; ValueF a -&gt; ValueF a
--   lodashMergeAlg r a' b' = case (a', b') of
--       (ObjectF a, ObjectF b) -&gt; ObjectF $ alignWith f a b
--       (ArrayF a,  ArrayF b)  -&gt; ArrayF $ alignWith f a b
--       (_,         b)         -&gt; b
--     where f (These x y) = r x y
--           f (This x)    = x
--           f (That x)    = x
--   </pre>
--   
--   <i>Since: aeson-extra-0.3.1.0</i>
merge :: (forall a. (a -> a -> a) -> ValueF a -> ValueF a -> ValueF a) -> Value -> Value -> Value

-- | Generic merge, in arbitrary context.
--   
--   <i>Since: aeson-extra-0.3.1.0</i>
mergeA :: Functor f => (forall a. (a -> a -> f a) -> ValueF a -> ValueF a -> f (ValueF a)) -> Value -> Value -> f Value

-- | An algebra of <a>Value</a>
--   
--   <i>Since: aeson-extra-0.3.1.0</i>
data ValueF a
ObjectF :: (ObjectF a) -> ValueF a
ArrayF :: !(ArrayF a) -> ValueF a
StringF :: !Text -> ValueF a
NumberF :: !Scientific -> ValueF a
BoolF :: !Bool -> ValueF a
NullF :: ValueF a

-- | A JSON "object" (key/value map).
--   
--   <i>Since: aeson-extra-0.3.1.0</i>
type ObjectF a = HashMap Text a

-- | A JSON "array" (sequence).
--   
--   <i>Since: aeson-extra-0.3.1.0</i>
type ArrayF a = Vector a


-- | Note: the contexts of functions are different with <tt>aeson-1</tt>.
module Data.Aeson.Extra.CollapsedList

-- | Collapsed list, singleton is represented as the value itself in JSON
--   encoding.
--   
--   <pre>
--   λ &gt; decode "null" :: Maybe (CollapsedList [Int] Int)
--   Just (CollapsedList [])
--   λ &gt; decode "42" :: Maybe (CollapsedList [Int] Int)
--   Just (CollapsedList [42])
--   λ &gt; decode "[1, 2, 3]" :: Maybe (CollapsedList [Int] Int)
--   Just (CollapsedList [1,2,3])
--   </pre>
--   
--   <pre>
--   λ &gt; encode (CollapsedList ([] :: [Int]))
--   "null"
--   λ &gt; encode (CollapsedList ([42] :: [Int]))
--   "42"
--   λ &gt; encode (CollapsedList ([1, 2, 3] :: [Int]))
--   "[1,2,3]"
--   </pre>
--   
--   Documentation rely on <tt>f</tt> <a>Alternative</a> instance behaving
--   like lists'.
newtype CollapsedList f a
CollapsedList :: (f a) -> CollapsedList f a
getCollapsedList :: CollapsedList f a -> f a

-- | Parses possibly collapsed array value from the object's field.
--   
--   <pre>
--   λ &gt; newtype V = V [Int] deriving (Show)
--   λ &gt; instance FromJSON V where parseJSON = withObject "V" $ \obj -&gt; V &lt;$&gt; parseCollapsedList obj "value"
--   λ &gt; decode "{}" :: Maybe V
--   Just (V [])
--   λ &gt; decode "{\"value\": null}" :: Maybe V
--   Just (V [])
--   λ &gt; decode "{\"value\": 42}" :: Maybe V
--   Just (V [42])
--   λ &gt; decode "{\"value\": [1, 2, 3, 4]}" :: Maybe V
--   Just (V [1,2,3,4])
--   </pre>
parseCollapsedList :: (FromJSON a, FromJSON1 f, Alternative f) => Object -> Text -> Parser (f a)
instance Data.Traversable.Traversable f => Data.Traversable.Traversable (Data.Aeson.Extra.CollapsedList.CollapsedList f)
instance Data.Foldable.Foldable f => Data.Foldable.Foldable (Data.Aeson.Extra.CollapsedList.CollapsedList f)
instance GHC.Base.Functor f => GHC.Base.Functor (Data.Aeson.Extra.CollapsedList.CollapsedList f)
instance GHC.Read.Read (f a) => GHC.Read.Read (Data.Aeson.Extra.CollapsedList.CollapsedList f a)
instance GHC.Show.Show (f a) => GHC.Show.Show (Data.Aeson.Extra.CollapsedList.CollapsedList f a)
instance GHC.Classes.Ord (f a) => GHC.Classes.Ord (Data.Aeson.Extra.CollapsedList.CollapsedList f a)
instance GHC.Classes.Eq (f a) => GHC.Classes.Eq (Data.Aeson.Extra.CollapsedList.CollapsedList f a)
instance (Data.Aeson.Types.FromJSON.FromJSON1 f, GHC.Base.Alternative f) => Data.Aeson.Types.FromJSON.FromJSON1 (Data.Aeson.Extra.CollapsedList.CollapsedList f)
instance (Data.Aeson.Types.ToJSON.ToJSON1 f, Data.Foldable.Foldable f) => Data.Aeson.Types.ToJSON.ToJSON1 (Data.Aeson.Extra.CollapsedList.CollapsedList f)
instance (Data.Aeson.Types.ToJSON.ToJSON1 f, Data.Foldable.Foldable f, Data.Aeson.Types.ToJSON.ToJSON a) => Data.Aeson.Types.ToJSON.ToJSON (Data.Aeson.Extra.CollapsedList.CollapsedList f a)
instance (Data.Aeson.Types.FromJSON.FromJSON1 f, GHC.Base.Alternative f, Data.Aeson.Types.FromJSON.FromJSON a) => Data.Aeson.Types.FromJSON.FromJSON (Data.Aeson.Extra.CollapsedList.CollapsedList f a)


-- | More or less useful newtypes for writing <a>FromJSON</a> &amp;
--   <a>ToJSON</a> instances
module Data.Aeson.Extra

-- | Like <a>encode</a>, but produces strict <a>ByteString</a>.
--   
--   <i>Since: 0.2.3.0</i>
encodeStrict :: ToJSON a => a -> ByteString

-- | A wrapper type to parse arbitrary maps
--   
--   <pre>
--   λ &gt; decode "{\"1\": 1, \"2\": 2}" :: Maybe (M (H.HashMap Int Int))
--   Just (M {getMap = fromList [(1,1),(2,2)]})
--   </pre>
newtype M a
M :: a -> M a
[getMap] :: M a -> a
class FromJSONKey a
parseJSONKey :: FromJSONKey a => Text -> Parser a
parseIntegralJSONKey :: Integral a => Text -> Parser a
class FromJSONMap m k v | m -> k v
parseJSONMap :: FromJSONMap m k v => HashMap Text Value -> Parser m
class ToJSONKey a
toJSONKey :: ToJSONKey a => a -> Text
class ToJSONMap m k v | m -> k v
toJSONMap :: ToJSONMap m k v => m -> HashMap Text Value

-- | Singleton string encoded and decoded as ifself.
--   
--   <pre>
--   λ&gt; encode (SymTag :: SymTag "foobar")
--   "\"foobar\""
--   </pre>
--   
--   <pre>
--   decode "\"foobar\"" :: Maybe (SymTag "foobar")
--   Just SymTag
--   </pre>
--   
--   <pre>
--   decode "\"foobar\"" :: Maybe (SymTag "barfoo")
--   Nothing
--   </pre>
--   
--   <i>Available with: base &gt;=4.7</i>
data SymTag (s :: Symbol)
SymTag :: SymTag

-- | Singleton value object
--   
--   <pre>
--   λ &gt; decode "{\"value\": 42 }" :: Maybe (SingObject "value" Int)
--   Just (SingObject 42)
--   </pre>
--   
--   <pre>
--   λ &gt; encode (SingObject 42 :: SingObject "value" Int)
--   "{\"value\":42}"
--   </pre>
--   
--   <i>Available with: base &gt;=4.7</i>
newtype SingObject (s :: Symbol) a
SingObject :: a -> SingObject a
mkSingObject :: Proxy s -> a -> SingObject s a
getSingObject :: Proxy s -> SingObject s a -> a

-- | Collapsed list, singleton is represented as the value itself in JSON
--   encoding.
--   
--   <pre>
--   λ &gt; decode "null" :: Maybe (CollapsedList [Int] Int)
--   Just (CollapsedList [])
--   λ &gt; decode "42" :: Maybe (CollapsedList [Int] Int)
--   Just (CollapsedList [42])
--   λ &gt; decode "[1, 2, 3]" :: Maybe (CollapsedList [Int] Int)
--   Just (CollapsedList [1,2,3])
--   </pre>
--   
--   <pre>
--   λ &gt; encode (CollapsedList ([] :: [Int]))
--   "null"
--   λ &gt; encode (CollapsedList ([42] :: [Int]))
--   "42"
--   λ &gt; encode (CollapsedList ([1, 2, 3] :: [Int]))
--   "[1,2,3]"
--   </pre>
--   
--   Documentation rely on <tt>f</tt> <a>Alternative</a> instance behaving
--   like lists'.
newtype CollapsedList f a
CollapsedList :: (f a) -> CollapsedList f a
getCollapsedList :: CollapsedList f a -> f a

-- | Parses possibly collapsed array value from the object's field.
--   
--   <pre>
--   λ &gt; newtype V = V [Int] deriving (Show)
--   λ &gt; instance FromJSON V where parseJSON = withObject "V" $ \obj -&gt; V &lt;$&gt; parseCollapsedList obj "value"
--   λ &gt; decode "{}" :: Maybe V
--   Just (V [])
--   λ &gt; decode "{\"value\": null}" :: Maybe V
--   Just (V [])
--   λ &gt; decode "{\"value\": 42}" :: Maybe V
--   Just (V [42])
--   λ &gt; decode "{\"value\": [1, 2, 3, 4]}" :: Maybe V
--   Just (V [1,2,3,4])
--   </pre>
parseCollapsedList :: (FromJSON a, FromJSON1 f, Alternative f) => Object -> Text -> Parser (f a)

-- | A type to parse <a>UTCTime</a>
--   
--   <a>FromJSON</a> instance accepts for example:
--   
--   <pre>
--   2015-09-07T08:16:40.807Z
--   2015-09-07 11:16:40.807 +03:00
--   </pre>
--   
--   Latter format is accepted by <tt>aeson</tt> staring from version
--   <tt>0.10.0.0</tt>.
--   
--   See
--   <a>https://github.com/bos/aeson/blob/4667ef1029a373cf4510f7deca147c357c6d8947/Data/Aeson/Parser/Time.hs#L150</a>
--   
--   <i>Since: aeson-extra-0.2.2.0</i>
newtype U
U :: UTCTime -> U
[getU] :: U -> UTCTime

-- | A type to parse <a>ZonedTime</a>
--   
--   <i>Since: aeson-extra-0.2.2.0</i>
newtype Z
Z :: ZonedTime -> Z
[getZ] :: Z -> ZonedTime

-- | An algebra of <a>Value</a>
--   
--   <i>Since: aeson-extra-0.3.1.0</i>
data ValueF a
ObjectF :: (ObjectF a) -> ValueF a
ArrayF :: !(ArrayF a) -> ValueF a
StringF :: !Text -> ValueF a
NumberF :: !Scientific -> ValueF a
BoolF :: !Bool -> ValueF a
NullF :: ValueF a

-- | A JSON "object" (key/value map).
--   
--   <i>Since: aeson-extra-0.3.1.0</i>
type ObjectF a = HashMap Text a

-- | A JSON "array" (sequence).
--   
--   <i>Since: aeson-extra-0.3.1.0</i>
type ArrayF a = Vector a

-- | Generic merge.
--   
--   For example <a>https://lodash.com/docs#merge</a>:
--   
--   <pre>
--   lodashMerge :: Value -&gt; Value -&gt; Value
--   lodashMerge x y = merge lodashMergeAlg x y
--   
--   lodashMergeAlg :: (a -&gt; a -&gt; a) -&gt; ValueF a -&gt; ValueF a -&gt; ValueF a
--   lodashMergeAlg r a' b' = case (a', b') of
--       (ObjectF a, ObjectF b) -&gt; ObjectF $ alignWith f a b
--       (ArrayF a,  ArrayF b)  -&gt; ArrayF $ alignWith f a b
--       (_,         b)         -&gt; b
--     where f (These x y) = r x y
--           f (This x)    = x
--           f (That x)    = x
--   </pre>
--   
--   <i>Since: aeson-extra-0.3.1.0</i>
merge :: (forall a. (a -> a -> a) -> ValueF a -> ValueF a -> ValueF a) -> Value -> Value -> Value

-- | Lazyly parse <a>ByteString</a> with top-level JSON array.
--   
--   <i>Note:</i> inspecting result's second field will force the list!
--   
--   <pre>
--   let ~(values, err) = <a>streamDecode</a> bs
--   traverse_ processValue values
--   maybe (pure ()) printError err
--   </pre>
streamDecode :: forall a. FromJSON a => ByteString -> ([a], Maybe String)

-- | Create a <a>Value</a> from string representation.
--   
--   This is useful in tests.
--   
--   <i>Since: aeson-extra-0.3.1.0</i>
mkValue :: String -> Q Exp

-- | Like <a>mkValue</a>, but replace single quotes with double quotes
--   before.
--   
--   <pre>
--   &gt; $(mkValue' "{'a': 2 }")
--   Object (fromList [("a",Number 2.0)])
--   </pre>
--   
--   <i>Since: aeson-extra-0.3.1.0</i>
mkValue' :: String -> Q Exp
