org.lwjgl.opencl.CLContextDestructorCallbackI Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of lwjgl-opencl Show documentation
Show all versions of lwjgl-opencl Show documentation
An open, royalty-free standard for cross-platform, parallel programming of diverse processors found in personal computers, servers, mobile devices and embedded platforms.
The newest version!
/*
* Copyright LWJGL. All rights reserved.
* License terms: https://www.lwjgl.org/license
* MACHINE GENERATED FILE, DO NOT EDIT
*/
package org.lwjgl.opencl;
import org.lwjgl.system.*;
import org.lwjgl.system.libffi.*;
import static org.lwjgl.system.APIUtil.*;
import static org.lwjgl.system.MemoryUtil.*;
import static org.lwjgl.system.libffi.LibFFI.*;
/**
* Instances of this interface may be passed to the {@link CL30#clSetContextDestructorCallback SetContextDestructorCallback} method.
*
* Type
*
*
* void (*{@link #invoke}) (
* cl_context context,
* void *user_data
* )
*/
@FunctionalInterface
@NativeType("void (*) (cl_context, void *)")
public interface CLContextDestructorCallbackI extends CallbackI {
FFICIF CIF = apiCreateCIF(
apiStdcall(),
ffi_type_void,
ffi_type_pointer, ffi_type_pointer
);
@Override
default FFICIF getCallInterface() { return CIF; }
@Override
default void callback(long ret, long args) {
invoke(
memGetAddress(memGetAddress(args)),
memGetAddress(memGetAddress(args + POINTER_SIZE))
);
}
/**
* Will be called when a context is destroyed.
*
* @param context the OpenCL context being deleted.
*
* When the callback function is called by the implementation, this context is no longer valid. {@code context} is only provided for reference purposes.
* @param user_data the user-specified value that was passed when calling {@link CL30#clSetContextDestructorCallback SetContextDestructorCallback}
*/
void invoke(@NativeType("cl_context") long context, @NativeType("void *") long user_data);
}