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

org.purejava.appindicator._GThreadFunctions Maven / Gradle / Ivy

// Generated by jextract

package org.purejava.appindicator;

import java.lang.invoke.*;
import java.lang.foreign.*;
import java.nio.ByteOrder;
import java.util.*;
import java.util.function.*;
import java.util.stream.*;

import static java.lang.foreign.ValueLayout.*;
import static java.lang.foreign.MemoryLayout.PathElement.*;

/**
 * {@snippet lang=c :
 * struct _GThreadFunctions {
 *     GMutex *(*mutex_new)(void);
 *     void (*mutex_lock)(GMutex *);
 *     gboolean (*mutex_trylock)(GMutex *);
 *     void (*mutex_unlock)(GMutex *);
 *     void (*mutex_free)(GMutex *);
 *     GCond *(*cond_new)(void);
 *     void (*cond_signal)(GCond *);
 *     void (*cond_broadcast)(GCond *);
 *     void (*cond_wait)(GCond *, GMutex *);
 *     gboolean (*cond_timed_wait)(GCond *, GMutex *, GTimeVal *);
 *     void (*cond_free)(GCond *);
 *     GPrivate *(*private_new)(GDestroyNotify);
 *     gpointer (*private_get)(GPrivate *);
 *     void (*private_set)(GPrivate *, gpointer);
 *     void (*thread_create)(GThreadFunc, gpointer, gulong, gboolean, gboolean, GThreadPriority, gpointer, GError **);
 *     void (*thread_yield)(void);
 *     void (*thread_join)(gpointer);
 *     void (*thread_exit)(void);
 *     void (*thread_set_priority)(gpointer, GThreadPriority);
 *     void (*thread_self)(gpointer);
 *     gboolean (*thread_equal)(gpointer, gpointer);
 * }
 * }
 */
public class _GThreadFunctions {

    _GThreadFunctions() {
        // Should not be called directly
    }

    private static final GroupLayout $LAYOUT = MemoryLayout.structLayout(
        app_indicator_h.C_POINTER.withName("mutex_new"),
        app_indicator_h.C_POINTER.withName("mutex_lock"),
        app_indicator_h.C_POINTER.withName("mutex_trylock"),
        app_indicator_h.C_POINTER.withName("mutex_unlock"),
        app_indicator_h.C_POINTER.withName("mutex_free"),
        app_indicator_h.C_POINTER.withName("cond_new"),
        app_indicator_h.C_POINTER.withName("cond_signal"),
        app_indicator_h.C_POINTER.withName("cond_broadcast"),
        app_indicator_h.C_POINTER.withName("cond_wait"),
        app_indicator_h.C_POINTER.withName("cond_timed_wait"),
        app_indicator_h.C_POINTER.withName("cond_free"),
        app_indicator_h.C_POINTER.withName("private_new"),
        app_indicator_h.C_POINTER.withName("private_get"),
        app_indicator_h.C_POINTER.withName("private_set"),
        app_indicator_h.C_POINTER.withName("thread_create"),
        app_indicator_h.C_POINTER.withName("thread_yield"),
        app_indicator_h.C_POINTER.withName("thread_join"),
        app_indicator_h.C_POINTER.withName("thread_exit"),
        app_indicator_h.C_POINTER.withName("thread_set_priority"),
        app_indicator_h.C_POINTER.withName("thread_self"),
        app_indicator_h.C_POINTER.withName("thread_equal")
    ).withName("_GThreadFunctions");

    /**
     * The layout of this struct
     */
    public static final GroupLayout layout() {
        return $LAYOUT;
    }

