################################
The |project| C++ Program Logic
################################
|project| is a program logic for low-level, concurrent C++ built on the Iris separation logic.
|project|'s goal is to develop a clear and compositional semantics of C++ programs, that can be used across many levels of abstraction.
.. topic:: Note
This repository does not provide usable verification tooling to apply these principles to real C++ programs.
If you are interested in verifying real, concurrent C++ programs using this logic, please open an issue an issue on this repository.
`BlueRock Security `_ has developed verification tools on top of this semantics that can be used to verify real C++ programs.
The |project| release contains two pieces:
* The cpp2v tool transforms C++ programs into a format that is digestible by the Coq proof assistant;
* The |project| program logic describes the meaning of C++ constructs in terms of reasoning principles that enable users to modularly derive the meaning of programs from their constituent pieces.
|project| focuses on a tailored (but relatively large) portion of modern C++.
Some high-level features (and non-features) include the following:
* |project| does not *currently* support some C++ features: e.g. member pointers, exceptions, goto, and virtual inheritance.
* |project| is currently limited to reasoning about templated code after it has been instantiated.
* Some features have restricted use: e.g. |project|'s support for switch statements does not support Duff's device.
* |project| adopts (limited) extensions to the C++ standard, based on existing research, e.g. for multi-address spaces, assembly interoperability, integer-to-pointer casts, and pointer provenance.
Our full feature set (as well as known issues) can be found on the :ref:`features ` page.
|project| is a work in progress. We welcome feedback, collaborations, and contributions.
.. toctree::
:maxdepth: 2
:caption: Table of Contents
features
evaluation
undefined_behavior
pointers
object_layout
machine
documentation
proof_examples
bibliography
acknowledgements
.. todo:: actually do something with these
..
Indices and tables
==================
* :ref:`genindex`
* :ref:`modindex`
* :ref:`search`