TY - JOUR ID - eprints3724 EP - 30 VL - 90 KW - ConcurrencyReversible computationBehavioral typesProcess calculi Y1 - 2017/// AV - public TI - Reversibility in session-based concurrency: A fresh look JF - Journal of Logical and Algebraic Methods in Programming UR - http://doi.org/10.1016/j.jlamp.2017.03.003 SN - 2352-2208 PB - Elsevier A1 - Mezzina, Claudio Antares A1 - Pérez, Jorge A. SP - 2 N2 - Much research has studied foundations for correct and reliable communication-centric software systems. A salient approach to correctness uses verification based on session types to enforce structured communications; a recent approach to reliability uses reversible actions as a way of reacting to unanticipated events or failures. In this paper, we develop a simple observation: the semantic machinery required to define asynchronous (queue-based), monitored communications can also support reversible protocols. We propose a framework of session communication in which monitors support reversibility of (untyped) processes. Main novelty in our approach are session types with present and past, which allow us to streamline the semantics of reversible actions. We prove that reversibility in our framework is causally consistent, and define ways of using monitors to control reversible actions. Keywords ER -