blob: 45c0fb614ce8f0243e4007db0df46d4dcbd81f78 [file] [log] [blame]
/*
* Copyright 2004-2005 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.codehaus.groovy.grails.commons.metaclass;
/**
* <p>Dynamic method invocation callback interface. Implementation classes
* can add a persistence functionality to Grails like save and delete.
*
* @author Steven Devijver
* @since Aug 7, 2005
*/
public interface DynamicMethodInvocation {
/**
* <p>Checks if a method name matches the criteria of the implementation class.
*
* @param methodName the static method name
* @return result of criteria match test
*/
public boolean isMethodMatch(String methodName);
/**
* <p>Returns the method name for this method implementation.
*
* @return method name
*/
public String getMethodName();
/**
* <p>Invokes the actual method. The target object and arguments are supplied.
*
* @param target the target on which the method is invoked.
* @param argumetns the arguments passed in the method call
* @param the return value of the dynamic method invocation.
*/
public Object invoke(Object target, Object[] arguments);
}