org.mvel2.optimizers.dynamic.DynamicOptimizer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of mvel2 Show documentation
Show all versions of mvel2 Show documentation
A fork of MVEL by Axibase. Original version is hosted here: https://github.com/mvel/mvel.
MVEL is a powerful expression language for Java-based applications.
It provides a plethora of features and is suited for everything
from the smallest property binding and extraction, to full blown scripts.
/**
* MVEL 2.0
* Copyright (C) 2007 The Codehaus
* Mike Brock, Dhanji Prasanna, John Graham, Mark Proctor
*
* 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.mvel2.optimizers.dynamic;
import org.mvel2.ParserContext;
import org.mvel2.compiler.Accessor;
import org.mvel2.integration.VariableResolverFactory;
import org.mvel2.optimizers.AbstractOptimizer;
import org.mvel2.optimizers.AccessorOptimizer;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;
import static java.lang.Thread.currentThread;
import static org.mvel2.optimizers.OptimizerFactory.SAFE_REFLECTIVE;
import static org.mvel2.optimizers.OptimizerFactory.getAccessorCompiler;
import static org.mvel2.optimizers.impl.asm.ASMAccessorOptimizer.setMVELClassLoader;
public class DynamicOptimizer extends AbstractOptimizer implements AccessorOptimizer {
private AccessorOptimizer firstStage = getAccessorCompiler(SAFE_REFLECTIVE);
private static final Object oLock = new Object();
private volatile static DynamicClassLoader classLoader;
public static int tenuringThreshold = 50;
public static long timeSpan = 100;
public static int maximumTenure = 1500;
public static int totalRecycled = 0;
private static volatile boolean useSafeClassloading = false;
private static ReadWriteLock lock = new ReentrantReadWriteLock();
private static Lock readLock = lock.readLock();
private static Lock writeLock = lock.writeLock();
public void init() {
_init();
}
private static void _init() {
setMVELClassLoader(classLoader = new DynamicClassLoader(currentThread().getContextClassLoader(), maximumTenure));
}
public static void enforceTenureLimit() {
writeLock.lock();
try{
if (classLoader.isOverloaded()) {
classLoader.deoptimizeAll();
totalRecycled = +classLoader.getTotalClasses();
_init();
}
}
finally{
writeLock.unlock();
}
}
public static final int REGULAR_ACCESSOR = 0;
public Accessor optimizeAccessor(ParserContext pCtx, char[] property, int start, int offset, Object ctx, Object thisRef,
VariableResolverFactory factory, boolean rootThisRef, Class ingressType) {
readLock.lock();
try{
pCtx.optimizationNotify();
return classLoader.registerDynamicAccessor(new DynamicGetAccessor(pCtx, property, start, offset, 0,
firstStage.optimizeAccessor(pCtx, property, start, offset, ctx, thisRef, factory, rootThisRef, ingressType)));
}
finally{
readLock.unlock();
}
}
public static final int SET_ACCESSOR = 1;
public Accessor optimizeSetAccessor(ParserContext pCtx, char[] property, int start, int offset, Object ctx, Object thisRef,
VariableResolverFactory factory, boolean rootThisRef, Object value, Class valueType) {
readLock.lock();
try{
return classLoader.registerDynamicAccessor(new DynamicSetAccessor(pCtx, property, start, offset,
firstStage.optimizeSetAccessor(pCtx, property, start, offset, ctx, thisRef, factory, rootThisRef, value, valueType)));
}
finally{
readLock.unlock();
}
}
public static final int COLLECTION = 2;
public Accessor optimizeCollection(ParserContext pCtx, Object rootObject, Class type, char[] property, int start,
int offset, Object ctx, Object thisRef, VariableResolverFactory factory) {
readLock.lock();
try{
return classLoader.registerDynamicAccessor(new DynamicCollectionAccessor(pCtx, rootObject, type, property, start, offset, 2,
firstStage.optimizeCollection(pCtx, rootObject, type, property, start, offset, ctx, thisRef, factory)));
}
finally{
readLock.unlock();
}
}
public static final int OBJ_CREATION = 3;
public Accessor optimizeObjectCreation(ParserContext pCtx, char[] property, int start, int offset,
Object ctx, Object thisRef, VariableResolverFactory factory) {
readLock.lock();
try{
return classLoader.registerDynamicAccessor(new DynamicGetAccessor(pCtx, property, start, offset, 3,
firstStage.optimizeObjectCreation(pCtx, property, start, offset, ctx, thisRef, factory)));
}
finally{
readLock.unlock();
}
}
public static boolean isOverloaded() {
return classLoader.isOverloaded();
}
public Object getResultOptPass() {
return firstStage.getResultOptPass();
}
public Class getEgressType() {
return firstStage.getEgressType();
}
public boolean isLiteralOnly() {
return firstStage.isLiteralOnly();
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy