Skip to Main content Skip to Navigation
New interface
Journal articles

Omniscient Debugging for Executable DSLs

Abstract : Omniscient debugging is a promising technique that relies on execution traces to enable free traversal of the states reached by a model (or program) during an execution. While a few General-Purpose Languages (GPLs) already have support for omniscient debugging, developing such a complex tool for any executable Domain Specific Language (DSL) remains a challenging and error prone task. A generic solution must: support a wide range of executable DSLs independently of the metaprogramming approaches used for implementing their semantics; be efficient for good responsiveness. Our contribution relies on a generic omniscient debugger supported by efficient generic trace management facilities. To support a wide range of executable DSLs, the debugger provides a common set of debugging facilities, and is based on a pattern to define runtime services independently of metaprogramming approaches. Results show that our debugger can be used with various executable DSLs implemented with different metaprogramming approaches. As compared to a solution that copies the model at each step, it is on average six times more efficient in memory, and at least 2.2 faster when exploring past execution states, while only slowing down the execution 1.6 times on average.
Document type :
Journal articles
Complete list of metadata

Cited literature [53 references]  Display  Hide  Download
Contributor : Erwan Bousse Connect in order to contact the contributor
Submitted on : Wednesday, December 13, 2017 - 9:29:35 AM
Last modification on : Friday, November 18, 2022 - 9:38:04 AM


Files produced by the author(s)



Erwan Bousse, Dorian Leroy, Benoit Combemale, Manuel Wimmer, Benoit Baudry. Omniscient Debugging for Executable DSLs. Journal of Systems and Software, 2018, 137, pp.261-288. ⟨10.1016/j.jss.2017.11.025⟩. ⟨hal-01662336⟩



Record views


Files downloads