Back to Search
Start Over
Denotational Semantics and a Fast Interpreter for jq
- Publication Year :
- 2023
-
Abstract
- jq is a widely used tool that provides a programming language to manipulate JSON data. However, its semantics are currently only specified by its implementation, making it difficult to reason about its behaviour. To this end, I provide a syntax and denotational semantics for a subset of the jq language. In particular, the semantics provide a new way to interpret updates. I implement an extended version of the semantics in a novel interpreter for the jq language called jaq. Although jaq uses a significantly simpler approach to execute jq programs than jq, jaq is faster than jq on ten out of thirteen benchmarks.<br />Comment: Submitted to OOPSLA 2023
Details
- Database :
- arXiv
- Publication Type :
- Report
- Accession number :
- edsarx.2302.10576
- Document Type :
- Working Paper