Comments (2)
Hi @seancorfield,
I've given this a lot of thought over the past few weeks.
You can already use non-Associative objects in a Component System as long as they do not have dependencies. I've seen functions, Java objects, and core.async Channels all used as Components. You don't have to return a map/record from Lifecycle/start
either; that's just a convention.
Components only need to be Associative when they have dependencies. The use of assoc
for dependencies is pretty fundamental to the design. In particular, it ensures that any Component in a started System is functionally indistinguishable from a complete System. This is a useful property when combining systems.
Allowing dependencies to be passed via metadata would mean having Components which are not Associative but are metadata-compatible. That's a small set of Clojure-native types. It would not allow, for example, a Java object to be used as a Component with dependencies. It's already common to wrap Java objects in Clojure maps or Records just to get metadata capabilities, so nothing much would change there.
While I'm not totally against this in theory, I currently do not envision a significant benefit relative to the additional complexity it would introduce. If you have other use cases in mind, I would be happy to discuss them further.
Thanks for the suggestion!
–S
from component.
Thanks for the feedback and for taking the time to analyze the suggestion. I agree that it adds a non-trivial amount of complexity and I was fairly sure you wouldn't consider the benefits to be worthwhile -- but I figured it was worth raising. I don't really have a concrete use case right now -- I've always found ways to fit into Component's world view so far. I'll close this out (but feel free to reopen if you want to keep it in play for future discussion etc).
from component.
Related Issues (20)
- Cljs source files requiring component break refresh for clj code HOT 9
- Question: Whether it should be okay to pass system record directly to a special component HOT 1
- still dependent on IoC container? HOT 1
- Startup with asynchronous components? HOT 8
- Add an option to log components/keys as they are started HOT 1
- start/stop don't call a component's start/stop when there is no dependencies in the system map... HOT 1
- init.el helper fns HOT 1
- How to inject db transaction per http request? HOT 1
- Reloading with component *without* introducing global state HOT 1
- Feature request: add system key metadata to components HOT 1
- :extend-via-metadata in 0.4.0 breaks on ClojureScript < 1.10.516 HOT 2
- Component includes org.clojure/clojure as a transitive dependency HOT 5
- Cleaning up component dependencies by default HOT 2
- Make it possible to start a subsystem? HOT 4
- Provide an example explaining the ?essence? of the components idea
- Keys of already started components for `::component/component-function-threw-exception` HOT 2
- ec alpha
- Multiple dependencies of same "type" HOT 1
- Using ECS lib for getting rid of deftypes/defrecords/defprotocols HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from component.