3.1 Locations
3.1.2 Science (and) fiction
Nesta seção é ilustrado o mapeamento entre os conceitos de orientação a aspectos providos por aSideML, no nível de projeto detalhado, para os conceitos providos pelo Metaspin, no nível de implementação abstrato de aspectos.
i. Mapeamento de Aspectos de aSideML para Aspectos no Metaspin: um aspecto em
aSideML é representado como um conjunto de características que enriquecem a estrutura e o comportamento de classes por meio de crosscutting. Dessa forma, os aspectos em aSideML são definidos usando-se argumentos fornecidos para parâmetros de template (Template Parameter) através de relacionamento crosscutting. Por sua vez, o Metaspin define um aspecto como um conjunto de seletores join point selectors, advices e variables e operations. Os aspectos de aSideML tem seu nome, atributos e conjunto de operações mapeados para o aspecto no Metaspin. A Figura 20 ilustra o mapeamento dos elementos de um aspecto aSideML para o Metaspin.
Figura 20 - Mapeamento de Aspecto em aSideML para Aspecto no Metaspin
ii. Mapeamento de Parâmetros de Template de aSideML para Join Point Selector no Metaspin: As operações de parâmetros de template definidos por aSideML são
placeholders para operações. Esses parâmetros de template de operação podem ser definidos e referenciados dentro de especificações de interação, denotando que são pointcuts para o comportamento crosscutting. O Metaspin representa o conceito de pointcut através de Join Point Selectors. Dessa forma, os parâmetros de template de aSideML são mapeados (ver Figura 21) para os join point selectors do Metaspin. O Join Point Selector possui uma expressão de pointcut. Essa expressão pode ser formada pela aplicação de um predicado simples ou ser composta através da aplicação de múltiplos predicados. A expressão de pointcut é representada no Metaspin como um predicado (Predicate) que possui a referencia aos join point que irão compor o pointcut do aspecto.
Figura 21 - Mapeamento de Template Parameter para Join Point Selector
iii. Mapeamento de Template Match de aSideML para Join Points no Metaspin: Os casamentos de template (Template Match) definidos em aSideML são um conjunto de
operações a serem substituídas pelos advices dos aspectos. Essas operações estão relacionadas com os join points que determinado aspecto trata. Os elementos definidos no join point do Template match (classes, métodos ou declarações) são mapeados diretamente para o conceito de join points no Metaspin. O Metaspin provê representação de join points estruturais e comportamentais. No entanto, em virtude de o nosso trabalho foca em modelagem estrutural utilizou-se somente a representação de join points estruturais. Logo, as classes, métodos ou declarações definidas no join point do Template Match de aSideML são mapeados (ver Figura 22) no Metaspin para Class Join Point Part, Method Join Point Part e Statement Join Point Part, respectivamente.
Figura 22 - Mapeamento de TemplateMatch para Join Points
iv. Mapeamento de características transversais estruturais para Intertype Declarations: em aSideML, uma característica transversal estrutural é a especificação de um
atributo que será introduzido na interface de uma ou mais classes base [Chavez, 2004]. A linguagem aSideML define que o elemento Additions deverá conter assinaturas de operações ou novos atributos, de forma que essas características possam ser incorporadas pelo aspecto em classes e interfaces que representam o código base. O Metaspin não provê elementos para o tratamento deste tipo de informação. Como forma de evitar perda de informações dos modelos estruturais, foi introduzido o elemento Intertype Declaration no metamodelo do Metaspin. Assim, os elementos Additions agora são mapeados para Intertype Declaration no Metaspin (Ver Figura 23).Além disso, os elementos que são incorporados nas interfaces ou classes são anotados com comentário do tipo “From aSideML – Crosscutting Structural Feature”, informando qual o elemento de Additions de aSideML foi mapeado para o Intertype Declaration a ser introduzido em determinada classe ou Interface.
Figura 23 - Mapeamento de Additions em aSideML para Intertype Declarations no Metaspin
v. Mapeamento de características transversais comportamentais para Advice Action e Advice Type: em aSideML, uma característica transversal comportamental é uma
especificação de parte do comportamento que será adicionado a uma ou mais classes do código base da aplicação. As características transversais comportamentais podem ser listadas em diferentes compartimentos de uma interface transversal de aSideML, tais como redefinições e refinamentos. As redefinições (Redefinitions) e refinamentos (Refinements) possuem elementos do tipo Adorno e Operation. Tais elementos irão compor o advice do metamodelo Metaspin. O elemento Operation é mapeado para a ação do advice (Advice Action), que neste caso é especializado para uma ação de meta-nível (Metalevel Action), correspondendo a um elemento do tipo EvalJoinPointInstruction. Adicionalmente, cada operação correspondente a uma característica transversal comportamental deve vir comentada indicando se tal característica sofreu um refinamento ou redefinição. Por outro lado, o elemento Adorno é mapeado para um avaliador de advice (Advice Evaluator), visto que cada ação de advice deve ter um avaliador relacionado. O avaliador de advice geralmente possui valores do tipo before, after e around.
Figura 24 - Mapeamento de Redefinition e Refinement em aSideML para advice no Metaspin
A Figura 24 ilustra o mapeamento entre as características transversais do tipo redefinition e refinement pertencentes à uma interface transversal para o advice de um aspecto expresso em um modelo Metaspin. A Tabela 2 resume o mapeamento entre os elementos de aSideML, que representam os conceitos de orientação a aspectos em nível de projeto detalhado, para os elementos do Metaspin.
Tabela 2 - Mapeamento entre aSideML e Metaspin
aSideML Metaspin
Aspect Aspect
Template Parameter Join Point Selector
Template Match
Joinpoint Joinpoint (conjunto de operações afetadas pelo aspecto).
Additions Intertype Declaration (operações ou atributos que serão inseridos em interfaces ou classes do código base)
Operation Advice Action: corresponde à ação a ser
executada em um advice. Crosscutting
Interface
Redefinition / Refinement
Adorno Advice Evaluator: corresponde a quando a ação do advice deverá ser executada (before, after, around)