    /**
     * {@snippet lang=c :
     * GMutex *(*mutex_new)(void)
     * }
     */
    public class mutex_new {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            MemorySegment apply();
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.of(
            app_indicator_h.C_POINTER);

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(mutex_new.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(mutex_new.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static MemorySegment invoke(MemorySegment funcPtr) {
            try {
                return (MemorySegment) DOWN$MH.invokeExact(funcPtr);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout mutex_new$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("mutex_new"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * GMutex *(*mutex_new)(void)
     * }
     */
    public static final AddressLayout mutex_new$layout() {
        return mutex_new$LAYOUT;
    }

    private static final long mutex_new$OFFSET = 0;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * GMutex *(*mutex_new)(void)
     * }
     */
    public static final long mutex_new$offset() {
        return mutex_new$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * GMutex *(*mutex_new)(void)
     * }
     */
    public static MemorySegment mutex_new(MemorySegment struct) {
        return struct.get(mutex_new$LAYOUT, mutex_new$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * GMutex *(*mutex_new)(void)
     * }
     */
    public static void mutex_new(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(mutex_new$LAYOUT, mutex_new$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * void (*mutex_lock)(GMutex *)
     * }
     */
    public class mutex_lock {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            void apply(MemorySegment _x0);
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.ofVoid(
            app_indicator_h.C_POINTER
        );

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(mutex_lock.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(mutex_lock.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static void invoke(MemorySegment funcPtr,MemorySegment _x0) {
            try {
                 DOWN$MH.invokeExact(funcPtr, _x0);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout mutex_lock$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("mutex_lock"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * void (*mutex_lock)(GMutex *)
     * }
     */
    public static final AddressLayout mutex_lock$layout() {
        return mutex_lock$LAYOUT;
    }

    private static final long mutex_lock$OFFSET = 8;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * void (*mutex_lock)(GMutex *)
     * }
     */
    public static final long mutex_lock$offset() {
        return mutex_lock$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * void (*mutex_lock)(GMutex *)
     * }
     */
    public static MemorySegment mutex_lock(MemorySegment struct) {
        return struct.get(mutex_lock$LAYOUT, mutex_lock$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * void (*mutex_lock)(GMutex *)
     * }
     */
    public static void mutex_lock(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(mutex_lock$LAYOUT, mutex_lock$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * gboolean (*mutex_trylock)(GMutex *)
     * }
     */
    public class mutex_trylock {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            int apply(MemorySegment _x0);
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.of(
            app_indicator_h.C_INT,
            app_indicator_h.C_POINTER
        );

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(mutex_trylock.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(mutex_trylock.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static int invoke(MemorySegment funcPtr,MemorySegment _x0) {
            try {
                return (int) DOWN$MH.invokeExact(funcPtr, _x0);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout mutex_trylock$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("mutex_trylock"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * gboolean (*mutex_trylock)(GMutex *)
     * }
     */
    public static final AddressLayout mutex_trylock$layout() {
        return mutex_trylock$LAYOUT;
    }

    private static final long mutex_trylock$OFFSET = 16;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * gboolean (*mutex_trylock)(GMutex *)
     * }
     */
    public static final long mutex_trylock$offset() {
        return mutex_trylock$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * gboolean (*mutex_trylock)(GMutex *)
     * }
     */
    public static MemorySegment mutex_trylock(MemorySegment struct) {
        return struct.get(mutex_trylock$LAYOUT, mutex_trylock$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * gboolean (*mutex_trylock)(GMutex *)
     * }
     */
    public static void mutex_trylock(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(mutex_trylock$LAYOUT, mutex_trylock$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * void (*mutex_unlock)(GMutex *)
     * }
     */
    public class mutex_unlock {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            void apply(MemorySegment _x0);
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.ofVoid(
            app_indicator_h.C_POINTER
        );

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(mutex_unlock.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(mutex_unlock.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static void invoke(MemorySegment funcPtr,MemorySegment _x0) {
            try {
                 DOWN$MH.invokeExact(funcPtr, _x0);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout mutex_unlock$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("mutex_unlock"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * void (*mutex_unlock)(GMutex *)
     * }
     */
    public static final AddressLayout mutex_unlock$layout() {
        return mutex_unlock$LAYOUT;
    }

    private static final long mutex_unlock$OFFSET = 24;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * void (*mutex_unlock)(GMutex *)
     * }
     */
    public static final long mutex_unlock$offset() {
        return mutex_unlock$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * void (*mutex_unlock)(GMutex *)
     * }
     */
    public static MemorySegment mutex_unlock(MemorySegment struct) {
        return struct.get(mutex_unlock$LAYOUT, mutex_unlock$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * void (*mutex_unlock)(GMutex *)
     * }
     */
    public static void mutex_unlock(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(mutex_unlock$LAYOUT, mutex_unlock$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * void (*mutex_free)(GMutex *)
     * }
     */
    public class mutex_free {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            void apply(MemorySegment _x0);
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.ofVoid(
            app_indicator_h.C_POINTER
        );

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(mutex_free.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(mutex_free.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static void invoke(MemorySegment funcPtr,MemorySegment _x0) {
            try {
                 DOWN$MH.invokeExact(funcPtr, _x0);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout mutex_free$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("mutex_free"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * void (*mutex_free)(GMutex *)
     * }
     */
    public static final AddressLayout mutex_free$layout() {
        return mutex_free$LAYOUT;
    }

    private static final long mutex_free$OFFSET = 32;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * void (*mutex_free)(GMutex *)
     * }
     */
    public static final long mutex_free$offset() {
        return mutex_free$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * void (*mutex_free)(GMutex *)
     * }
     */
    public static MemorySegment mutex_free(MemorySegment struct) {
        return struct.get(mutex_free$LAYOUT, mutex_free$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * void (*mutex_free)(GMutex *)
     * }
     */
    public static void mutex_free(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(mutex_free$LAYOUT, mutex_free$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * GCond *(*cond_new)(void)
     * }
     */
    public class cond_new {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            MemorySegment apply();
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.of(
            app_indicator_h.C_POINTER);

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(cond_new.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(cond_new.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static MemorySegment invoke(MemorySegment funcPtr) {
            try {
                return (MemorySegment) DOWN$MH.invokeExact(funcPtr);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout cond_new$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("cond_new"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * GCond *(*cond_new)(void)
     * }
     */
    public static final AddressLayout cond_new$layout() {
        return cond_new$LAYOUT;
    }

    private static final long cond_new$OFFSET = 40;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * GCond *(*cond_new)(void)
     * }
     */
    public static final long cond_new$offset() {
        return cond_new$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * GCond *(*cond_new)(void)
     * }
     */
    public static MemorySegment cond_new(MemorySegment struct) {
        return struct.get(cond_new$LAYOUT, cond_new$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * GCond *(*cond_new)(void)
     * }
     */
    public static void cond_new(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(cond_new$LAYOUT, cond_new$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * void (*cond_signal)(GCond *)
     * }
     */
    public class cond_signal {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            void apply(MemorySegment _x0);
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.ofVoid(
            app_indicator_h.C_POINTER
        );

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(cond_signal.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(cond_signal.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static void invoke(MemorySegment funcPtr,MemorySegment _x0) {
            try {
                 DOWN$MH.invokeExact(funcPtr, _x0);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout cond_signal$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("cond_signal"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * void (*cond_signal)(GCond *)
     * }
     */
    public static final AddressLayout cond_signal$layout() {
        return cond_signal$LAYOUT;
    }

    private static final long cond_signal$OFFSET = 48;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * void (*cond_signal)(GCond *)
     * }
     */
    public static final long cond_signal$offset() {
        return cond_signal$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * void (*cond_signal)(GCond *)
     * }
     */
    public static MemorySegment cond_signal(MemorySegment struct) {
        return struct.get(cond_signal$LAYOUT, cond_signal$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * void (*cond_signal)(GCond *)
     * }
     */
    public static void cond_signal(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(cond_signal$LAYOUT, cond_signal$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * void (*cond_broadcast)(GCond *)
     * }
     */
    public class cond_broadcast {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            void apply(MemorySegment _x0);
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.ofVoid(
            app_indicator_h.C_POINTER
        );

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(cond_broadcast.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(cond_broadcast.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static void invoke(MemorySegment funcPtr,MemorySegment _x0) {
            try {
                 DOWN$MH.invokeExact(funcPtr, _x0);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout cond_broadcast$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("cond_broadcast"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * void (*cond_broadcast)(GCond *)
     * }
     */
    public static final AddressLayout cond_broadcast$layout() {
        return cond_broadcast$LAYOUT;
    }

    private static final long cond_broadcast$OFFSET = 56;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * void (*cond_broadcast)(GCond *)
     * }
     */
    public static final long cond_broadcast$offset() {
        return cond_broadcast$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * void (*cond_broadcast)(GCond *)
     * }
     */
    public static MemorySegment cond_broadcast(MemorySegment struct) {
        return struct.get(cond_broadcast$LAYOUT, cond_broadcast$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * void (*cond_broadcast)(GCond *)
     * }
     */
    public static void cond_broadcast(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(cond_broadcast$LAYOUT, cond_broadcast$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * void (*cond_wait)(GCond *, GMutex *)
     * }
     */
    public class cond_wait {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            void apply(MemorySegment _x0, MemorySegment _x1);
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.ofVoid(
            app_indicator_h.C_POINTER,
            app_indicator_h.C_POINTER
        );

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(cond_wait.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(cond_wait.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static void invoke(MemorySegment funcPtr,MemorySegment _x0, MemorySegment _x1) {
            try {
                 DOWN$MH.invokeExact(funcPtr, _x0, _x1);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout cond_wait$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("cond_wait"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * void (*cond_wait)(GCond *, GMutex *)
     * }
     */
    public static final AddressLayout cond_wait$layout() {
        return cond_wait$LAYOUT;
    }

    private static final long cond_wait$OFFSET = 64;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * void (*cond_wait)(GCond *, GMutex *)
     * }
     */
    public static final long cond_wait$offset() {
        return cond_wait$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * void (*cond_wait)(GCond *, GMutex *)
     * }
     */
    public static MemorySegment cond_wait(MemorySegment struct) {
        return struct.get(cond_wait$LAYOUT, cond_wait$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * void (*cond_wait)(GCond *, GMutex *)
     * }
     */
    public static void cond_wait(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(cond_wait$LAYOUT, cond_wait$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * gboolean (*cond_timed_wait)(GCond *, GMutex *, GTimeVal *)
     * }
     */
    public class cond_timed_wait {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            int apply(MemorySegment _x0, MemorySegment _x1, MemorySegment _x2);
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.of(
            app_indicator_h.C_INT,
            app_indicator_h.C_POINTER,
            app_indicator_h.C_POINTER,
            app_indicator_h.C_POINTER
        );

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(cond_timed_wait.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(cond_timed_wait.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static int invoke(MemorySegment funcPtr,MemorySegment _x0, MemorySegment _x1, MemorySegment _x2) {
            try {
                return (int) DOWN$MH.invokeExact(funcPtr, _x0, _x1, _x2);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout cond_timed_wait$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("cond_timed_wait"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * gboolean (*cond_timed_wait)(GCond *, GMutex *, GTimeVal *)
     * }
     */
    public static final AddressLayout cond_timed_wait$layout() {
        return cond_timed_wait$LAYOUT;
    }

    private static final long cond_timed_wait$OFFSET = 72;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * gboolean (*cond_timed_wait)(GCond *, GMutex *, GTimeVal *)
     * }
     */
    public static final long cond_timed_wait$offset() {
        return cond_timed_wait$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * gboolean (*cond_timed_wait)(GCond *, GMutex *, GTimeVal *)
     * }
     */
    public static MemorySegment cond_timed_wait(MemorySegment struct) {
        return struct.get(cond_timed_wait$LAYOUT, cond_timed_wait$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * gboolean (*cond_timed_wait)(GCond *, GMutex *, GTimeVal *)
     * }
     */
    public static void cond_timed_wait(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(cond_timed_wait$LAYOUT, cond_timed_wait$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * void (*cond_free)(GCond *)
     * }
     */
    public class cond_free {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            void apply(MemorySegment _x0);
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.ofVoid(
            app_indicator_h.C_POINTER
        );

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(cond_free.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(cond_free.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static void invoke(MemorySegment funcPtr,MemorySegment _x0) {
            try {
                 DOWN$MH.invokeExact(funcPtr, _x0);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout cond_free$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("cond_free"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * void (*cond_free)(GCond *)
     * }
     */
    public static final AddressLayout cond_free$layout() {
        return cond_free$LAYOUT;
    }

    private static final long cond_free$OFFSET = 80;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * void (*cond_free)(GCond *)
     * }
     */
    public static final long cond_free$offset() {
        return cond_free$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * void (*cond_free)(GCond *)
     * }
     */
    public static MemorySegment cond_free(MemorySegment struct) {
        return struct.get(cond_free$LAYOUT, cond_free$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * void (*cond_free)(GCond *)
     * }
     */
    public static void cond_free(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(cond_free$LAYOUT, cond_free$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * GPrivate *(*private_new)(GDestroyNotify)
     * }
     */
    public class private_new {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            MemorySegment apply(MemorySegment _x0);
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.of(
            app_indicator_h.C_POINTER,
            app_indicator_h.C_POINTER
        );

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(private_new.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(private_new.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static MemorySegment invoke(MemorySegment funcPtr,MemorySegment _x0) {
            try {
                return (MemorySegment) DOWN$MH.invokeExact(funcPtr, _x0);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout private_new$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("private_new"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * GPrivate *(*private_new)(GDestroyNotify)
     * }
     */
    public static final AddressLayout private_new$layout() {
        return private_new$LAYOUT;
    }

    private static final long private_new$OFFSET = 88;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * GPrivate *(*private_new)(GDestroyNotify)
     * }
     */
    public static final long private_new$offset() {
        return private_new$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * GPrivate *(*private_new)(GDestroyNotify)
     * }
     */
    public static MemorySegment private_new(MemorySegment struct) {
        return struct.get(private_new$LAYOUT, private_new$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * GPrivate *(*private_new)(GDestroyNotify)
     * }
     */
    public static void private_new(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(private_new$LAYOUT, private_new$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * gpointer (*private_get)(GPrivate *)
     * }
     */
    public class private_get {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            MemorySegment apply(MemorySegment _x0);
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.of(
            app_indicator_h.C_POINTER,
            app_indicator_h.C_POINTER
        );

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(private_get.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(private_get.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static MemorySegment invoke(MemorySegment funcPtr,MemorySegment _x0) {
            try {
                return (MemorySegment) DOWN$MH.invokeExact(funcPtr, _x0);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout private_get$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("private_get"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * gpointer (*private_get)(GPrivate *)
     * }
     */
    public static final AddressLayout private_get$layout() {
        return private_get$LAYOUT;
    }

    private static final long private_get$OFFSET = 96;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * gpointer (*private_get)(GPrivate *)
     * }
     */
    public static final long private_get$offset() {
        return private_get$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * gpointer (*private_get)(GPrivate *)
     * }
     */
    public static MemorySegment private_get(MemorySegment struct) {
        return struct.get(private_get$LAYOUT, private_get$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * gpointer (*private_get)(GPrivate *)
     * }
     */
    public static void private_get(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(private_get$LAYOUT, private_get$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * void (*private_set)(GPrivate *, gpointer)
     * }
     */
    public class private_set {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            void apply(MemorySegment _x0, MemorySegment _x1);
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.ofVoid(
            app_indicator_h.C_POINTER,
            app_indicator_h.C_POINTER
        );

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(private_set.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(private_set.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static void invoke(MemorySegment funcPtr,MemorySegment _x0, MemorySegment _x1) {
            try {
                 DOWN$MH.invokeExact(funcPtr, _x0, _x1);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout private_set$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("private_set"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * void (*private_set)(GPrivate *, gpointer)
     * }
     */
    public static final AddressLayout private_set$layout() {
        return private_set$LAYOUT;
    }

    private static final long private_set$OFFSET = 104;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * void (*private_set)(GPrivate *, gpointer)
     * }
     */
    public static final long private_set$offset() {
        return private_set$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * void (*private_set)(GPrivate *, gpointer)
     * }
     */
    public static MemorySegment private_set(MemorySegment struct) {
        return struct.get(private_set$LAYOUT, private_set$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * void (*private_set)(GPrivate *, gpointer)
     * }
     */
    public static void private_set(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(private_set$LAYOUT, private_set$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * void (*thread_create)(GThreadFunc, gpointer, gulong, gboolean, gboolean, GThreadPriority, gpointer, GError **)
     * }
     */
    public class thread_create {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            void apply(MemorySegment _x0, MemorySegment _x1, long _x2, int _x3, int _x4, int _x5, MemorySegment _x6, MemorySegment _x7);
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.ofVoid(
            app_indicator_h.C_POINTER,
            app_indicator_h.C_POINTER,
            app_indicator_h.C_LONG,
            app_indicator_h.C_INT,
            app_indicator_h.C_INT,
            app_indicator_h.C_INT,
            app_indicator_h.C_POINTER,
            app_indicator_h.C_POINTER
        );

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(thread_create.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(thread_create.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static void invoke(MemorySegment funcPtr,MemorySegment _x0, MemorySegment _x1, long _x2, int _x3, int _x4, int _x5, MemorySegment _x6, MemorySegment _x7) {
            try {
                 DOWN$MH.invokeExact(funcPtr, _x0, _x1, _x2, _x3, _x4, _x5, _x6, _x7);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout thread_create$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("thread_create"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * void (*thread_create)(GThreadFunc, gpointer, gulong, gboolean, gboolean, GThreadPriority, gpointer, GError **)
     * }
     */
    public static final AddressLayout thread_create$layout() {
        return thread_create$LAYOUT;
    }

    private static final long thread_create$OFFSET = 112;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * void (*thread_create)(GThreadFunc, gpointer, gulong, gboolean, gboolean, GThreadPriority, gpointer, GError **)
     * }
     */
    public static final long thread_create$offset() {
        return thread_create$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * void (*thread_create)(GThreadFunc, gpointer, gulong, gboolean, gboolean, GThreadPriority, gpointer, GError **)
     * }
     */
    public static MemorySegment thread_create(MemorySegment struct) {
        return struct.get(thread_create$LAYOUT, thread_create$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * void (*thread_create)(GThreadFunc, gpointer, gulong, gboolean, gboolean, GThreadPriority, gpointer, GError **)
     * }
     */
    public static void thread_create(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(thread_create$LAYOUT, thread_create$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * void (*thread_yield)(void)
     * }
     */
    public class thread_yield {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            void apply();
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.ofVoid();

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(thread_yield.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(thread_yield.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static void invoke(MemorySegment funcPtr) {
            try {
                 DOWN$MH.invokeExact(funcPtr);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout thread_yield$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("thread_yield"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * void (*thread_yield)(void)
     * }
     */
    public static final AddressLayout thread_yield$layout() {
        return thread_yield$LAYOUT;
    }

    private static final long thread_yield$OFFSET = 120;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * void (*thread_yield)(void)
     * }
     */
    public static final long thread_yield$offset() {
        return thread_yield$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * void (*thread_yield)(void)
     * }
     */
    public static MemorySegment thread_yield(MemorySegment struct) {
        return struct.get(thread_yield$LAYOUT, thread_yield$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * void (*thread_yield)(void)
     * }
     */
    public static void thread_yield(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(thread_yield$LAYOUT, thread_yield$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * void (*thread_join)(gpointer)
     * }
     */
    public class thread_join {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            void apply(MemorySegment _x0);
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.ofVoid(
            app_indicator_h.C_POINTER
        );

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(thread_join.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(thread_join.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static void invoke(MemorySegment funcPtr,MemorySegment _x0) {
            try {
                 DOWN$MH.invokeExact(funcPtr, _x0);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout thread_join$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("thread_join"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * void (*thread_join)(gpointer)
     * }
     */
    public static final AddressLayout thread_join$layout() {
        return thread_join$LAYOUT;
    }

    private static final long thread_join$OFFSET = 128;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * void (*thread_join)(gpointer)
     * }
     */
    public static final long thread_join$offset() {
        return thread_join$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * void (*thread_join)(gpointer)
     * }
     */
    public static MemorySegment thread_join(MemorySegment struct) {
        return struct.get(thread_join$LAYOUT, thread_join$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * void (*thread_join)(gpointer)
     * }
     */
    public static void thread_join(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(thread_join$LAYOUT, thread_join$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * void (*thread_exit)(void)
     * }
     */
    public class thread_exit {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            void apply();
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.ofVoid();

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(thread_exit.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(thread_exit.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static void invoke(MemorySegment funcPtr) {
            try {
                 DOWN$MH.invokeExact(funcPtr);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout thread_exit$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("thread_exit"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * void (*thread_exit)(void)
     * }
     */
    public static final AddressLayout thread_exit$layout() {
        return thread_exit$LAYOUT;
    }

    private static final long thread_exit$OFFSET = 136;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * void (*thread_exit)(void)
     * }
     */
    public static final long thread_exit$offset() {
        return thread_exit$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * void (*thread_exit)(void)
     * }
     */
    public static MemorySegment thread_exit(MemorySegment struct) {
        return struct.get(thread_exit$LAYOUT, thread_exit$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * void (*thread_exit)(void)
     * }
     */
    public static void thread_exit(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(thread_exit$LAYOUT, thread_exit$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * void (*thread_set_priority)(gpointer, GThreadPriority)
     * }
     */
    public class thread_set_priority {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            void apply(MemorySegment _x0, int _x1);
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.ofVoid(
            app_indicator_h.C_POINTER,
            app_indicator_h.C_INT
        );

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(thread_set_priority.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(thread_set_priority.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static void invoke(MemorySegment funcPtr,MemorySegment _x0, int _x1) {
            try {
                 DOWN$MH.invokeExact(funcPtr, _x0, _x1);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout thread_set_priority$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("thread_set_priority"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * void (*thread_set_priority)(gpointer, GThreadPriority)
     * }
     */
    public static final AddressLayout thread_set_priority$layout() {
        return thread_set_priority$LAYOUT;
    }

    private static final long thread_set_priority$OFFSET = 144;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * void (*thread_set_priority)(gpointer, GThreadPriority)
     * }
     */
    public static final long thread_set_priority$offset() {
        return thread_set_priority$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * void (*thread_set_priority)(gpointer, GThreadPriority)
     * }
     */
    public static MemorySegment thread_set_priority(MemorySegment struct) {
        return struct.get(thread_set_priority$LAYOUT, thread_set_priority$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * void (*thread_set_priority)(gpointer, GThreadPriority)
     * }
     */
    public static void thread_set_priority(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(thread_set_priority$LAYOUT, thread_set_priority$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * void (*thread_self)(gpointer)
     * }
     */
    public class thread_self {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            void apply(MemorySegment _x0);
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.ofVoid(
            app_indicator_h.C_POINTER
        );

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(thread_self.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(thread_self.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static void invoke(MemorySegment funcPtr,MemorySegment _x0) {
            try {
                 DOWN$MH.invokeExact(funcPtr, _x0);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout thread_self$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("thread_self"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * void (*thread_self)(gpointer)
     * }
     */
    public static final AddressLayout thread_self$layout() {
        return thread_self$LAYOUT;
    }

    private static final long thread_self$OFFSET = 152;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * void (*thread_self)(gpointer)
     * }
     */
    public static final long thread_self$offset() {
        return thread_self$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * void (*thread_self)(gpointer)
     * }
     */
    public static MemorySegment thread_self(MemorySegment struct) {
        return struct.get(thread_self$LAYOUT, thread_self$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * void (*thread_self)(gpointer)
     * }
     */
    public static void thread_self(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(thread_self$LAYOUT, thread_self$OFFSET, fieldValue);
    }

    /**
     * {@snippet lang=c :
     * gboolean (*thread_equal)(gpointer, gpointer)
     * }
     */
    public class thread_equal {

        /**
         * The function pointer signature, expressed as a functional interface
         */
        public interface Function {
            int apply(MemorySegment _x0, MemorySegment _x1);
        }

        private static final FunctionDescriptor $DESC = FunctionDescriptor.of(
            app_indicator_h.C_INT,
            app_indicator_h.C_POINTER,
            app_indicator_h.C_POINTER
        );

        /**
         * The descriptor of this function pointer
         */
        public static FunctionDescriptor descriptor() {
            return $DESC;
        }

        private static final MethodHandle UP$MH = app_indicator_h.upcallHandle(thread_equal.Function.class, "apply", $DESC);

        /**
         * Allocates a new upcall stub, whose implementation is defined by {@code fi}.
         * The lifetime of the returned segment is managed by {@code arena}
         */
        public static MemorySegment allocate(thread_equal.Function fi, Arena arena) {
            return Linker.nativeLinker().upcallStub(UP$MH.bindTo(fi), $DESC, arena);
        }

        private static final MethodHandle DOWN$MH = Linker.nativeLinker().downcallHandle($DESC);

        /**
         * Invoke the upcall stub {@code funcPtr}, with given parameters
         */
        public static int invoke(MemorySegment funcPtr,MemorySegment _x0, MemorySegment _x1) {
            try {
                return (int) DOWN$MH.invokeExact(funcPtr, _x0, _x1);
            } catch (Throwable ex$) {
                throw new AssertionError("should not reach here", ex$);
            }
        }
    }

    private static final AddressLayout thread_equal$LAYOUT = (AddressLayout)$LAYOUT.select(groupElement("thread_equal"));

    /**
     * Layout for field:
     * {@snippet lang=c :
     * gboolean (*thread_equal)(gpointer, gpointer)
     * }
     */
    public static final AddressLayout thread_equal$layout() {
        return thread_equal$LAYOUT;
    }

    private static final long thread_equal$OFFSET = 160;

    /**
     * Offset for field:
     * {@snippet lang=c :
     * gboolean (*thread_equal)(gpointer, gpointer)
     * }
     */
    public static final long thread_equal$offset() {
        return thread_equal$OFFSET;
    }

    /**
     * Getter for field:
     * {@snippet lang=c :
     * gboolean (*thread_equal)(gpointer, gpointer)
     * }
     */
    public static MemorySegment thread_equal(MemorySegment struct) {
        return struct.get(thread_equal$LAYOUT, thread_equal$OFFSET);
    }

    /**
     * Setter for field:
     * {@snippet lang=c :
     * gboolean (*thread_equal)(gpointer, gpointer)
     * }
     */
    public static void thread_equal(MemorySegment struct, MemorySegment fieldValue) {
        struct.set(thread_equal$LAYOUT, thread_equal$OFFSET, fieldValue);
    }

    /**
     * Obtains a slice of {@code arrayParam} which selects the array element at {@code index}.
     * The returned segment has address {@code arrayParam.address() + index * layout().byteSize()}
     */
    public static MemorySegment asSlice(MemorySegment array, long index) {
        return array.asSlice(layout().byteSize() * index);
    }

    /**
     * The size (in bytes) of this struct
     */
    public static long sizeof() { return layout().byteSize(); }

    /**
     * Allocate a segment of size {@code layout().byteSize()} using {@code allocator}
     */
    public static MemorySegment allocate(SegmentAllocator allocator) {
        return allocator.allocate(layout());
    }

    /**
     * Allocate an array of size {@code elementCount} using {@code allocator}.
     * The returned segment has size {@code elementCount * layout().byteSize()}.
     */
    public static MemorySegment allocateArray(long elementCount, SegmentAllocator allocator) {
        return allocator.allocate(MemoryLayout.sequenceLayout(elementCount, layout()));
    }

    /**
     * Reinterprets {@code addr} using target {@code arena} and {@code cleanupAction) (if any).
     * The returned segment has size {@code layout().byteSize()}
     */
    public static MemorySegment reinterpret(MemorySegment addr, Arena arena, Consumer cleanup) {
        return reinterpret(addr, 1, arena, cleanup);
    }

    /**
     * Reinterprets {@code addr} using target {@code arena} and {@code cleanupAction) (if any).
     * The returned segment has size {@code elementCount * layout().byteSize()}
     */
    public static MemorySegment reinterpret(MemorySegment addr, long elementCount, Arena arena, Consumer cleanup) {
        return addr.reinterpret(layout().byteSize() * elementCount, arena, cleanup);
    }
}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy