Citation
Stulova, Nataliia and Morales Caballero, José Francisco and Hermenegildo, Manuel V.
(2014).
Assertion-based debugging of
higher-order (C)LP programs.
In: "16th International Symposium on Principles and Practice of Declarative Programming", 08-10 Sep 2014, Canterbury, Reino Unido. ISBN 978-1-4503-2947-7. pp. 225-235.
https://doi.org/10.1145/2643135.2643148.
Abstract
Higher-order constructs extend the expressiveness of firstorder
(Constraint) Logic Programming ((C)LP) both syntactically
and semantically. At the same time assertions have
been in use for some time in (C)LP systems helping programmers
detect errors and validate programs. However,
these assertion-based extensions to (C)LP have not been
integrated well with higher-order to date. This paper contributes
to filling this gap by extending the assertion-based
approach to error detection and program verification to the
higher-order context within (C)LP. We propose an extension
of properties and assertions as used in (C)LP in order
to be able to fully describe arguments that are predicates.
The extension makes the full power of the assertion language
available when describing higher-order arguments. We provide
syntax and semantics for (higher-order) properties and
assertions, as well as for programs which contain such assertions,
including the notions of error and partial correctness.
We also discuss several alternatives for performing run-time
checking of such programs.