N.B. This is a strawman proposal This is primarily based on the stand-alone use-case and not part of any framework integration. As such, there are possibly edge or corner cases not taken into account. That said, this is mostly shifting class boundaries around a bit and clarifying semantics, rather than modifying the underlying logic.
The main context here is present-day use of Environment.new
, not the global ROM.setup
.
Very basic, slapdash first cut at a refactor: https://github.com/endash/rom/tree/rework-env (this really just served to test that the existing code could be re-arranged as intended and still work, not as a genuine attempt at a refactor).
Issue 1: We instantiate Environment
, but Environment
is throw-away. We actually want the Container
at the end, in all cases, so that we can get at relations, commands, etc. We even access the Container
via Environment#env
, so users are encouraged to mentally conflate the two. Environment
is, essentially, a sin