1674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen/* 2674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * Copyright 2003,2004 The Apache Software Foundation 3674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * 4674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * Licensed under the Apache License, Version 2.0 (the "License"); 5674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * you may not use this file except in compliance with the License. 6674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * You may obtain a copy of the License at 7674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * 8674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * http://www.apache.org/licenses/LICENSE-2.0 9674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * 10674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * Unless required by applicable law or agreed to in writing, software 11674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * distributed under the License is distributed on an "AS IS" BASIS, 12674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * See the License for the specific language governing permissions and 14674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * limitations under the License. 15674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen */ 16674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogenpackage org.mockito.cglib.proxy; 17674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen 18674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogenimport java.lang.reflect.Method; 19674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogenimport java.util.List; 20674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen 21674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen/** 22674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * Map methods of subclasses generated by {@link Enhancer} to a particular 23674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * callback. The type of the callbacks chosen for each method affects 24674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * the bytecode generated for that method in the subclass, and cannot 25674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * change for the life of the class. 26674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen */ 27674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogenpublic interface CallbackFilter { 28674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen /** 29674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * Map a method to a callback. 30674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * 31674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * @param method the intercepted method 32674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * @param allMethods all the methods found on the instance. Don't mess with the contents of this list!!! 33674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * @return the index into the array of callbacks (as specified by {@link Enhancer#setCallbacks}) to use for the method, 34674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen */ 35674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen int accept(Method method, List<Method> allMethods); 36674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen 37674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen /** 38674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * The <code>CallbackFilter</code> in use affects which cached class 39674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * the <code>Enhancer</code> will use, so this is a reminder that 40674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * you should correctly implement <code>equals</code> and 41674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * <code>hashCode</code> for custom <code>CallbackFilter</code> 42674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * implementations in order to improve performance. 43674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen */ 44674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen boolean equals(Object o); 45674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen} 46