This paper describes a Java-based framework for the development of component-based software systems supporting the specification of the logic of component interactions as a first-class aspect. Java is used as the reference development language. On the one side, the framework makes it possible to specify the logic of interaction at the component-level, in terms of input and output interfaces, the events generated and observed by a component, and related information about the management of the control flow. On the other side, it is possible to specify the logic of interaction at the inter-component level, providing a modelling and linguistic support for designing and (dynamically) programming the glue among the components, enabling general forms of observation, control and construction of the interaction space. As a result, the framework supports the coordination of components at different levels: from interoperability among heterogeneous and unknown components, to the support for dynamic introduction, removal and update of components, to general coordination patterns, such as workflow. The framework adopts first-order logic as the reference computational model for describing and defining the logic of interaction: the modalities adopted by components to interact, the coordination laws gluing the components and the interaction events occurring in the system are expressed as facts and rules. They compose the (evolving) logic theories describing and defining the interaction at the system level, and can be observed and controlled at runtime to allow dynamic re-configurability.
[1]
David C. Luckham,et al.
An Event-Based Architecture Definition Language
,
1995,
IEEE Trans. Software Eng..
[2]
Farhad Arbab,et al.
Abstract Behavior Types: a foundation model for components and their composition
,
2002,
Sci. Comput. Program..
[3]
Lodewijk Bergmans,et al.
Composing crosscutting concerns using composition filters
,
2001,
CACM.
[4]
Nicholas Carriero,et al.
Coordination languages and their significance
,
1992,
CACM.
[5]
Andrea Omicini,et al.
Programmable Coordination Media
,
1997,
COORDINATION.
[6]
Andrea Omicini,et al.
Multi-paradigm Java-Prolog integration in tuProlog
,
2005,
Sci. Comput. Program..
[7]
Naranker Dulay,et al.
Specifying Distributed Software Architectures
,
1995,
ESEC.
[8]
Farhad Arbab,et al.
Coordination Models and Languages
,
1998,
Adv. Comput..
[9]
David Garlan,et al.
Acme: an architecture description interchange language
,
1997,
CASCON.
[10]
David Garlan,et al.
Software architecture: a roadmap
,
2000,
ICSE '00.
[11]
Clemens A. Szyperski,et al.
Component software - beyond object-oriented programming
,
2002
.
[12]
Bradley R. Schmerl,et al.
Rainbow: Architecture-Based Self-Adaptation with Reusable Infrastructure
,
2004,
Computer.
[13]
Bradley R. Schmerl,et al.
Rainbow: architecture-based self-adaptation with reusable infrastructure
,
2004,
International Conference on Autonomic Computing, 2004. Proceedings..