3.13 What are Reach’s limitations and its future roadmap
Today, Reach is a powerful language for building decentralized applications, as demonstrated in the overview, the tutorial, and the workshop series.
However, it has a lot of potential for growth.
This section describes a few of these areas and gives brief sketches of our roadmap for directing this growth.
We welcome your contributions on GitHub and on the Discord community to helping make these improvement plans come to fruition.
Foremost, Reach is a consensus network
-agnostic language, so one of our highest priorities is supporting a wide variety of platforms, including layer-2 abstractions over other layer-1 networks.
Presently, we have a robust Ethereum backend
and Algorand backend
Presently, Reach has a robust backend
However, we believe that many decentralized application developers would like to make use of languages like Go and Rust for their participants.
Presently, this can be accomplished via the Reach RPC Server
, but we’d like to build a dedicated backend for languages like these.
, free-form objects, destructuring bindings, robust
specificiers, and so on.
We have plans to extend Reach’s type system to be able to track more specific features of values, such as substructural types
to allow mutation and arbitrary range integer types, which will be coalesced during compilation.
Finally, we have plans to allow more exotic features, like non-communicating loops with guaranteed termination, statically computable exceptions, and pay-as-you-go closures, including non-tail-recursion through closure conversion of non-contifiable continuations.
Verification. Reach’s verifier is robust in the face of many complex and interesting theorems about decentralized application behavior.
In the longer term, we intend to introduce verification promises that constrain the eventual use of values, refine the knowledge checker to reduce false positives, verify core compiler algorithms, and introduce a model-checking-based assertion mechanism for specifying game theoretic properties of an application, such as that all state changes are Pareto improvements.
Infrastructure. We intend to build a package system for Reach to allow for sharing composable decentralized applications.
Since Reach is consensus network
-agnostic, it is not possible for Reach programs to directly integrate with network-specific features, such as observing the blockhash on Ethereum.
Reach programs can instead interact with these low-level details of their chosen consensus network via remote object
Reach’s communication language has some limitations that we have plans to remove.
For example, Reach linear state
must be linear in the number of participants to the application, rather than in the number of publications
, because some consensus networks do not support the latter.
We plan to allow such programs and simply limit which networks they may compile to.
Reach’s communication language has some limitations for which we do not have plans for removing.
For example, we do not intend to support co-inductive or cyclic state, nor expose an arbitrary consensus heap to programmers.