distributed-static

Compositional, type-safe, polymorphic static values and closures

http://haskell-distributed.github.com

Version on this page:0.3.1.0
LTS Haskell 22.39:0.3.11@rev:1
Stackage Nightly 2024-10-31:0.3.11@rev:1
Latest on Hackage:0.3.11@rev:1

See all snapshots distributed-static appears in

BSD-3-Clause licensed by Edsko de Vries
This version can be pinned in stack with:distributed-static-0.3.1.0@sha256:4eed18be3d22e22ef68738482b905e06ff8522a294156b89d0b02d5b7296bb07,2165

Module documentation for 0.3.1.0

  • Control
    • Control.Distributed
      • Control.Distributed.Static

Towards Haskell in the Cloud (Epstein et al, Haskell Symposium 2011) introduces the concept of static values: values that are known at compile time. In a distributed setting where all nodes are running the same executable, static values can be serialized simply by transmitting a code pointer to the value. This however requires special compiler support, which is not yet available in ghc. We can mimick the behaviour by keeping an explicit mapping (RemoteTable) from labels to values (and making sure that all distributed nodes are using the same RemoteTable). In this module we implement this mimickry and various extensions: type safety (including for polymorphic static values) and compositionality.