1. /*
  2. * Copyright 2002-2004 the original author or authors.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. package org.springframework.aop.interceptor;
  17. import org.aopalliance.intercept.MethodInterceptor;
  18. import org.aopalliance.intercept.MethodInvocation;
  19. /**
  20. * AOP Alliance MethodInterceptor that can be introduced in a chain to display
  21. * verbose information about intercepted invocations to the console.
  22. * @author Rod Johnson
  23. * @version $Id: DebugInterceptor.java,v 1.3 2004/03/18 02:46:09 trisberg Exp $
  24. */
  25. public class DebugInterceptor implements MethodInterceptor {
  26. private int count;
  27. /**
  28. * @see org.aopalliance.intercept.MethodInterceptor#invoke(MethodInvocation)
  29. */
  30. public Object invoke(MethodInvocation invocation) throws Throwable {
  31. ++count;
  32. System.out.println("Debug interceptor: count=" + count +
  33. " invocation=[" + invocation + "]");
  34. Object rval = invocation.proceed();
  35. System.out.println("Debug interceptor: next returned");
  36. return rval;
  37. }
  38. /**
  39. * Return the number of times this interceptor has been invoked
  40. * @return the number of times this interceptor has been invoked
  41. */
  42. public int getCount() {
  43. return this.count;
  44. }
  45. }