org.aspectj.weaver.tools.cache.GeneratedCachedClassHandler Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aspectjweaver Show documentation
Show all versions of aspectjweaver Show documentation
The AspectJ weaver applies aspects to Java classes. It can be used as a Java agent in order to apply load-time
weaving (LTW) during class-loading and also contains the AspectJ runtime classes.
/*******************************************************************************
* Copyright (c) 2012 Contributors.
* All rights reserved.
* This program and the accompanying materials are made available
* under the terms of the Eclipse Public License v 2.0
* which accompanies this distribution and is available at
* https://www.eclipse.org/org/documents/epl-2.0/EPL-2.0.txt
*
* Contributors:
* John Kew (vmware) initial implementation
* Lyor Goldstein (vmware) add support for weaved class being re-defined
*******************************************************************************/
package org.aspectj.weaver.tools.cache;
import org.aspectj.weaver.tools.GeneratedClassHandler;
/**
* Handler for generated classes; such as Shadowed closures, etc. This wraps the normal
* generated class handler with caching
*/
public class GeneratedCachedClassHandler implements GeneratedClassHandler {
private final WeavedClassCache cache;
private final GeneratedClassHandler nextGeneratedClassHandler;
public GeneratedCachedClassHandler(WeavedClassCache cache, GeneratedClassHandler nextHandler) {
this.cache = cache;
this.nextGeneratedClassHandler = nextHandler;
}
public void acceptClass (String name, byte[] originalBytes, byte[] wovenBytes) {
// The cache expects classNames in dot form
CachedClassReference ref = cache.createGeneratedCacheKey(name.replace('/', '.'));
cache.put(ref, originalBytes, wovenBytes);
if (nextGeneratedClassHandler != null) {
nextGeneratedClassHandler.acceptClass(name, originalBytes, wovenBytes);
}
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy