Bryan O'Sullivan avatar Bryan O'Sullivan committed c4221fe

Make Value an instance of Hashable.

Comments (0)

Files changed (1)

Data/Aeson/Types.hs

 import Data.Aeson.Functions
 import Data.Attoparsec.Char8 (Number(..))
 import Data.Data (Data)
+import Data.Hashable (Hashable(..))
 import Data.Int (Int8, Int16, Int32, Int64)
+import Data.List (foldl')
 import Data.Map (Map)
 import Data.Monoid (Dual(..), First(..), Last(..))
 import Data.Monoid (Monoid(..))
     fromString = String . pack
     {-# INLINE fromString #-}
 
+instance Hashable Value where
+    hash (Object o) = foldl' hashWithSalt 0 . M.toList $ o
+    hash (Array a)  = V.foldl' hashWithSalt 1 a
+    hash (String s) = 2 `hashWithSalt` s
+    hash (Number n) = 3 `hashWithSalt` case n of I i -> hash i; D d -> hash d
+    hash (Bool b)   = 4 `hashWithSalt` b
+    hash Null       = 5
+
 -- | The empty array.
 emptyArray :: Value
 emptyArray = Array V.empty
Tip: Filter by directory path e.g. /media app.js to search for public/media/app.js.
Tip: Use camelCasing e.g. ProjME to search for ProjectModifiedEvent.java.
Tip: Filter by extension type e.g. /repo .js to search for all .js files in the /repo directory.
Tip: Separate your search with spaces e.g. /ssh pom.xml to search for src/ssh/pom.xml.
Tip: Use ↑ and ↓ arrow keys to navigate and return to view the file.
Tip: You can also navigate files with Ctrl+j (next) and Ctrl+k (previous) and view the file with Ctrl+o.
Tip: You can also navigate files with Alt+j (next) and Alt+k (previous) and view the file with Alt+o.