org.jruby.ext.ffi.FFI Maven / Gradle / Ivy
package org.jruby.ext.ffi;
import org.jruby.*;
import org.jruby.internal.runtime.methods.DynamicMethod;
import org.jruby.runtime.builtin.IRubyObject;
import java.util.Collections;
import java.util.Map;
import java.util.WeakHashMap;
/**
* The holder of all per-ruby-runtime FFI data
*/
public class FFI {
public final RubyModule ffiModule;
public final RubyClass memoryClass, bufferClass, pointerClass, memptrClass;
public final RubyClass structClass, functionClass, callbackClass;
public final RubyClass typeClass;
public final RubyHash typedefs;
private final NullMemoryIO nullMemoryIO;
private final TypeResolver typeResolver;
/**
* Reference map to keep libraries open for as long as there is a method mapped
* to that library.
*/
private final Map refmap
= Collections.synchronizedMap(new WeakHashMap());
public FFI(RubyModule ffiModule) {
this.ffiModule = ffiModule;
this.bufferClass = ffiModule.getClass("Buffer");
this.pointerClass = ffiModule.getClass("Pointer");
this.memptrClass = ffiModule.getClass("MemoryPointer");
this.memoryClass = ffiModule.getClass("AbstractMemory");
this.structClass = ffiModule.getClass("Struct");
this.functionClass = ffiModule.getClass("Function");
this.callbackClass = ffiModule.getClass("Callback");
this.typeClass = ffiModule.getClass("Type");
this.typedefs = (RubyHash) ffiModule.getConstant("TypeDefs");
this.typeResolver = new TypeResolver(this);
this.nullMemoryIO = new NullMemoryIO(ffiModule.getRuntime());
}
public final TypeResolver getTypeResolver() {
return typeResolver;
}
public NullMemoryIO getNullMemoryIO() {
return nullMemoryIO;
}
public void registerAttachedMethod(DynamicMethod method, AbstractInvoker invoker) {
refmap.put(method, invoker);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy