dc.creatorFigueroa, Ismael
dc.creatorTanter, Éric Pierre
dc.date.accessioned2016-06-28T22:00:49Z
dc.date.accessioned2019-04-26T00:52:46Z
dc.date.available2016-06-28T22:00:49Z
dc.date.available2019-04-26T00:52:46Z
dc.date.created2016-06-28T22:00:49Z
dc.date.issued2016
dc.identifierScience of Computer Programming 119 (2016) 3–30
dc.identifier0167-6423
dc.identifierDOI: 10.1016/j.scico.2015.11.010
dc.identifierhttp://repositorio.uchile.cl/handle/2250/139232
dc.identifier.urihttp://repositorioslatinoamericanos.uchile.cl/handle/2250/2443378
dc.description.abstractComputational effects complicate the tasks of reasoning about and maintaining software, due to the many kinds of interferences that can occur. While different proposals have been formulated to alleviate the fragility and burden of dealing with specific effects, such as state or exceptions, there is no prevalent robust mechanism that addresses the general interference issue. Building upon the idea of capability-based security, we propose effect capabilities as an effective and flexible manner to control monadic effects and their interferences. Capabilities can be selectively shared between modules to establish secure effect-centric coordination. We further refine capabilities with type-based permission lattices to allow fine-grained decomposition of authority. We provide an implementation of effect capabilities in Haskell, using type classes to establish a way to statically share capabilities between modules, as well as to check proper access permissions to effects at compile time. We first exemplify how to tame effect interferences using effect capabilities by treating state and exceptions. Then we focus on taming I/O by proposing a fine-grained lattice of I/O permissions based on the current classification of its operations. Finally, we show that integrating effect capabilities with modern tag-based monadic mechanisms provides a practical, modular and safe mechanism for monadic programming in Haskell.
dc.languageen
dc.publisherElsevier
dc.rightshttp://creativecommons.org/licenses/by-nc-nd/3.0/cl/
dc.rightsAtribución-NoComercial-SinDerivadas 3.0 Chile
dc.subjectMonads
dc.subjectCapabilities
dc.subjectComputational effects
dc.subjectTagged monads
dc.titleEffect capabilities for Haskell: Taming effect interference in monadic programming
dc.typeArtículos de revistas


Este ítem pertenece a la siguiente institución