Component interdependencies might appear deeply nested in the component. Remember that component comes from the Latin word "componere" which means being composed. The following example shows a use-relation between A.B and X.Y.
data:image/s3,"s3://crabby-images/9ba81/9ba81a0a3031abc6e13a3745654d160e39957e69" alt=""
data:image/s3,"s3://crabby-images/510d9/510d932bcdf7880551b983668b610efa6c3153cb" alt=""
data:image/s3,"s3://crabby-images/e9389/e938914f9034add7403cb7705d2d24050db3c971" alt=""
Technical Architecture
You may argue that component are not complex enough to control their use-relation by an explicit dependency. But imagine a software architecture which is based on layers and packages:
data:image/s3,"s3://crabby-images/7b190/7b190f9df22300871ad24a600266297db0dcba77" alt=""
Just imagine you could explicitly define the dependencies between the packages. And now imagine that every template inter-dependency (one generic class using other generic classes) is checked immediately by the actifsource real-time validator.
Providing such a system your technical architecture would be documented soundly. And moreover actifsource would ensure that your code follows perfectly along the architecture.
Business Architecture
Another very interesting application of dependency relations is found when designing the business architecture. Coping with a complex business domain the relating business objects have to be structured to keep the overview.
data:image/s3,"s3://crabby-images/12df4/12df4a0b38123c698604e7ecbd3f6923309eba1f" alt=""
Providing such a system would allow you to group domain objects together for a perfect overview. Moreover actifsource would ensure that any relationship between components follows the well defined business architecture.Conclusion
Modeling explicit dependencies allows you to control use-relations from a higher view. This view is what we usually call the architecture overview. actifsource could not only provide sound documentation of the architecture (technical and business) but also ensure at real-time that no artifact breaks the dependency rules.
The secret to this functionality lies in typed folders as Micha described in his blog Grouping Is Domain Specific Too. In one of my next blogs I try to workout the tricky details.
No comments:
Post a Comment