hjsonpointer: JSON Pointer library

[ data, deprecated, library, mit ] [ Propose Tags ] [ Report a vulnerability ]
Deprecated

Modules

[Index]

Downloads

Note: This package has metadata revisions in the cabal description newer than included in the tarball. To unpack the package including the revisions, use 'cabal get'.

Maintainer's Corner

Package maintainers

For package maintainers and hackage trustees

Candidates

  • No Candidates
Versions [RSS] 0.1.0.0, 0.1.0.1, 0.2.0.0, 0.2.0.1, 0.2.0.2, 0.2.0.3, 0.2.0.4, 0.3.0.0, 0.3.0.1, 0.3.0.2, 1.0.0.0, 1.0.0.1, 1.0.0.2, 1.1.0.0, 1.1.0.1, 1.1.0.2, 1.1.1, 1.2.0, 1.3.0, 1.4.0, 1.5.0
Change log changelog.md
Dependencies aeson (>=0.7 && <1.3), base (>=4.6 && <4.10), hashable (>=1.2 && <1.3), QuickCheck (>=2.8 && <2.11), semigroups (>=0.18 && <0.19), text (>=1.2 && <1.3), unordered-containers (>=0.2 && <0.3), vector (>=0.10 && <0.13) [details]
License MIT
Author Ian Grant Jeffries
Maintainer ian@housejeffries.com
Revised Revision 3 made by AdamBergmark at 2017-06-28T07:31:35Z
Category Data
Home page https://github.com/seagreen/hjsonpointer
Source repo head: git clone git://github.com/seagreen/hjsonpointer.git
Uploaded by seagreen at 2017-06-26T21:10:22Z
Distributions
Reverse Dependencies 2 direct, 6 indirect [details]
Downloads 16734 total (69 in the last 30 days)
Rating 1.75 (votes: 1) [estimated by Bayesian average]
Your Rating
  • λ
  • λ
  • λ
Status Docs available [build log]
Last success reported on 2017-06-26 [all 1 reports]

Readme for hjsonpointer-1.2.0

[back to package description]

Summary

JSON Pointer library for Haskell.

Hackage / GitHub / Travis CI

Example

module Example where import Control.Monad (unless) import Data.Aeson import qualified JSONPointer as JP main :: IO () main = do -- JSON Pointers must either be empty or start with a /. pntr1 <- case JP.unescape "/foo/0" of Left _ -> error "Failed to construct JSON Pointer." Right pntr -> return pntr -- We can also write JSON Pointers in Haskell. let pntr2 = JP.Pointer [JP.Token "/"] -- When we do this we don't have to escape / or ~ characters -- (as ~1 and ~0 respectively) like we do in an escaped JSON -- Pointer string. unless (JP.unescape "/~1" == Right pntr2) (error "ohno!") print (JP.resolve pntr1 document) print (JP.resolve pntr2 document) where document :: Value document = object [ "foo" .= [String "bar", String "baz"] , "/" .= String "quux" ] 

Output:

Right (String "bar") Right (String "quux")