• This repository has been archived on 25/Jul/2022
  • Stars
    star
    473
  • Rank 92,832 (Top 2 %)
  • Language
    Haskell
  • License
    BSD 3-Clause "New...
  • Created over 7 years ago
  • Updated over 2 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Functional sed for JSON

jl Build Status

jl ("JSON lambda") is a tiny functional language for querying and manipulating JSON.

Example:

$ jl 'map $ \o -> { sha: o.sha, ps: map _.sha o.parents }' x.json
[{"sha":"7b81a836c31500e685d043729259affa8b670a87","ps":["c538237f4e4c381d35f1c15497c...

Installing

Binary releases for Linux and OS X are available here.

Builds on Windows (see AppVeyor status), haven't added Windows binaries to the releases yet.

Installing from source:

  1. Get stack
  2. Run stack install in the repository directory.
  3. Add ~/.local/bin/ to your PATH.

Core syntax

Literals:

123, 4.5, -6, "hi", null, true, false

Lambdas:

\x -> y

Function application

get "f" o

Arithmetic:

x * (4 + 3)

Objects:

{foo: 123, bar: 34.3, "a:b": "hi"}

Arrays:

[1, 4 * 5, id 5]

Conditionals:

if x then y else z

Short-hand for fields:

o.f  is sugar for         get "f" o
_.f  is sugar for  (\o -> get "f" o)

For arrays:

_[0] is sugar for   (\o -> get 0 o)

Or objects:

_[k]     is sugar for   (\o -> get k o)
_["foo"] is sugar for   (\o -> get "foo" o)

Function composition:

a | b | c is sugar for `\x -> c (b (a x))`

Mini tutorial

You do everything with usual functional programming functions.

Returning the same thing, aka identity. That's normal in functional programming:

jl 'id'

A sequence of JSON strings will be read in and processed individually:

E.g.

$ cat x.json | jl id
{"a":1}
{"a":2}
{"a":3}
{"a":4}

If you want to read the input in as an array, use --array:

$ cat x.json | jl --array 'map _.a'
[1,2,3,4]

After processing, sometimes you want to print each element of the array out line by line, for that use --lines:

$ cat x.json | jl --array --lines 'map _.a'
1
2
3
4

Taking the first element of something, using syntax that looks like regular array access. The _ is a short-hand so that you don't need a lambda:

jl '_[0]'

If you want to get what keys are available, you can run:

jl 'map keys | _[0]'
["sha","committer","url","comments_url","parents","author","html_url","commit"]

Taking the first element and then creating a record of some parts of it:

jl '_[0] | \o -> {msg: o.commit.message, n: o.commit.committer.name}'

Note the use of | to compose functions. Just like in the shell.

Applying a function to all elements in an array:

jl 'map _.commit.committer.name'

Note how you can nest property access easily.

Applying something more detailed, by constructing a record of our own

jl 'map $ \o -> {msg: o.commit.message, n: o.commit.committer.name}'

You can use $ to avoid using parentheses on the right. That's a trick from Haskell.

Applying functions to nested data structures:

jl '_[0] | \o -> {msg: o.commit.message, n: o.commit.committer.name, ps: map _.html_url o.parents }'

Notice the ps property comes by taking the html_url of all the parents.

Filtering is easy, simply write a function that returns true:

jl 'map (\o -> { sha: o.sha, ps: map _.sha o.parents }) | filter (\o -> length o.ps > 1)'

If you want to make an object with arbitrary keys that come at runtime, use set:

$ echo '"hello"' | jl '\x -> set x 123 {}'
{"hello":123}

This sets the key x in the empty object {} to "hello" with the value 123. You can use set repeatedly to construct more keys.

If you want to construct an object from a list of key/values, you can use fold:

$ echo '[{"k":"foo","v":123},{"k":"bar","v":456}]' | jl 'fold (\acc o -> set o.k o.v acc) {}'
{"foo":123,"bar":456}

Available functions

Record access

get :: JSON β†’ JSON β†’ JSON

Get the value at k from the object

set :: JSON β†’ JSON β†’ JSON β†’ JSON

Set the value k to v in object

modify :: JSON β†’ (JSON β†’ JSON) β†’ JSON β†’ JSON

Modify the object at k with function f

keys :: JSON β†’ JSON

Get all keys of the object

elems :: JSON β†’ JSON

Get all elements of the object

Sequences

map :: (JSON β†’ JSON) β†’ JSON β†’ JSON

Apply a function to every element in the sequence

filter :: (JSON β†’ JSON) β†’ JSON β†’ JSON

Keep only items from the sequence for which p returns true

takeWhile :: (JSON β†’ JSON) β†’ JSON β†’ JSON

Take elements from a sequence while given predicate is true

empty :: JSON β†’ JSON

Is a sequence empty?

length :: JSON β†’ JSON

Get the length of a sequence

reverse :: JSON β†’ JSON

Reverse a sequence

drop :: JSON β†’ JSON β†’ JSON

Drop n items from the sequence

elem :: JSON β†’ JSON β†’ JSON

Is x an element of y?

concat :: JSON β†’ JSON

Concatenate a list of sequences into one sequence

zipWith :: (JSON β†’ JSON β†’ JSON) β†’ JSON β†’ JSON β†’ JSON

Zip two lists calling with each element to f x y

take :: JSON β†’ JSON β†’ JSON

Take n items from sequence

fold :: (JSON β†’ JSON β†’ JSON) β†’ JSON β†’ JSON β†’ JSON

Fold over a structure with a state.

dropWhile :: (JSON β†’ JSON) β†’ JSON β†’ JSON

Drop elements from a sequence while a predicate is true

any :: (JSON β†’ JSON) β†’ JSON β†’ JSON

Does p return true for any of the elements?

all :: (JSON β†’ JSON) β†’ JSON β†’ JSON

Does p return true for all of the elements?

nub :: JSON β†’ JSON

Return the sequence with no duplicates; the nub of it

sort :: JSON β†’ JSON

Return the sequence sorted

append :: JSON β†’ JSON β†’ JSON

Append the members of the second sequence to the first sequence

sum :: JSON β†’ JSON

Get the sum of a sequence

product :: JSON β†’ JSON

Get the product of a sequence

minimum :: JSON β†’ JSON

Get the minimum of a sequence

maximum :: JSON β†’ JSON

Get the maximum of a sequence

Strings

words :: JSON β†’ JSON

Split the string into a list of words

unwords :: JSON β†’ JSON

Join the list of strings into a string separated by spaces

lines :: JSON β†’ JSON

Split the string into a list of lines

unlines :: JSON β†’ JSON

Join the list of strings into a string separated by lines and terminated by a new line

Predicate operators

/= :: JSON β†’ JSON β†’ JSON

a /= b

= :: JSON β†’ JSON β†’ JSON

a = b

Boolean operators

&& :: JSON β†’ JSON β†’ JSON

a && b

|| :: JSON β†’ JSON β†’ JSON

a || b

not :: JSON β†’ JSON

not b

Numeric operators

> :: JSON β†’ JSON β†’ JSON

a > b

< :: JSON β†’ JSON β†’ JSON

a < b

>= :: JSON β†’ JSON β†’ JSON

a >= b

<= :: JSON β†’ JSON β†’ JSON

a <= b

* :: JSON β†’ JSON β†’ JSON

a * b

+ :: JSON β†’ JSON β†’ JSON

a + b

- :: JSON β†’ JSON β†’ JSON

a - b

/ :: JSON β†’ JSON β†’ JSON

a / b

min :: JSON β†’ JSON β†’ JSON

a min b

max :: JSON β†’ JSON β†’ JSON

a max b

abs :: JSON β†’ JSON

abs b

Function combinators

id :: JSON β†’ JSON

Identity function, returns its input unchanged

compose :: (JSON β†’ JSON) β†’ (JSON β†’ JSON) β†’ JSON β†’ JSON

Compose two functions

flip :: (JSON β†’ JSON β†’ JSON) β†’ JSON β†’ JSON β†’ JSON

Flips the argument order of a function of two or more arguments

More Repositories

1

elisp-guide

A quick guide to Emacs Lisp programming
1,397
star
2

intero

Haskell
1,021
star
3

jquery-console

A simple JQuery console emulator
JavaScript
668
star
4

hell

Haskell-based shell scripting language
Haskell
520
star
5

lucid

Clear to write, read and edit DSL for writing HTML
Haskell
284
star
6

vado

A demo web browser engine written in Haskell
Haskell
281
star
7

z

A strict, impure, curried, partially applied programming language with rather peculiar syntax.
Haskell
277
star
8

duet

A tiny language, a subset of Haskell aimed at aiding teachers teach Haskell
Haskell
201
star
9

dynamic

Dynamic typing in Haskell
Haskell
193
star
10

tryhaskell

Try Haskell
Haskell
187
star
11

hulk

Haskell IRC daemon.
Haskell
142
star
12

emacs-config

My Emacs config
Emacs Lisp
118
star
13

haskell-style-guide

95
star
14

ircbrowse

An IRC analysis server.
Haskell
80
star
15

purify

Reproducible builds for PureScript
Haskell
73
star
16

labels

Declare and access tuple fields with labels
Haskell
61
star
17

descriptive

Self-describing consumers/parsers
Haskell
41
star
18

ghci-reload-demo

A demo of using GHCi as a persistent development environment
Haskell
41
star
19

chrisdone-xmonad

My xmonad configuration.
Haskell
33
star
20

freenect

Haskell interface to Kinect.
Haskell
26
star
21

bdo

Do things in the browser from Emacs, namely update the stylesheet (but maybe more later)
Haskell
26
star
22

ats-examples

Examples from Introduction to Programming in ATS
ATS
25
star
23

present

Make presentations for data types
Haskell
25
star
24

audit

Code auditing mode for Emacs
Emacs Lisp
25
star
25

webshow

Show programming language printed values in a web UI
Haskell
22
star
26

sdl2-sprite

Create and animate sprites easily with sdl2 (Haskell)
Haskell
22
star
27

prana

Interpreter for GHC Haskell
Haskell
22
star
28

flycheck-stack

A flycheck checker that uses stack ghci
Emacs Lisp
22
star
29

ini

Quick and easy INI configuration files for Haskell
Haskell
22
star
30

zenburn

Fork of Zenburn theme for emacs
Emacs Lisp
20
star
31

inflex

Pure, statically typed, content-addressable, programming language for spreadsheet use
Haskell
20
star
32

ghc-server

A server interface to GHC.
Haskell
20
star
33

advent-2017-maze-rust-haskell

Haskell
17
star
34

google-closure-purescript

Dockerfile
16
star
35

streaming-parsers

Streaming parsers collection
Haskell
15
star
36

ace

Attempto Controlled English parser and printer
Haskell
15
star
37

scrobble

Scrobbling server. A library providing server-side and client-side support for the Audioscrobbler Realtime Submission protocol: http://www.audioscrobbler.net/development/protocol/
Haskell
15
star
38

flo

Generate flow charts from your code base.
Haskell
14
star
39

conditions

Conditions for Haskell
Haskell
14
star
40

pgsql-simple

A mid-level client library for the PostgreSQL database, intended to be fast and easy to use.
Haskell
13
star
41

sandbox

Small random demonstrations of code
Haskell
12
star
42

duta

Haskell
12
star
43

pure-io

Pure IO monad.
Haskell
11
star
44

caseof

A simple way to query constructors, like cases but slightly more concise
Haskell
11
star
45

css

Monadic Haskell DSL for CSS.
Haskell
10
star
46

rocksdb-haskell-ng

Haskell
9
star
47

snappy

A reactive library for using SVG in the browser for Haskell
Haskell
9
star
48

display

Haskell
8
star
49

ety

Simple API for etymology online
Haskell
8
star
50

copy-paste-sync

An easy way to share clipboard (not encrypted) on a trusted LAN
Haskell
8
star
51

tdiff

Simply print the time difference between lines from stdin
Haskell
8
star
52

frisby

Linear time composable parser for PEG grammars
Haskell
7
star
53

forge

Haskell form library
Haskell
7
star
54

asp-mode

A simple ASP mode for Emacs which does syntax highlighting and indentation support
Emacs Lisp
7
star
55

basic-lens

Basic lens type and functions
Haskell
6
star
56

number

Emacs number manipulation
Emacs Lisp
6
star
57

osdkeys

Show keys pressed with an on-screen display (Linux only)
Haskell
6
star
58

emacs-magit-config

Handy pre-made Emacs config for using magit
Emacs Lisp
6
star
59

org-focus

Emacs Lisp
6
star
60

haskell-exercises

Haskell training test suite
Haskell
6
star
61

gmail

GMail client for Emacs
Emacs Lisp
6
star
62

maintainer

Haskell
5
star
63

hex-server

A minimal X11 server written in Haskell
Haskell
5
star
64

cabal-sign

Haskell
5
star
65

blogination

Very simple blog software
Haskell
5
star
66

sorting

Sorting algorithms
Haskell
4
star
67

stack-doc

Show stack's documentation in Emacs
Emacs Lisp
4
star
68

fore

Haskell Core to JavaScript compiler
Haskell
4
star
69

cron-daemon

Run a program as a daemon
Haskell
4
star
70

keyboard-stats

Gather and produce statistics about keyboard typing habbits
Haskell
4
star
71

codeparty

Online code sharing teaching platform
JavaScript
4
star
72

pdfinfo

Simple pdfinfo wrapper
Haskell
4
star
73

haskelldb-demo

Haskell
4
star
74

hog

IRC logger bot
Haskell
3
star
75

clockin

Track clocking in and out of work.
Haskell
3
star
76

sourcemap

Implementation of source maps as proposed by Mozilla and Google
Haskell
3
star
77

proclog

Haskell
3
star
78

haskell-trace

Add tracing to modules.
Haskell
2
star
79

hamlet-mode

Emacs Lisp
2
star
80

pid1-rust

Rust
2
star
81

senza

An interface to blaze-html without the need for operators.
Haskell
2
star
82

env-args

Source program arguments from the environment in a predictable way
Haskell
2
star
83

url-generic

Parse/format generic key/value URLs from record data types.
Haskell
2
star
84

typegraph

Haskell
1
star
85

riker

Simple reverse proxy, replacement for nginx
Haskell
1
star
86

servant-example

Haskell
1
star
87

liquid-post

Haskell
1
star
88

terminal

Haskell
1
star
89

snap-app

Small snap modules for MVC.
Haskell
1
star
90

yesod-lucid

Haskell
1
star
91

novella

Haskell
1
star
92

codepad

Haskell library for pasting to CodePad
Haskell
1
star