-- Hoogle documentation, generated by Haddock -- See Hoogle, http://www.haskell.org/hoogle/ -- | library for querying from JSON -- -- library(HXT-like) for querying from JSON @package hjson-query @version 1.0 module Text.HJson.Query type Jsons = [Json] type JFilter = Json -> Jsons -- | create empty JSON object emptyObj :: Json -- | create JSON object (-->) :: String -> Json -> Json -- | merge two JSON Objects (<>) :: Json -> Json -> Json -- | recursive merge two JSON Objects (<.>) :: Json -> Json -> Json -- | merge list JSON Objects merges :: [Json] -> Json -- | recursive merge lists JSON Objects -- -- Example: -- --
--   j1 = jParse "{\"Europa\": {\"Ukraine\": [\"Kiyv\", \"Gitomir\", \"Lviv\"]}}"
--   j2 = jParse "{\"Asia\": {\"Japan\": [\"Tokyo\"]}}"
--   j3 = jParse "{\"Europa\": {\"UnitedKingdom\": [\"London\", \"Glasgow\"]}}"
--   j4 = jParse "{\"Europa\": {\"Germany\": [\"Berlin\", \"Bonn\"]}}"
--   j5 = jParse "{\"Africa\": {}}"
--   j6 = jParse"{\"America\": {\"USA\": [], \"Canada\": [\"Toronto\"]}}"
--   j7 = jParse "{\"Australia\": [\"Melburn\", \"Adelaida\"]}"
--   merg = mergsRec [j1, j2, j3, j4, j5, j6, j7]
--   ex0 = putJson merg
--   
-- -- Result: -- --
--   {
--      "Africa": {
--      },
--      "America": {
--         "Canada": ["Toronto"],
--         "USA": []
--      },
--      "Asia": {
--         "Japan": ["Tokyo"]
--      },
--      "Australia": ["Melburn", "Adelaida"],
--      "Europa": {
--         "Germany": ["Berlin", "Bonn"],
--         "Ukraine": ["Kiyv", "Gitomir", "Lviv"],
--         "UnitedKingdom": ["London", "Glasgow"]
--      }
--   }
--   
mergesRec :: [Json] -> Json -- | filter JSON objects isObj :: JFilter -- | filter JSON arrays isArr :: JFilter -- | filter JSON strings isStr :: JFilter -- | predicative filter JSON strings isStrBy :: (String -> Bool) -> JFilter -- | filter JSON numbers isNum :: JFilter -- | predicative filter JSON numbers isNumBy :: Fractional a => (a -> Bool) -> JFilter -- | filter JSON Bool isBool :: JFilter -- | filter JSON null isNull :: JFilter -- | filter primitive types isPrimitive :: JFilter -- | get elements from object with keys -- -- Example: -- --
--   query1 = getFromKeys ["Europa", "America", "Africa"] 
--   json1 = query1 merg 
--   ex1 = putJsons json1
--   
-- -- Result: -- --
--   {
--      "Germany": ["Berlin", "Bonn"],
--      "Ukraine": ["Kiyv", "Gitomir", "Lviv"],
--      "UnitedKingdom": ["London", "Glasgow"]
--   }
--   {
--      "Canada": ["Toronto"],
--      "USA": []
--   }
--   {
--   
--   }
--   
getFromKeys :: [String] -> JFilter -- | get all elements from object getFromObj :: JFilter -- | get all elements from array getFromArr :: JFilter -- | get element from array with index getFromIndex :: Int -> JFilter -- | get elements from array with indexes getFromIndexes :: [Int] -> JFilter -- | get all elements from object and array getChildern :: JFilter -- | get elements from object with key getFromKey :: String -> JFilter -- | Example: -- --
--   query2 = query1 >>> getFromObj 
--   json2 = query2 merg
--   ex2 = putJsons json2
--   
-- -- Result: -- --
--   ["Berlin", "Bonn"]
--   ["Kiyv", "Gitomir", "Lviv"]
--   ["London", "Glasgow"]
--   ["Toronto"]
--   []
--   
(>>>) :: JFilter -> JFilter -> JFilter -- | concat result two filters (<+>) :: JFilter -> JFilter -> JFilter orElse :: JFilter -> JFilter -> JFilter when :: JFilter -> JFilter -> JFilter guards :: JFilter -> JFilter -> JFilter -- | tree traversal filter for object deepObj :: JFilter -> JFilter -- | tree traversal filter for array deepArr :: JFilter -> JFilter -- | tree traversal filter for objects and arrays -- -- Example: -- --
--   -- Qwery:  All city Europa, America, Australia and Africa
--   -- q31, q32, q33 is equal
--   
--   q31 = getFromKeys ["Europa", "America", "Africa", "Australia"] 
--     >>> (getFromArr `orElse`  getFromObj)
--     >>> (isStr `orElse` getFromArr)
--   
--   q32 = getFromKeys ["Europa", "America", "Africa", "Australia"] 
--     >>> (getFromObj `when` isObj)
--     >>> getFromArr
--   
--   q33 = getFromKeys ["Europa", "America", "Africa", "Australia"] 
--     >>> 
--   deep getFromArr
--   
-- -- See also: www.haskell.org/haskellwiki/HXT deep :: JFilter -> JFilter