Back to Search Start Over

Denotational Semantics and a Fast Interpreter for jq

Authors :
Färber, Michael
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