FoCaLiZe: Inside an F-IDE

Research output: Contribution to journalConference articlepeer-review

Abstract

For years, Integrated Development Environments have demonstrated their usefulness in order to ease the development of software. High-level security or safety systems require proofs of compliance to standards, based on analyses such as code review and, increasingly nowadays, formal proofs of conformance to specifications. This implies mixing computational and logical aspects all along the development, which naturally raises the need for a notion of Formal IDE. This paper examines the FoCaLiZe environment and explores the implementation issues raised by the decision to provide a single language to express specification properties, source code and machine-checked proofs while allowing incremental development and code reusability. Such features create strong dependencies between functions, properties and proofs, and impose an particular compilation scheme, which is described here. The compilation results are runnable OCaml code and a checkable Coq term. All these points are illustrated through a running example.

Original languageEnglish
Pages (from-to)64-78
Number of pages15
JournalElectronic Proceedings in Theoretical Computer Science, EPTCS
Volume149
DOIs
Publication statusPublished - 26 Apr 2014
Event1st Workshop on Formal Integrated Development Environment, F-IDE 2014 - Grenoble, France
Duration: 6 Apr 2014 → …

Fingerprint

Dive into the research topics of 'FoCaLiZe: Inside an F-IDE'. Together they form a unique fingerprint.

Cite this