All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.lwjgl.llvm.LLVMOrcObjectTransformLayerTransformFunctionI Maven / Gradle / Ivy

There is a newer version: 3.3.6
Show newest version
/*
 * Copyright LWJGL. All rights reserved.
 * License terms: https://www.lwjgl.org/license
 * MACHINE GENERATED FILE, DO NOT EDIT
 */
package org.lwjgl.llvm;

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 LLVMOrc#LLVMOrcObjectTransformLayerSetTransform OrcObjectTransformLayerSetTransform} method.
 * 
 * 

Type

* *

 * LLVMErrorRef (*{@link #invoke}) (
 *     void *Ctx,
 *     LLVMMemoryBufferRef *ObjInOut
 * )
*/ @FunctionalInterface @NativeType("LLVMOrcObjectTransformLayerTransformFunction") public interface LLVMOrcObjectTransformLayerTransformFunctionI extends CallbackI { FFICIF CIF = apiCreateCIF( FFI_DEFAULT_ABI, ffi_type_pointer, ffi_type_pointer, ffi_type_pointer ); @Override default FFICIF getCallInterface() { return CIF; } @Override default void callback(long ret, long args) { long __result = invoke( memGetAddress(memGetAddress(args)), memGetAddress(memGetAddress(args + POINTER_SIZE)) ); apiClosureRetP(ret, __result); } /** * A function for applying transformations to an object file buffer. * *

Implementations of this type are responsible for managing the lifetime of the memory buffer pointed to by {@code ObjInOut}: If the * {@code LLVMMemoryBufferRef} value is overwritten then the function is responsible for disposing of the incoming buffer. If the buffer is simply * accessed/mutated in-place then ownership returns to the caller and the function does not need to do any lifetime management.

* *

The transform is allowed to return an error, in which case the {@code ObjInOut} buffer should be disposed of and set to null.

*/ @NativeType("LLVMErrorRef") long invoke(@NativeType("void *") long Ctx, @NativeType("LLVMMemoryBufferRef *") long ObjInOut); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy