/**************************************************************************************
* Copyright (c) Jonas Bon�r, Alexandre Vasseur. All rights reserved. *
* http://aspectwerkz.codehaus.org *
* ---------------------------------------------------------------------------------- *
* The software in this package is published under the terms of the LGPL license *
* a copy of which has been included with this distribution in the license.txt file. *
**************************************************************************************/
package org.codehaus.aspectwerkz.joinpoint.management;
import org.codehaus.aspectwerkz.AdviceInfo;
import java.io.Serializable;
/**
* Handles the execution of the before advices.
*
* @author <a href="mailto:jboner@codehaus.org">Jonas Bon�r </a>
* @author <a href="mailto:alex@gnilux.com">Alexandre Vasseur </a>
*/
public class BeforeAdviceExecutor implements Serializable {
/**
* The advices indexes.
*/
private final AdviceInfo[] m_adviceIndexes;
/**
* Creates a new advice executor.
*
* @param adviceIndexes
*/
public BeforeAdviceExecutor(final AdviceInfo[] adviceIndexes) {
m_adviceIndexes = adviceIndexes;
}
/**
* Executes its advices one by one. After the last advice has been executed, the original method is invoked.
*
* @param joinPoint the current join point
* @return null
*/
public Object proceed(final JoinPointBase joinPoint) throws Throwable {
if (!joinPoint.isInCflow()) {
return null;
}
for (int i = 0, j = m_adviceIndexes.length; i < j; i++) {
AdviceInfo index = m_adviceIndexes[i];
int aspectIndex = index.getAspectIndex();
int methodIndex = index.getMethodIndex();
index.getAspectManager().getAspectContainer(aspectIndex).invokeAdvice(methodIndex, joinPoint, index.getMethodToArgIndexes());
}
return null;
}
/**
* Checks if the executor has any advices.
*
* @return true if it has advices
*/
public boolean hasAdvices() {
return m_adviceIndexes.length != 0;
}
}