diff --git a/modules/overrungl.core/src/main/java/overrungl/internal/RuntimeHelper.java b/modules/overrungl.core/src/main/java/overrungl/internal/RuntimeHelper.java index 3eb0dc38..44af12e9 100644 --- a/modules/overrungl.core/src/main/java/overrungl/internal/RuntimeHelper.java +++ b/modules/overrungl.core/src/main/java/overrungl/internal/RuntimeHelper.java @@ -74,21 +74,12 @@ private RuntimeHelper() { throw new IllegalStateException("Do not construct instance"); } + @Deprecated(since = "0.1.0") private static MemorySegment reinterpreting(MemorySegment pointerToPointer, int index, ToLongFunction size) { final MemorySegment seg = pointerToPointer.getAtIndex(ADDRESS, index); return seg.reinterpret(size.applyAsLong(seg)); } - /** - * Gets a UTF-8 string from the given pointer of a string. - * - * @param segment the memory segment. - * @return the string. - */ - public static String unboundPointerString(MemorySegment segment) { - return unboundPointerString(segment, 0); - } - /** * Gets a UTF-8 string from the given pointer of a string at the given index. * @@ -96,6 +87,7 @@ public static String unboundPointerString(MemorySegment segment) { * @param index the index. * @return the string. */ + @Deprecated(since = "0.1.0") public static String unboundPointerString(MemorySegment segment, int index) { return reinterpreting(segment, index, str -> MemoryUtil.strlen(str) + 1).getString(0); } @@ -180,6 +172,7 @@ public static SymbolLookup load(String module, String basename, String version) * * @param segment the segment. */ + @Deprecated(since = "0.1.0") public static boolean isNullptr(@Nullable MemorySegment segment) { return segment == null || segment.equals(MemorySegment.NULL); } @@ -193,6 +186,7 @@ public static boolean isNullptr(@Nullable MemorySegment segment) { * @return a downcall method handle. or {@code null} if the symbol {@link MemorySegment#NULL} */ @Nullable + @Deprecated(since = "0.1.0") public static MethodHandle downcallSafe(@Nullable MemorySegment symbol, FunctionDescriptor function, Linker.Option... options) { return isNullptr(symbol) ? null : LINKER.downcallHandle(symbol, function, options); } @@ -205,6 +199,7 @@ public static MethodHandle downcallSafe(@Nullable MemorySegment symbol, Function * @param options the linker options associated with this linkage request. * @return a downcall method handle. */ + @Deprecated(since = "0.1.0") public static MethodHandle downcallThrow(Optional optional, FunctionDescriptor function, Linker.Option... options) { return LINKER.downcallHandle(optional.orElseThrow(), function, options); } @@ -218,6 +213,7 @@ public static MethodHandle downcallThrow(Optional optional, Funct * @return a downcall method handle. or {@code null} if the symbol {@link MemorySegment#NULL} */ @Nullable + @Deprecated(since = "0.1.0") public static MethodHandle downcallSafe(@Nullable MemorySegment symbol, FunctionDescriptors function, Linker.Option... options) { return downcallSafe(symbol, function.descriptor(), options); } @@ -230,6 +226,7 @@ public static MethodHandle downcallSafe(@Nullable MemorySegment symbol, Function * @param options the linker options associated with this linkage request. * @return a downcall method handle. */ + @Deprecated(since = "0.1.0") public static MethodHandle downcallThrow(Optional optional, FunctionDescriptors function, Linker.Option... options) { return downcallThrow(optional, function.descriptor(), options); } @@ -243,6 +240,7 @@ public static MethodHandle downcallThrow(Optional optional, Funct * @param generator the generator, from a zero-length address to the array type * @return arr */ + @Deprecated(since = "0.1.0") public static T[] toArray(MemorySegment seg, T[] arr, Function generator) { for (int i = 0; i < arr.length; i++) { @@ -258,6 +256,7 @@ public static T[] toArray(MemorySegment seg, T[] arr, * @param arr the array to hold the result * @return an array of the zero-length addresses. */ + @Deprecated(since = "0.1.0") public static MemorySegment[] toArray(MemorySegment seg, MemorySegment[] arr) { return toArray(seg, arr, Function.identity()); } @@ -269,6 +268,7 @@ public static MemorySegment[] toArray(MemorySegment seg, MemorySegment[] arr) { * @param arr the array to hold the result * @return arr */ + @Deprecated(since = "0.1.0") public static String[] toUnboundedArray(@NativeType("char**") MemorySegment seg, String[] arr) { for (int i = 0; i < arr.length; i++) { arr[i] = unboundPointerString(seg, i); @@ -283,6 +283,7 @@ public static String[] toUnboundedArray(@NativeType("char**") MemorySegment seg, * @param arr the array to hold the result * @return arr */ + @Deprecated(since = "0.1.0") public static boolean[] toArray(MemorySegment seg, boolean[] arr) { for (int i = 0; i < arr.length; i++) { arr[i] = seg.get(JAVA_BOOLEAN, i); @@ -297,6 +298,7 @@ public static boolean[] toArray(MemorySegment seg, boolean[] arr) { * @param arr the array to hold the result * @return arr */ + @Deprecated(since = "0.1.0") public static byte[] toArray(MemorySegment seg, byte[] arr) { MemorySegment.copy(seg, JAVA_BYTE, 0, arr, 0, arr.length); return arr; @@ -309,6 +311,7 @@ public static byte[] toArray(MemorySegment seg, byte[] arr) { * @param arr the array to hold the result * @return arr */ + @Deprecated(since = "0.1.0") public static short[] toArray(MemorySegment seg, short[] arr) { MemorySegment.copy(seg, JAVA_SHORT, 0, arr, 0, arr.length); return arr; @@ -321,6 +324,7 @@ public static short[] toArray(MemorySegment seg, short[] arr) { * @param arr the array to hold the result * @return arr */ + @Deprecated(since = "0.1.0") public static int[] toArray(MemorySegment seg, int[] arr) { MemorySegment.copy(seg, JAVA_INT, 0, arr, 0, arr.length); return arr; @@ -333,6 +337,7 @@ public static int[] toArray(MemorySegment seg, int[] arr) { * @param arr the array to hold the result * @return arr */ + @Deprecated(since = "0.1.0") public static long[] toArray(MemorySegment seg, long[] arr) { MemorySegment.copy(seg, JAVA_LONG, 0, arr, 0, arr.length); return arr; @@ -345,6 +350,7 @@ public static long[] toArray(MemorySegment seg, long[] arr) { * @param arr the array to hold the result * @return arr */ + @Deprecated(since = "0.1.0") public static float[] toArray(MemorySegment seg, float[] arr) { MemorySegment.copy(seg, JAVA_FLOAT, 0, arr, 0, arr.length); return arr; @@ -357,6 +363,7 @@ public static float[] toArray(MemorySegment seg, float[] arr) { * @param arr the array to hold the result * @return arr */ + @Deprecated(since = "0.1.0") public static double[] toArray(MemorySegment seg, double[] arr) { MemorySegment.copy(seg, JAVA_DOUBLE, 0, arr, 0, arr.length); return arr; diff --git a/modules/overrungl.glfw/src/main/java/overrungl/glfw/GLFW.java b/modules/overrungl.glfw/src/main/java/overrungl/glfw/GLFW.java index 3dde3290..0c21ffad 100644 --- a/modules/overrungl.glfw/src/main/java/overrungl/glfw/GLFW.java +++ b/modules/overrungl.glfw/src/main/java/overrungl/glfw/GLFW.java @@ -18,8 +18,10 @@ import org.jetbrains.annotations.Nullable; import overrun.marshal.Downcall; +import overrun.marshal.MemoryStack; +import overrun.marshal.Unmarshal; +import overrun.marshal.gen.*; import overrungl.internal.RuntimeHelper; -import overrungl.util.MemoryStack; import overrungl.util.value.Pair; import overrungl.util.value.Quad; import overrungl.util.value.Triplet; @@ -41,7 +43,7 @@ public interface GLFW { /** * The instance of GLFW. */ - GLFW INSTANCE = Downcall.load(Handles.lookup); + GLFW INSTANCE = Downcall.load(lookup); /** * The major version number of the GLFW header. @@ -914,13 +916,9 @@ static String getErrorString(int errorCode) { * @glfw.thread_safety This function must only be called from the main thread. * @see #terminate */ - static boolean init() { - try { - return (int) glfwInit.invokeExact() != FALSE; - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Convert(Type.INT) + @Entrypoint("glfwInit") + boolean init(); /** * Terminates the GLFW library. @@ -945,13 +943,8 @@ static boolean init() { * @glfw.thread_safety This function must only be called from the main thread. * @see #init */ - static void terminate() { - try { - glfwTerminate.invokeExact(); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwTerminate") + void terminate(); /** * Sets the specified init hint to the desired value. @@ -973,13 +966,8 @@ static void terminate() { * @glfw.thread_safety This function must only be called from the main thread. * @see #init() init */ - static void initHint(int hint, int value) { - try { - glfwInitHint.invokeExact(hint, value); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwInitHint") + void initHint(int hint, int value); /** * Retrieves the version of the GLFW library. @@ -998,13 +986,8 @@ static void initHint(int hint, int value) { * @glfw.thread_safety This function may be called from any thread. * @see #ngetVersionString() getVersionString */ - static void ngetVersion(MemorySegment major, MemorySegment minor, MemorySegment rev) { - try { - glfwGetVersion.invokeExact(major, minor, rev); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetVersion") + void ngetVersion(MemorySegment major, MemorySegment minor, MemorySegment rev); /** * Retrieves the version of the GLFW library. @@ -1014,27 +997,8 @@ static void ngetVersion(MemorySegment major, MemorySegment minor, MemorySegment * @param rev Where to store the revision number, or {@code null}. * @see #ngetVersion(MemorySegment, MemorySegment, MemorySegment) ngetVersion */ - static void getVersion(int @Nullable [] major, int @Nullable [] minor, int @Nullable [] rev) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var pMajor = major != null ? stack.callocInt() : MemorySegment.NULL; - var pMinor = minor != null ? stack.callocInt() : MemorySegment.NULL; - var pRev = rev != null ? stack.callocInt() : MemorySegment.NULL; - ngetVersion(pMajor, pMinor, pRev); - if (major != null && major.length > 0) { - major[0] = pMajor.get(JAVA_INT, 0); - } - if (minor != null && minor.length > 0) { - minor[0] = pMinor.get(JAVA_INT, 0); - } - if (rev != null && rev.length > 0) { - rev[0] = pRev.get(JAVA_INT, 0); - } - } finally { - stack.setPointer(stackPointer); - } - } + @Entrypoint("glfwGetVersion") + void getVersion(@Ref int @Nullable [] major, @Ref int @Nullable [] minor, @Ref int @Nullable [] rev); /** * Retrieves the version of the GLFW library. @@ -1042,19 +1006,16 @@ static void getVersion(int @Nullable [] major, int @Nullable [] minor, int @Null * @return the major, minor and revision version number * @see #ngetVersion(MemorySegment, MemorySegment, MemorySegment) ngetVersion */ - static Triplet.OfInt getVersion() { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var pMajor = stack.callocInt(); - var pMinor = stack.callocInt(); - var pRev = stack.callocInt(); + @Skip + default Triplet.OfInt getVersion() { + try (MemoryStack stack = MemoryStack.stackPush()) { + var pMajor = stack.ints(0); + var pMinor = stack.ints(0); + var pRev = stack.ints(0); ngetVersion(pMajor, pMinor, pRev); return new Triplet.OfInt(pMajor.get(JAVA_INT, 0), pMinor.get(JAVA_INT, 0), pRev.get(JAVA_INT, 0)); - } finally { - stack.setPointer(stackPointer); } } @@ -1077,13 +1038,8 @@ static Triplet.OfInt getVersion() { * @glfw.thread_safety This function may be called from any thread. * @see #ngetVersion(MemorySegment, MemorySegment, MemorySegment) getVersion */ - static MemorySegment ngetVersionString() { - try { - return (MemorySegment) glfwGetVersionString.invokeExact(); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetVersionString") + MemorySegment ngetVersionString(); /** * Returns a string describing the compile-time configuration. @@ -1091,9 +1047,10 @@ static MemorySegment ngetVersionString() { * @return The ASCII encoded GLFW version string. * @see #ngetVersionString() ngetVersionString */ - static String getVersionString() { - return ngetVersionString().getString(0); - } + @Entrypoint("glfwGetVersionString") + @SizedSeg(Unmarshal.STR_SIZE) + @StrCharset("US-ASCII") + String getVersionString(); /** * Returns and clears the last error for the calling thread. @@ -1114,13 +1071,8 @@ static String getVersionString() { * @glfw.thread_safety This function may be called from any thread. * @see #nsetErrorCallback(MemorySegment) setErrorCallback */ - static int ngetError(MemorySegment description) { - try { - return (int) glfwGetError.invokeExact(description); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetError") + int ngetError(MemorySegment description); /** * Returns and clears the last error for the calling thread. @@ -1129,20 +1081,8 @@ static int ngetError(MemorySegment description) { * @return The last error code for the calling thread, or {@link #NO_ERROR} (zero). * @see #ngetError(MemorySegment) ngetError */ - static int getError(String @Nullable [] description) { - final MemoryStack stack = MemoryStack.stackGet(); - final long stackPointer = stack.getPointer(); - try { - final MemorySegment seg = description != null ? stack.mallocPointer() : MemorySegment.NULL; - final int err = ngetError(seg); - if (description != null && description.length > 0) { - description[0] = RuntimeHelper.unboundPointerString(seg); - } - return err; - } finally { - stack.setPointer(stackPointer); - } - } + @Entrypoint("glfwGetError") + int getError(@Ref String @Nullable [] description); /** * Returns and clears the last error for the calling thread. @@ -1150,15 +1090,12 @@ static int getError(String @Nullable [] description) { * @return the error description pointer. and the last error code for the calling thread, or {@link #NO_ERROR} (zero) * @see #ngetError(MemorySegment) ngetError */ - static Tuple2.OfObjInt getError() { - final MemoryStack stack = MemoryStack.stackGet(); - final long stackPointer = stack.getPointer(); - try { - final MemorySegment seg = stack.mallocPointer(); + @Skip + default Tuple2.OfObjInt getError() { + try (MemoryStack stack = MemoryStack.stackPush()) { + final MemorySegment seg = stack.allocate(ADDRESS); final int err = ngetError(seg); - return new Tuple2.OfObjInt<>(RuntimeHelper.unboundPointerString(seg), err); - } finally { - stack.setPointer(stackPointer); + return new Tuple2.OfObjInt<>(Unmarshal.unmarshalAsString(seg.get(Unmarshal.STR_LAYOUT, 0L)), err); } } @@ -1190,13 +1127,8 @@ static Tuple2.OfObjInt getError() { * @glfw.thread_safety This function must only be called from the main thread. * @see #ngetError(MemorySegment) getError */ - static MemorySegment nsetErrorCallback(MemorySegment callback) { - try { - return (MemorySegment) glfwSetErrorCallback.invokeExact(callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetErrorCallback") + MemorySegment nsetErrorCallback(MemorySegment callback); /** * Sets the error callback. @@ -1205,7 +1137,8 @@ static MemorySegment nsetErrorCallback(MemorySegment callback) { * @return The previously set callback, or {@link MemorySegment#NULL NULL} if no callback was set. * @see #nsetErrorCallback(MemorySegment) nsetErrorCallback */ - static MemorySegment setErrorCallback(@Nullable GLFWErrorFun callback) { + @Skip + default MemorySegment setErrorCallback(@Nullable GLFWErrorFun callback) { return nsetErrorCallback(callback != null ? callback.stub(Arena.ofAuto()) : MemorySegment.NULL); } @@ -1227,13 +1160,8 @@ static MemorySegment setErrorCallback(@Nullable GLFWErrorFun callback) { * @glfw.thread_safety This function must only be called from the main thread. * @see #getPrimaryMonitor() getPrimaryMonitor */ - static MemorySegment ngetMonitors(MemorySegment count) { - try { - return (MemorySegment) glfwGetMonitors.invokeExact(count); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetMonitors") + MemorySegment ngetMonitors(MemorySegment count); /** * Returns the currently connected monitors. @@ -1242,17 +1170,12 @@ static MemorySegment ngetMonitors(MemorySegment count) { * if an error occurred. * @see #ngetMonitors(MemorySegment) ngetMonitors */ - static MemorySegment @Nullable [] getMonitors() { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var pCount = stack.callocInt(); + @Skip + default MemorySegment @Nullable [] getMonitors() { + try (MemoryStack stack = MemoryStack.stackPush()) { + var pCount = stack.ints(0); var pMonitors = ngetMonitors(pCount); - return RuntimeHelper.isNullptr(pMonitors) ? - null : - RuntimeHelper.toArray(pMonitors, new MemorySegment[pCount.get(JAVA_INT, 0)]); - } finally { - stack.setPointer(stackPointer); + return Unmarshal.unmarshalAsAddressArray(pMonitors.reinterpret(ADDRESS.scale(0L, pCount.get(JAVA_INT, 0L)))); } } @@ -1270,13 +1193,8 @@ static MemorySegment ngetMonitors(MemorySegment count) { * {@link #ngetMonitors(MemorySegment) getMonitors}. * @see #ngetMonitors(MemorySegment) getMonitors */ - static MemorySegment getPrimaryMonitor() { - try { - return (MemorySegment) glfwGetPrimaryMonitor.invokeExact(); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetPrimaryMonitor") + MemorySegment getPrimaryMonitor(); /** * Returns the position of the monitor's viewport on the virtual screen. @@ -1294,13 +1212,8 @@ static MemorySegment getPrimaryMonitor() { * {@link #PLATFORM_ERROR}. * @glfw.thread_safety This function must only be called from the main thread. */ - static void ngetMonitorPos(MemorySegment monitor, MemorySegment xpos, MemorySegment ypos) { - try { - glfwGetMonitorPos.invokeExact(monitor, xpos, ypos); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetMonitorPos") + void ngetMonitorPos(MemorySegment monitor, MemorySegment xpos, MemorySegment ypos); /** * Returns the position of the monitor's viewport on the virtual screen. @@ -1310,23 +1223,8 @@ static void ngetMonitorPos(MemorySegment monitor, MemorySegment xpos, MemorySegm * @param ypos Where to store the monitor y-coordinate, or {@code null}. * @see #ngetMonitorPos(MemorySegment, MemorySegment, MemorySegment) ngetMonitorPos */ - static void getMonitorPos(MemorySegment monitor, int @Nullable [] xpos, int @Nullable [] ypos) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var px = xpos != null ? stack.callocInt() : MemorySegment.NULL; - var py = ypos != null ? stack.callocInt() : MemorySegment.NULL; - ngetMonitorPos(monitor, px, py); - if (xpos != null && xpos.length > 0) { - xpos[0] = px.get(JAVA_INT, 0); - } - if (ypos != null && ypos.length > 0) { - ypos[0] = py.get(JAVA_INT, 0); - } - } finally { - stack.setPointer(stackPointer); - } - } + @Entrypoint("glfwGetMonitorPos") + void getMonitorPos(MemorySegment monitor, @Ref int @Nullable [] xpos, @Ref int @Nullable [] ypos); /** * Returns the position of the monitor's viewport on the virtual screen. @@ -1335,16 +1233,13 @@ static void getMonitorPos(MemorySegment monitor, int @Nullable [] xpos, int @Nul * @return the monitor xy-coordinate * @see #ngetMonitorPos(MemorySegment, MemorySegment, MemorySegment) ngetMonitorPos */ - static Pair.OfInt getMonitorPos(MemorySegment monitor) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var px = stack.callocInt(); - var py = stack.callocInt(); + @Skip + default Pair.OfInt getMonitorPos(MemorySegment monitor) { + try (MemoryStack stack = MemoryStack.stackPush()) { + var px = stack.ints(0); + var py = stack.ints(0); ngetMonitorPos(monitor, px, py); return new Pair.OfInt(px.get(JAVA_INT, 0), py.get(JAVA_INT, 0)); - } finally { - stack.setPointer(stackPointer); } } @@ -1370,13 +1265,8 @@ static Pair.OfInt getMonitorPos(MemorySegment monitor) { * {@link #PLATFORM_ERROR}. * @glfw.thread_safety This function must only be called from the main thread. */ - static void ngetMonitorWorkarea(MemorySegment monitor, MemorySegment xpos, MemorySegment ypos, MemorySegment width, MemorySegment height) { - try { - glfwGetMonitorWorkarea.invokeExact(monitor, xpos, ypos, width, height); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetMonitorWorkarea") + void ngetMonitorWorkarea(MemorySegment monitor, MemorySegment xpos, MemorySegment ypos, MemorySegment width, MemorySegment height); /** * Retrieves the work area of the monitor. @@ -1388,31 +1278,8 @@ static void ngetMonitorWorkarea(MemorySegment monitor, MemorySegment xpos, Memor * @param height Where to store the monitor height, or {@code null}. * @see #ngetMonitorWorkarea(MemorySegment, MemorySegment, MemorySegment, MemorySegment, MemorySegment) ngetMonitorWorkarea */ - static void getMonitorWorkarea(MemorySegment monitor, int @Nullable [] xpos, int @Nullable [] ypos, int @Nullable [] width, int @Nullable [] height) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var px = xpos != null ? stack.callocInt() : MemorySegment.NULL; - var py = ypos != null ? stack.callocInt() : MemorySegment.NULL; - var pw = width != null ? stack.callocInt() : MemorySegment.NULL; - var ph = height != null ? stack.callocInt() : MemorySegment.NULL; - ngetMonitorWorkarea(monitor, px, py, pw, ph); - if (xpos != null && xpos.length > 0) { - xpos[0] = px.get(JAVA_INT, 0); - } - if (ypos != null && ypos.length > 0) { - ypos[0] = py.get(JAVA_INT, 0); - } - if (width != null && width.length > 0) { - width[0] = pw.get(JAVA_INT, 0); - } - if (height != null && height.length > 0) { - height[0] = ph.get(JAVA_INT, 0); - } - } finally { - stack.setPointer(stackPointer); - } - } + @Entrypoint("glfwGetMonitorWorkarea") + void getMonitorWorkarea(MemorySegment monitor, @Ref int @Nullable [] xpos, @Ref int @Nullable [] ypos, @Ref int @Nullable [] width, @Ref int @Nullable [] height); /** * Retrieves the work area of the monitor. @@ -1421,21 +1288,18 @@ static void getMonitorWorkarea(MemorySegment monitor, int @Nullable [] xpos, int * @return the monitor xy-coordinate, the monitor width and the monitor height * @see #ngetMonitorWorkarea(MemorySegment, MemorySegment, MemorySegment, MemorySegment, MemorySegment) ngetMonitorWorkarea */ - static Quad.OfInt getMonitorWorkarea(MemorySegment monitor) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var px = stack.callocInt(); - var py = stack.callocInt(); - var pw = stack.callocInt(); - var ph = stack.callocInt(); + @Skip + default Quad.OfInt getMonitorWorkarea(MemorySegment monitor) { + try (MemoryStack stack = MemoryStack.stackPush()) { + var px = stack.ints(0); + var py = stack.ints(0); + var pw = stack.ints(0); + var ph = stack.ints(0); ngetMonitorWorkarea(monitor, px, py, pw, ph); return new Quad.OfInt(px.get(JAVA_INT, 0), py.get(JAVA_INT, 0), pw.get(JAVA_INT, 0), ph.get(JAVA_INT, 0)); - } finally { - stack.setPointer(stackPointer); } } @@ -1463,13 +1327,8 @@ static Quad.OfInt getMonitorWorkarea(MemorySegment monitor) { * the current resolution and system DPI instead of querying the monitor EDID data. * @glfw.thread_safety This function must only be called from the main thread. */ - static void ngetMonitorPhysicalSize(MemorySegment monitor, MemorySegment widthMM, MemorySegment heightMM) { - try { - glfwGetMonitorPhysicalSize.invokeExact(monitor, widthMM, heightMM); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetMonitorPhysicalSize") + void ngetMonitorPhysicalSize(MemorySegment monitor, MemorySegment widthMM, MemorySegment heightMM); /** * Returns the physical size of the monitor. @@ -1481,23 +1340,8 @@ static void ngetMonitorPhysicalSize(MemorySegment monitor, MemorySegment widthMM * monitor's display area, or {@code null}. * @see #ngetMonitorPhysicalSize(MemorySegment, MemorySegment, MemorySegment) ngetMonitorPhysicalSize */ - static void getMonitorPhysicalSize(MemorySegment monitor, int @Nullable [] widthMM, int @Nullable [] heightMM) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var pw = widthMM != null ? stack.callocInt() : MemorySegment.NULL; - var ph = heightMM != null ? stack.callocInt() : MemorySegment.NULL; - ngetMonitorPhysicalSize(monitor, pw, ph); - if (widthMM != null && widthMM.length > 0) { - widthMM[0] = pw.get(JAVA_INT, 0); - } - if (heightMM != null && heightMM.length > 0) { - heightMM[0] = ph.get(JAVA_INT, 0); - } - } finally { - stack.setPointer(stackPointer); - } - } + @Entrypoint("glfwGetMonitorPhysicalSize") + void getMonitorPhysicalSize(MemorySegment monitor, @Ref int @Nullable [] widthMM, @Ref int @Nullable [] heightMM); /** * Returns the physical size of the monitor. @@ -1506,16 +1350,13 @@ static void getMonitorPhysicalSize(MemorySegment monitor, int @Nullable [] width * @return the width and height, in millimetres, of the monitor's display area. * @see #ngetMonitorPhysicalSize(MemorySegment, MemorySegment, MemorySegment) ngetMonitorPhysicalSize */ - static Pair.OfInt getMonitorPhysicalSize(MemorySegment monitor) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var pw = stack.callocInt(); - var ph = stack.callocInt(); + @Skip + default Pair.OfInt getMonitorPhysicalSize(MemorySegment monitor) { + try (MemoryStack stack = MemoryStack.stackPush()) { + var pw = stack.ints(0); + var ph = stack.ints(0); ngetMonitorPhysicalSize(monitor, pw, ph); return new Pair.OfInt(pw.get(JAVA_INT, 0), ph.get(JAVA_INT, 0)); - } finally { - stack.setPointer(stackPointer); } } @@ -1542,13 +1383,8 @@ static Pair.OfInt getMonitorPhysicalSize(MemorySegment monitor) { * @glfw.thread_safety This function must only be called from the main thread. * @see #ngetWindowContentScale(MemorySegment, MemorySegment, MemorySegment) getWindowContentScale */ - static void ngetMonitorContentScale(MemorySegment monitor, MemorySegment xscale, MemorySegment yscale) { - try { - glfwGetMonitorContentScale.invokeExact(monitor, xscale, yscale); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetMonitorContentScale") + void ngetMonitorContentScale(MemorySegment monitor, MemorySegment xscale, MemorySegment yscale); /** * Retrieves the content scale for the specified monitor. @@ -1558,23 +1394,8 @@ static void ngetMonitorContentScale(MemorySegment monitor, MemorySegment xscale, * @param yscale Where to store the y-axis content scale, or {@code null}. * @see #ngetMonitorContentScale(MemorySegment, MemorySegment, MemorySegment) ngetMonitorContentScale */ - static void getMonitorContentScale(MemorySegment monitor, float @Nullable [] xscale, float @Nullable [] yscale) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var px = xscale != null ? stack.callocFloat() : MemorySegment.NULL; - var py = yscale != null ? stack.callocFloat() : MemorySegment.NULL; - ngetMonitorContentScale(monitor, px, py); - if (xscale != null && xscale.length > 0) { - xscale[0] = px.get(JAVA_FLOAT, 0); - } - if (yscale != null && yscale.length > 0) { - yscale[0] = py.get(JAVA_FLOAT, 0); - } - } finally { - stack.setPointer(stackPointer); - } - } + @Entrypoint("glfwGetMonitorContentScale") + void getMonitorContentScale(MemorySegment monitor, @Ref float @Nullable [] xscale, @Ref float @Nullable [] yscale); /** * Retrieves the content scale for the specified monitor. @@ -1583,16 +1404,13 @@ static void getMonitorContentScale(MemorySegment monitor, float @Nullable [] xsc * @return the xy-axis content scale * @see #ngetMonitorContentScale(MemorySegment, MemorySegment, MemorySegment) ngetMonitorContentScale */ - static Pair.OfFloat getMonitorContentScale(MemorySegment monitor) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var px = stack.callocFloat(); - var py = stack.callocFloat(); + @Skip + default Pair.OfFloat getMonitorContentScale(MemorySegment monitor) { + try (MemoryStack stack = MemoryStack.stackPush()) { + var px = stack.floats(0F); + var py = stack.floats(0F); ngetMonitorContentScale(monitor, px, py); return new Pair.OfFloat(px.get(JAVA_FLOAT, 0), py.get(JAVA_FLOAT, 0)); - } finally { - stack.setPointer(stackPointer); } } @@ -1612,13 +1430,8 @@ static Pair.OfFloat getMonitorContentScale(MemorySegment monitor) { * disconnected or the library is terminated. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment ngetMonitorName(MemorySegment monitor) { - try { - return (MemorySegment) glfwGetMonitorName.invokeExact(monitor); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetMonitorName") + MemorySegment ngetMonitorName(MemorySegment monitor); /** * Returns the name of the specified monitor. @@ -1628,11 +1441,10 @@ static MemorySegment ngetMonitorName(MemorySegment monitor) { * error occurred. * @see #ngetMonitorName(MemorySegment) ngetMonitorName */ + @Entrypoint("glfwGetMonitorName") @Nullable - static String getMonitorName(MemorySegment monitor) { - var pName = ngetMonitorName(monitor); - return RuntimeHelper.isNullptr(pName) ? null : pName.getString(0); - } + @SizedSeg(Unmarshal.STR_SIZE) + String getMonitorName(MemorySegment monitor); /** * Sets the user pointer of the specified monitor. @@ -1651,13 +1463,8 @@ static String getMonitorName(MemorySegment monitor) { * synchronized. * @see #getMonitorUserPointer(MemorySegment) getMonitorUserPointer */ - static void setMonitorUserPointer(MemorySegment monitor, MemorySegment pointer) { - try { - glfwSetMonitorUserPointer.invokeExact(monitor, pointer); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetMonitorUserPointer") + void setMonitorUserPointer(MemorySegment monitor, MemorySegment pointer); /** * {@return the user pointer of the specified monitor} @@ -1674,13 +1481,8 @@ static void setMonitorUserPointer(MemorySegment monitor, MemorySegment pointer) * synchronized. * @see #setMonitorUserPointer(MemorySegment, MemorySegment) setMonitorUserPointer */ - static MemorySegment getMonitorUserPointer(MemorySegment monitor) { - try { - return (MemorySegment) glfwGetMonitorUserPointer.invokeExact(monitor); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetMonitorUserPointer") + MemorySegment getMonitorUserPointer(MemorySegment monitor); /** * Sets the monitor configuration callback. @@ -1699,13 +1501,8 @@ static MemorySegment getMonitorUserPointer(MemorySegment monitor) { * @glfw.errors Possible errors include {@link #NOT_INITIALIZED}. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment nsetMonitorCallback(MemorySegment callback) { - try { - return (MemorySegment) glfwSetMonitorCallback.invokeExact(callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetMonitorCallback") + MemorySegment nsetMonitorCallback(MemorySegment callback); /** * Sets the monitor configuration callback. @@ -1716,7 +1513,8 @@ static MemorySegment nsetMonitorCallback(MemorySegment callback) { * library had not been initialized. * @see #nsetMonitorCallback(MemorySegment) nsetMonitorCallback */ - static MemorySegment setMonitorCallback(@Nullable GLFWMonitorFun callback) { + @Skip + default MemorySegment setMonitorCallback(@Nullable GLFWMonitorFun callback) { return nsetMonitorCallback(callback != null ? callback.stub(Arena.ofAuto()) : MemorySegment.NULL); } @@ -1743,13 +1541,8 @@ static MemorySegment setMonitorCallback(@Nullable GLFWMonitorFun callback) { * @glfw.thread_safety This function must only be called from the main thread. * @see #ngetVideoMode(MemorySegment) getVideoMode */ - static MemorySegment ngetVideoModes(MemorySegment monitor, MemorySegment count) { - try { - return (MemorySegment) glfwGetVideoModes.invokeExact(monitor, count); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetVideoModes") + MemorySegment ngetVideoModes(MemorySegment monitor, MemorySegment count); /** * Returns the available video modes for the specified monitor. @@ -1759,17 +1552,16 @@ static MemorySegment ngetVideoModes(MemorySegment monitor, MemorySegment count) * error occurred. * @see #ngetVideoModes(MemorySegment, MemorySegment) ngetVideoModes */ - static @Nullable GLFWVidMode getVideoModes(MemorySegment monitor) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var pCount = stack.callocInt(); + @Skip + default @Nullable GLFWVidMode getVideoModes(MemorySegment monitor) { + try (MemoryStack stack = MemoryStack.stackPush()) { + var pCount = stack.ints(0); var pModes = ngetVideoModes(monitor, pCount); - return RuntimeHelper.isNullptr(pModes) ? - null : - new GLFWVidMode(pModes, pCount.get(JAVA_INT, 0)); - } finally { - stack.setPointer(stackPointer); + if (Unmarshal.isNullPointer(pModes)) { + return null; + } + final int count = pCount.get(JAVA_INT, 0); + return new GLFWVidMode(pModes.reinterpret(GLFWVidMode.LAYOUT.scale(0L, count)), count); } } @@ -1791,13 +1583,8 @@ static MemorySegment ngetVideoModes(MemorySegment monitor, MemorySegment count) * @glfw.thread_safety This function must only be called from the main thread. * @see #ngetVideoModes(MemorySegment, MemorySegment) getVideoModes */ - static MemorySegment ngetVideoMode(MemorySegment monitor) { - try { - return (MemorySegment) glfwGetVideoMode.invokeExact(monitor); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetVideoMode") + MemorySegment ngetVideoMode(MemorySegment monitor); /** * Returns the current mode of the specified monitor. @@ -1808,10 +1595,11 @@ static MemorySegment ngetVideoMode(MemorySegment monitor) { * @see #ngetVideoMode(MemorySegment) ngetVideoMode */ @Nullable - static GLFWVidMode.Value getVideoMode(MemorySegment monitor) { + @Skip + default GLFWVidMode.Value getVideoMode(MemorySegment monitor) { var pMode = ngetVideoMode(monitor); - if (RuntimeHelper.isNullptr(pMode)) return null; - return new GLFWVidMode(pMode).value(); + if (Unmarshal.isNullPointer(pMode)) return null; + return new GLFWVidMode(pMode.reinterpret(GLFWVidMode.LAYOUT.byteSize())).value(); } /** @@ -1837,13 +1625,8 @@ static GLFWVidMode.Value getVideoMode(MemorySegment monitor) { * will thus never be implemented and emits {@link #PLATFORM_ERROR}. * @glfw.thread_safety This function must only be called from the main thread. */ - static void setGamma(MemorySegment monitor, float gamma) { - try { - glfwSetGamma.invokeExact(monitor, gamma); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetGamma") + void setGamma(MemorySegment monitor, float gamma); /** * Returns the current gamma ramp for the specified monitor. @@ -1864,13 +1647,8 @@ static void setGamma(MemorySegment monitor, float gamma) { * monitor or the library is terminated. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment ngetGammaRamp(MemorySegment monitor) { - try { - return (MemorySegment) glfwGetGammaRamp.invokeExact(monitor); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetGammaRamp") + MemorySegment ngetGammaRamp(MemorySegment monitor); /** * Returns the current gamma ramp for the specified monitor. @@ -1880,12 +1658,9 @@ static MemorySegment ngetGammaRamp(MemorySegment monitor) { * error occurred. * @see #ngetGammaRamp(MemorySegment) ngetGammaRamp */ + @Entrypoint("glfwGetGammaRamp") @Nullable - static GLFWGammaRamp getGammaRamp(MemorySegment monitor) { - var pRamp = ngetGammaRamp(monitor); - if (RuntimeHelper.isNullptr(pRamp)) return null; - return new GLFWGammaRamp(pRamp); - } + GLFWGammaRamp getGammaRamp(MemorySegment monitor); /** * Sets the current gamma ramp for the specified monitor. @@ -1917,13 +1692,8 @@ static GLFWGammaRamp getGammaRamp(MemorySegment monitor) { * returns. * @glfw.thread_safety This function must only be called from the main thread. */ - static void nsetGammaRamp(MemorySegment monitor, MemorySegment ramp) { - try { - glfwSetGammaRamp.invokeExact(monitor, ramp); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetGammaRamp") + void nsetGammaRamp(MemorySegment monitor, MemorySegment ramp); /** * Sets the current gamma ramp for the specified monitor. @@ -1932,9 +1702,8 @@ static void nsetGammaRamp(MemorySegment monitor, MemorySegment ramp) { * @param ramp The gamma ramp to use. * @see #nsetGammaRamp(MemorySegment, MemorySegment) nsetGammaRamp */ - static void setGammaRamp(MemorySegment monitor, GLFWGammaRamp ramp) { - nsetGammaRamp(monitor, ramp.segment()); - } + @Entrypoint("glfwSetGammaRamp") + void setGammaRamp(MemorySegment monitor, GLFWGammaRamp ramp); /** * Resets all window hints to their default values. @@ -1947,13 +1716,8 @@ static void setGammaRamp(MemorySegment monitor, GLFWGammaRamp ramp) { * @see #windowHint(int, int) windowHint * @see #nwindowHintString(int, MemorySegment) windowHintString */ - static void defaultWindowHints() { - try { - glfwDefaultWindowHints.invokeExact(); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwDefaultWindowHints") + void defaultWindowHints(); /** * Sets the specified window hint to the desired value. @@ -1981,13 +1745,8 @@ static void defaultWindowHints() { * @see #nwindowHintString(int, MemorySegment) windowHintString * @see #defaultWindowHints */ - static void windowHint(int hint, int value) { - try { - glfwWindowHint.invokeExact(hint, value); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwWindowHint") + void windowHint(int hint, int value); /** * Sets the specified window hint to the desired value. @@ -1996,9 +1755,8 @@ static void windowHint(int hint, int value) { * @param value The new value of the window hint. * @see #windowHint(int, int) */ - static void windowHint(int hint, boolean value) { - windowHint(hint, value ? TRUE : FALSE); - } + @Entrypoint("glfwWindowHint") + void windowHint(int hint, @Convert(Type.INT) boolean value); /** * Sets the specified window hint to the desired value. @@ -2028,13 +1786,8 @@ static void windowHint(int hint, boolean value) { * @see #windowHint(int, int) windowHint * @see #defaultWindowHints */ - static void nwindowHintString(int hint, MemorySegment value) { - try { - glfwWindowHintString.invokeExact(hint, value); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwWindowHintString") + void nwindowHintString(int hint, MemorySegment value); /** * Sets the specified window hint to the desired value. @@ -2043,15 +1796,8 @@ static void nwindowHintString(int hint, MemorySegment value) { * @param value The new value of the window hint. * @see #nwindowHintString(int, MemorySegment) nwindowHintString */ - static void windowHintString(int hint, String value) { - final MemoryStack stack = MemoryStack.stackGet(); - final long stackPointer = stack.getPointer(); - try { - nwindowHintString(hint, stack.allocateFrom(value)); - } finally { - stack.setPointer(stackPointer); - } - } + @Entrypoint("glfwWindowHintString") + void windowHintString(int hint, String value); /** * Creates a window and its associated context. @@ -2204,13 +1950,8 @@ static void windowHintString(int hint, String value) { * @glfw.thread_safety This function must only be called from the main thread. * @see #destroyWindow */ - static MemorySegment ncreateWindow(int width, int height, MemorySegment title, MemorySegment monitor, MemorySegment share) { - try { - return (MemorySegment) glfwCreateWindow.invokeExact(width, height, title, monitor, share); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwCreateWindow") + MemorySegment ncreateWindow(int width, int height, MemorySegment title, MemorySegment monitor, MemorySegment share); /** * Creates a window and its associated context. @@ -2228,15 +1969,8 @@ static MemorySegment ncreateWindow(int width, int height, MemorySegment title, M * error occurred. * @see #ncreateWindow(int, int, MemorySegment, MemorySegment, MemorySegment) ncreateWindow */ - static MemorySegment createWindow(int width, int height, String title, MemorySegment monitor, MemorySegment share) { - final MemoryStack stack = MemoryStack.stackGet(); - final long stackPointer = stack.getPointer(); - try { - return ncreateWindow(width, height, stack.allocateFrom(title), monitor, share); - } finally { - stack.setPointer(stackPointer); - } - } + @Entrypoint("glfwCreateWindow") + MemorySegment createWindow(int width, int height, String title, MemorySegment monitor, MemorySegment share); /** * Destroys the specified window and its context. @@ -2256,13 +1990,8 @@ static MemorySegment createWindow(int width, int height, String title, MemorySeg * @glfw.thread_safety This function must only be called from the main thread. * @see #ncreateWindow(int, int, MemorySegment, MemorySegment, MemorySegment) createWindow */ - static void destroyWindow(MemorySegment window) { - try { - glfwDestroyWindow.invokeExact(window); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwDestroyWindow") + void destroyWindow(MemorySegment window); /** * Checks the close flag of the specified window. @@ -2275,13 +2004,9 @@ static void destroyWindow(MemorySegment window) { * @glfw.thread_safety This function may be called from any thread. Access is not * synchronized. */ - static boolean windowShouldClose(MemorySegment window) { - try { - return (int) glfwWindowShouldClose.invokeExact(window) != FALSE; - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Convert(Type.INT) + @Entrypoint("glfwWindowShouldClose") + boolean windowShouldClose(MemorySegment window); /** * Sets the close flag of the specified window. @@ -2296,13 +2021,8 @@ static boolean windowShouldClose(MemorySegment window) { * @glfw.thread_safety This function may be called from any thread. Access is not * synchronized. */ - static void setWindowShouldClose(MemorySegment window, boolean value) { - try { - glfwSetWindowShouldClose.invokeExact(window, value ? TRUE : FALSE); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowShouldClose") + void setWindowShouldClose(MemorySegment window, @Convert(Type.INT) boolean value); /** * Sets the title of the specified window. @@ -2318,13 +2038,8 @@ static void setWindowShouldClose(MemorySegment window, boolean value) { * process events. * @glfw.thread_safety This function must only be called from the main thread. */ - static void nsetWindowTitle(MemorySegment window, MemorySegment title) { - try { - glfwSetWindowTitle.invokeExact(window, title); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowTitle") + void nsetWindowTitle(MemorySegment window, MemorySegment title); /** * Sets the title of the specified window. @@ -2333,15 +2048,8 @@ static void nsetWindowTitle(MemorySegment window, MemorySegment title) { * @param title The UTF-8 encoded window title. * @see #nsetWindowTitle(MemorySegment, MemorySegment) nsetWindowTitle */ - static void setWindowTitle(MemorySegment window, String title) { - final MemoryStack stack = MemoryStack.stackGet(); - final long stackPointer = stack.getPointer(); - try { - nsetWindowTitle(window, stack.allocateFrom(title)); - } finally { - stack.setPointer(stackPointer); - } - } + @Entrypoint("glfwSetWindowTitle") + void setWindowTitle(MemorySegment window, String title); /** * Sets the icon for the specified window. @@ -2379,13 +2087,8 @@ static void setWindowTitle(MemorySegment window, String title) { * This function always emits {@link #PLATFORM_ERROR}. * @glfw.thread_safety This function must only be called from the main thread. */ - static void nsetWindowIcon(MemorySegment window, int count, MemorySegment images) { - try { - glfwSetWindowIcon.invokeExact(window, count, images); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowIcon") + void nsetWindowIcon(MemorySegment window, int count, MemorySegment images); /** * Sets the icon for the specified window. @@ -2397,7 +2100,8 @@ static void nsetWindowIcon(MemorySegment window, int count, MemorySegment images * count is zero. * @see #nsetWindowIcon(MemorySegment, int, MemorySegment) nsetWindowIcon */ - static void setWindowIcon(MemorySegment window, int count, GLFWImage images) { + @Skip + default void setWindowIcon(MemorySegment window, int count, GLFWImage images) { if (images == null || count == 0) { nsetWindowIcon(window, 0, MemorySegment.NULL); } else { @@ -2413,7 +2117,8 @@ static void setWindowIcon(MemorySegment window, int count, GLFWImage images) { * revert to the default window icon. * @see #nsetWindowIcon(MemorySegment, int, MemorySegment) nsetWindowIcon */ - static void setWindowIcon(MemorySegment window, @Nullable GLFWImage images) { + @Skip + default void setWindowIcon(MemorySegment window, @Nullable GLFWImage images) { setWindowIcon(window, images == null ? 0 : Math.toIntExact(images.elementCount()), images); } @@ -2439,13 +2144,8 @@ static void setWindowIcon(MemorySegment window, @Nullable GLFWImage images) { * @glfw.thread_safety This function must only be called from the main thread. * @see #setWindowPos(MemorySegment, int, int) setWindowPos */ - static void ngetWindowPos(MemorySegment window, MemorySegment xpos, MemorySegment ypos) { - try { - glfwGetWindowPos.invokeExact(window, xpos, ypos); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetWindowPos") + void ngetWindowPos(MemorySegment window, MemorySegment xpos, MemorySegment ypos); /** * Retrieves the position of the content area of the specified window. @@ -2456,23 +2156,8 @@ static void ngetWindowPos(MemorySegment window, MemorySegment xpos, MemorySegmen * @param ypos Where to store the y-coordinate of the upper-left corner of * the content area, or {@code null}. */ - static void getWindowPos(MemorySegment window, int @Nullable [] xpos, int @Nullable [] ypos) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var px = xpos != null ? stack.callocInt() : MemorySegment.NULL; - var py = ypos != null ? stack.callocInt() : MemorySegment.NULL; - ngetWindowPos(window, px, py); - if (xpos != null && xpos.length > 1) { - xpos[0] = px.get(JAVA_INT, 0); - } - if (ypos != null && ypos.length > 1) { - ypos[0] = py.get(JAVA_INT, 0); - } - } finally { - stack.setPointer(stackPointer); - } - } + @Entrypoint("glfwGetWindowPos") + void getWindowPos(MemorySegment window, @Ref int @Nullable [] xpos, @Ref int @Nullable [] ypos); /** * Retrieves the position of the content area of the specified window. @@ -2480,16 +2165,13 @@ static void getWindowPos(MemorySegment window, int @Nullable [] xpos, int @Nulla * @param window The window to query. * @return the xy-coordinate of the upper-left corner of the content area. */ - static Pair.OfInt getWindowPos(MemorySegment window) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var px = stack.callocInt(); - var py = stack.callocInt(); + @Skip + default Pair.OfInt getWindowPos(MemorySegment window) { + try (MemoryStack stack = MemoryStack.stackPush()) { + var px = stack.ints(0); + var py = stack.ints(0); ngetWindowPos(window, px, py); return new Pair.OfInt(px.get(JAVA_INT, 0), py.get(JAVA_INT, 0)); - } finally { - stack.setPointer(stackPointer); } } @@ -2517,13 +2199,8 @@ static Pair.OfInt getWindowPos(MemorySegment window) { * @glfw.thread_safety This function must only be called from the main thread. * @see #ngetWindowPos(MemorySegment, MemorySegment, MemorySegment) getWindowPos */ - static void setWindowPos(MemorySegment window, int xpos, int ypos) { - try { - glfwSetWindowPos.invokeExact(window, xpos, ypos); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowPos") + void setWindowPos(MemorySegment window, int xpos, int ypos); /** * Retrieves the size of the content area of the specified window. @@ -2546,13 +2223,8 @@ static void setWindowPos(MemorySegment window, int xpos, int ypos) { * @glfw.thread_safety This function must only be called from the main thread. * @see #setWindowSize(MemorySegment, int, int) setWindowSize */ - static void ngetWindowSize(MemorySegment window, MemorySegment width, MemorySegment height) { - try { - glfwGetWindowSize.invokeExact(window, width, height); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetWindowSize") + void ngetWindowSize(MemorySegment window, MemorySegment width, MemorySegment height); /** * Retrieves the size of the content area of the specified window. @@ -2564,23 +2236,8 @@ static void ngetWindowSize(MemorySegment window, MemorySegment width, MemorySegm * content area, or {@code null}. * @see #ngetWindowSize(MemorySegment, MemorySegment, MemorySegment) ngetWindowSize */ - static void getWindowSize(MemorySegment window, int @Nullable [] width, int @Nullable [] height) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var pw = width != null ? stack.callocInt() : MemorySegment.NULL; - var ph = height != null ? stack.callocInt() : MemorySegment.NULL; - ngetWindowSize(window, pw, ph); - if (width != null && width.length > 0) { - width[0] = pw.get(JAVA_INT, 0); - } - if (height != null && height.length > 0) { - height[0] = ph.get(JAVA_INT, 0); - } - } finally { - stack.setPointer(stackPointer); - } - } + @Entrypoint("glfwGetWindowSize") + void getWindowSize(MemorySegment window, @Ref int @Nullable [] width, @Ref int @Nullable [] height); /** * Retrieves the size of the content area of the specified window. @@ -2589,16 +2246,13 @@ static void getWindowSize(MemorySegment window, int @Nullable [] width, int @Nul * @return the width and height, in screen coordinates, of the content area. * @see #ngetWindowSize(MemorySegment, MemorySegment, MemorySegment) ngetWindowSize */ - static Pair.OfInt getWindowSize(MemorySegment window) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var pw = stack.callocInt(); - var ph = stack.callocInt(); + @Skip + default Pair.OfInt getWindowSize(MemorySegment window) { + try (MemoryStack stack = MemoryStack.stackPush()) { + var pw = stack.ints(0); + var ph = stack.ints(0); ngetWindowSize(window, pw, ph); return new Pair.OfInt(pw.get(JAVA_INT, 0), ph.get(JAVA_INT, 0)); - } finally { - stack.setPointer(stackPointer); } } @@ -2635,13 +2289,8 @@ static Pair.OfInt getWindowSize(MemorySegment window) { * @glfw.thread_safety This function must only be called from the main thread. * @see #setWindowAspectRatio(MemorySegment, int, int) setWindowAspectRatio */ - static void setWindowSizeLimits(MemorySegment window, int minWidth, int minHeight, int maxWidth, int maxHeight) { - try { - glfwSetWindowSizeLimits.invokeExact(window, minWidth, minHeight, maxWidth, maxHeight); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowSizeLimits") + void setWindowSizeLimits(MemorySegment window, int minWidth, int minHeight, int maxWidth, int maxHeight); /** * Sets the aspect ratio of the specified window. @@ -2676,13 +2325,8 @@ static void setWindowSizeLimits(MemorySegment window, int minWidth, int minHeigh * @glfw.thread_safety This function must only be called from the main thread. * @see #setWindowSizeLimits(MemorySegment, int, int, int, int) setWindowSizeLimits */ - static void setWindowAspectRatio(MemorySegment window, int numer, int denom) { - try { - glfwSetWindowAspectRatio.invokeExact(window, numer, denom); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowAspectRatio") + void setWindowAspectRatio(MemorySegment window, int numer, int denom); /** * Sets the size of the content area of the specified window. @@ -2715,13 +2359,8 @@ static void setWindowAspectRatio(MemorySegment window, int numer, int denom) { * @see #ngetWindowSize(MemorySegment, MemorySegment, MemorySegment) getWindowSize * @see #setWindowMonitor(MemorySegment, MemorySegment, int, int, int, int, int) setWindowMonitor */ - static void setWindowSize(MemorySegment window, int width, int height) { - try { - glfwSetWindowSize.invokeExact(window, width, height); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowSize") + void setWindowSize(MemorySegment window, int width, int height); /** * Retrieves the size of the framebuffer of the specified window. @@ -2743,13 +2382,8 @@ static void setWindowSize(MemorySegment window, int width, int height) { * @glfw.thread_safety This function must only be called from the main thread. * @see #nsetFramebufferSizeCallback(MemorySegment, MemorySegment) setFramebufferSizeCallback */ - static void ngetFramebufferSize(MemorySegment window, MemorySegment width, MemorySegment height) { - try { - glfwGetFramebufferSize.invokeExact(window, width, height); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetFramebufferSize") + void ngetFramebufferSize(MemorySegment window, MemorySegment width, MemorySegment height); /** * Retrieves the size of the framebuffer of the specified window. @@ -2761,23 +2395,8 @@ static void ngetFramebufferSize(MemorySegment window, MemorySegment width, Memor * or {@code null}. * @see #ngetFramebufferSize(MemorySegment, MemorySegment, MemorySegment) ngetFramebufferSize */ - static void getFramebufferSize(MemorySegment window, int @Nullable [] width, int @Nullable [] height) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var pw = width != null ? stack.callocInt() : MemorySegment.NULL; - var ph = height != null ? stack.callocInt() : MemorySegment.NULL; - ngetFramebufferSize(window, pw, ph); - if (width != null && width.length > 0) { - width[0] = pw.get(JAVA_INT, 0); - } - if (height != null && height.length > 0) { - height[0] = ph.get(JAVA_INT, 0); - } - } finally { - stack.setPointer(stackPointer); - } - } + @Entrypoint("glfwGetFramebufferSize") + void getFramebufferSize(MemorySegment window, @Ref int @Nullable [] width, @Ref int @Nullable [] height); /** * Retrieves the size of the framebuffer of the specified window. @@ -2786,16 +2405,13 @@ static void getFramebufferSize(MemorySegment window, int @Nullable [] width, int * @return the width and height, in pixels, of the framebuffer. * @see #ngetFramebufferSize(MemorySegment, MemorySegment, MemorySegment) ngetFramebufferSize */ - static Pair.OfInt getFramebufferSize(MemorySegment window) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var pw = stack.callocInt(); - var ph = stack.callocInt(); + @Skip + default Pair.OfInt getFramebufferSize(MemorySegment window) { + try (MemoryStack stack = MemoryStack.stackPush()) { + var pw = stack.ints(0); + var ph = stack.ints(0); ngetFramebufferSize(window, pw, ph); return new Pair.OfInt(pw.get(JAVA_INT, 0), ph.get(JAVA_INT, 0)); - } finally { - stack.setPointer(stackPointer); } } @@ -2828,13 +2444,8 @@ static Pair.OfInt getFramebufferSize(MemorySegment window) { * {@link #PLATFORM_ERROR}. * @glfw.thread_safety This function must only be called from the main thread. */ - static void ngetWindowFrameSize(MemorySegment window, MemorySegment left, MemorySegment top, MemorySegment right, MemorySegment bottom) { - try { - glfwGetWindowFrameSize.invokeExact(window, left, top, right, bottom); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetWindowFrameSize") + void ngetWindowFrameSize(MemorySegment window, MemorySegment left, MemorySegment top, MemorySegment right, MemorySegment bottom); /** * Retrieves the size of the frame of the window. @@ -2850,31 +2461,8 @@ static void ngetWindowFrameSize(MemorySegment window, MemorySegment left, Memory * bottom edge of the window frame, or {@code null}. * @see #ngetWindowFrameSize(MemorySegment, MemorySegment, MemorySegment, MemorySegment, MemorySegment) ngetWindowFrameSize */ - static void getWindowFrameSize(MemorySegment window, int @Nullable [] left, int @Nullable [] top, int @Nullable [] right, int @Nullable [] bottom) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var pl = left != null ? stack.callocInt() : MemorySegment.NULL; - var pt = top != null ? stack.callocInt() : MemorySegment.NULL; - var pr = right != null ? stack.callocInt() : MemorySegment.NULL; - var pb = bottom != null ? stack.callocInt() : MemorySegment.NULL; - ngetWindowFrameSize(window, pl, pt, pr, pb); - if (left != null && left.length > 0) { - left[0] = pl.get(JAVA_INT, 0); - } - if (top != null && top.length > 0) { - top[0] = pt.get(JAVA_INT, 0); - } - if (right != null && right.length > 0) { - right[0] = pr.get(JAVA_INT, 0); - } - if (bottom != null && bottom.length > 0) { - bottom[0] = pb.get(JAVA_INT, 0); - } - } finally { - stack.setPointer(stackPointer); - } - } + @Entrypoint("glfwGetWindowFrameSize") + void getWindowFrameSize(MemorySegment window, @Ref int @Nullable [] left, @Ref int @Nullable [] top, @Ref int @Nullable [] right, @Ref int @Nullable [] bottom); /** * Retrieves the size of the frame of the window. @@ -2884,21 +2472,18 @@ static void getWindowFrameSize(MemorySegment window, int @Nullable [] left, int * edge of the window frame. * @see #ngetWindowFrameSize(MemorySegment, MemorySegment, MemorySegment, MemorySegment, MemorySegment) ngetWindowFrameSize */ - static Quad.OfInt getWindowFrameSize(MemorySegment window) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var pl = stack.callocInt(); - var pt = stack.callocInt(); - var pr = stack.callocInt(); - var pb = stack.callocInt(); + @Skip + default Quad.OfInt getWindowFrameSize(MemorySegment window) { + try (MemoryStack stack = MemoryStack.stackPush()) { + var pl = stack.ints(0); + var pt = stack.ints(0); + var pr = stack.ints(0); + var pb = stack.ints(0); ngetWindowFrameSize(window, pl, pt, pr, pb); return new Quad.OfInt(pl.get(JAVA_INT, 0), pt.get(JAVA_INT, 0), pr.get(JAVA_INT, 0), pb.get(JAVA_INT, 0)); - } finally { - stack.setPointer(stackPointer); } } @@ -2926,13 +2511,8 @@ static Quad.OfInt getWindowFrameSize(MemorySegment window) { * @see #nsetWindowContentScaleCallback(MemorySegment, MemorySegment) setWindowContentScaleCallback * @see #ngetMonitorContentScale(MemorySegment, MemorySegment, MemorySegment) getMonitorContentScale */ - static void ngetWindowContentScale(MemorySegment window, MemorySegment xscale, MemorySegment yscale) { - try { - glfwGetWindowContentScale.invokeExact(window, xscale, yscale); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetWindowContentScale") + void ngetWindowContentScale(MemorySegment window, MemorySegment xscale, MemorySegment yscale); /** * Retrieves the content scale for the specified window. @@ -2942,23 +2522,8 @@ static void ngetWindowContentScale(MemorySegment window, MemorySegment xscale, M * @param yscale Where to store the y-axis content scale, or {@code null}. * @see #ngetWindowContentScale(MemorySegment, MemorySegment, MemorySegment) ngetWindowContentScale */ - static void getWindowContentScale(MemorySegment window, float @Nullable [] xscale, float @Nullable [] yscale) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var px = xscale != null ? stack.callocFloat() : MemorySegment.NULL; - var py = yscale != null ? stack.callocFloat() : MemorySegment.NULL; - ngetWindowContentScale(window, px, py); - if (xscale != null && xscale.length > 0) { - xscale[0] = px.get(JAVA_FLOAT, 0); - } - if (yscale != null && yscale.length > 0) { - yscale[0] = py.get(JAVA_FLOAT, 0); - } - } finally { - stack.setPointer(stackPointer); - } - } + @Entrypoint("glfwGetWindowContentScale") + void getWindowContentScale(MemorySegment window, @Ref float @Nullable [] xscale, @Ref float @Nullable [] yscale); /** * Retrieves the content scale for the specified window. @@ -2967,16 +2532,13 @@ static void getWindowContentScale(MemorySegment window, float @Nullable [] xscal * @return the xy-axis content scale. * @see #ngetWindowContentScale(MemorySegment, MemorySegment, MemorySegment) ngetWindowContentScale */ - static Pair.OfFloat getWindowContentScale(MemorySegment window) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var px = stack.callocFloat(); - var py = stack.callocFloat(); + @Skip + default Pair.OfFloat getWindowContentScale(MemorySegment window) { + try (MemoryStack stack = MemoryStack.stackPush()) { + var px = stack.floats(0F); + var py = stack.floats(0F); ngetWindowContentScale(window, px, py); return new Pair.OfFloat(px.get(JAVA_FLOAT, 0), py.get(JAVA_FLOAT, 0)); - } finally { - stack.setPointer(stackPointer); } } @@ -2998,13 +2560,8 @@ static Pair.OfFloat getWindowContentScale(MemorySegment window) { * @glfw.thread_safety This function must only be called from the main thread. * @see #setWindowOpacity(MemorySegment, float) setWindowOpacity */ - static float getWindowOpacity(MemorySegment window) { - try { - return (float) glfwGetWindowOpacity.invokeExact(window); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetWindowOpacity") + float getWindowOpacity(MemorySegment window); /** * Sets the opacity of the whole window. @@ -3026,13 +2583,8 @@ static float getWindowOpacity(MemorySegment window) { * @glfw.thread_safety This function must only be called from the main thread. * @see #getWindowOpacity(MemorySegment) getWindowOpacity */ - static void setWindowOpacity(MemorySegment window, float opacity) { - try { - glfwSetWindowOpacity.invokeExact(window, opacity); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowOpacity") + void setWindowOpacity(MemorySegment window, float opacity); /** * Iconifies the specified window. @@ -3052,13 +2604,8 @@ static void setWindowOpacity(MemorySegment window, float opacity) { * @see #restoreWindow(MemorySegment) restoreWindow * @see #maximizeWindow(MemorySegment) maximizeWindow */ - static void iconifyWindow(MemorySegment window) { - try { - glfwIconifyWindow.invokeExact(window); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwIconifyWindow") + void iconifyWindow(MemorySegment window); /** * Restores the specified window. @@ -3077,13 +2624,8 @@ static void iconifyWindow(MemorySegment window) { * @see #iconifyWindow(MemorySegment) iconifyWindow * @see #maximizeWindow(MemorySegment) maximizeWindow */ - static void restoreWindow(MemorySegment window) { - try { - glfwRestoreWindow.invokeExact(window); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwRestoreWindow") + void restoreWindow(MemorySegment window); /** * Maximizes the specified window. @@ -3100,13 +2642,8 @@ static void restoreWindow(MemorySegment window) { * @see #iconifyWindow(MemorySegment) iconifyWindow * @see #restoreWindow(MemorySegment) restoreWindow */ - static void maximizeWindow(MemorySegment window) { - try { - glfwMaximizeWindow.invokeExact(window); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwMaximizeWindow") + void maximizeWindow(MemorySegment window); /** * Makes the specified window visible. @@ -3130,13 +2667,8 @@ static void maximizeWindow(MemorySegment window) { * @glfw.thread_safety This function must only be called from the main thread. * @see #hideWindow(MemorySegment) hideWindow */ - static void showWindow(MemorySegment window) { - try { - glfwShowWindow.invokeExact(window); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwShowWindow") + void showWindow(MemorySegment window); /** * Hides the specified window. @@ -3151,13 +2683,8 @@ static void showWindow(MemorySegment window) { * @glfw.thread_safety This function must only be called from the main thread. * @see #showWindow(MemorySegment) showWindow */ - static void hideWindow(MemorySegment window) { - try { - glfwHideWindow.invokeExact(window); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwHideWindow") + void hideWindow(MemorySegment window); /** * Brings the specified window to front and sets input focus. @@ -3187,13 +2714,8 @@ static void hideWindow(MemorySegment window) { * to front, this function will always emit {@link #PLATFORM_ERROR}. * @glfw.thread_safety This function must only be called from the main thread. */ - static void focusWindow(MemorySegment window) { - try { - glfwFocusWindow.invokeExact(window); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwFocusWindow") + void focusWindow(MemorySegment window); /** * Requests user attention to the specified window. @@ -3212,13 +2734,8 @@ static void focusWindow(MemorySegment window) { * specific window. * @glfw.thread_safety This function must only be called from the main thread. */ - static void requestWindowAttention(MemorySegment window) { - try { - glfwRequestWindowAttention.invokeExact(window); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwRequestWindowAttention") + void requestWindowAttention(MemorySegment window); /** * Returns the monitor that the window uses for full screen mode. @@ -3233,13 +2750,8 @@ static void requestWindowAttention(MemorySegment window) { * @glfw.thread_safety This function must only be called from the main thread. * @see #setWindowMonitor(MemorySegment, MemorySegment, int, int, int, int, int) setWindowMonitor */ - static MemorySegment getWindowMonitor(MemorySegment window) { - try { - return (MemorySegment) glfwGetWindowMonitor.invokeExact(window); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetWindowMonitor") + MemorySegment getWindowMonitor(MemorySegment window); /** * Sets the mode, monitor, video mode and placement of a window. @@ -3289,13 +2801,8 @@ static MemorySegment getWindowMonitor(MemorySegment window) { * @see #getWindowMonitor(MemorySegment) getWindowMonitor * @see #setWindowSize(MemorySegment, int, int) setWindowSize */ - static void setWindowMonitor(MemorySegment window, MemorySegment monitor, int xpos, int ypos, int width, int height, int refreshRate) { - try { - glfwSetWindowMonitor.invokeExact(window, monitor, xpos, ypos, width, height, refreshRate); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowMonitor") + void setWindowMonitor(MemorySegment window, MemorySegment monitor, int xpos, int ypos, int width, int height, int refreshRate); /** * Returns an attribute of the specified window. @@ -3324,13 +2831,8 @@ static void setWindowMonitor(MemorySegment window, MemorySegment monitor, int xp * @glfw.thread_safety This function must only be called from the main thread. * @see #setWindowAttrib(MemorySegment, int, boolean) setWindowAttrib */ - static int getWindowAttrib(MemorySegment window, int attrib) { - try { - return (int) glfwGetWindowAttrib.invokeExact(window, attrib); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetWindowAttrib") + int getWindowAttrib(MemorySegment window, int attrib); /** * Sets an attribute of the specified window. @@ -3359,13 +2861,8 @@ static int getWindowAttrib(MemorySegment window, int attrib) { * @glfw.thread_safety This function must only be called from the main thread. * @see #getWindowAttrib(MemorySegment, int) getWindowAttrib */ - static void setWindowAttrib(MemorySegment window, int attrib, boolean value) { - try { - glfwSetWindowAttrib.invokeExact(window, attrib, value ? TRUE : FALSE); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowAttrib") + void setWindowAttrib(MemorySegment window, int attrib, @Convert(Type.INT) boolean value); /** * Sets the user pointer of the specified window. @@ -3381,13 +2878,8 @@ static void setWindowAttrib(MemorySegment window, int attrib, boolean value) { * synchronized. * @see #getWindowUserPointer(MemorySegment) getWindowUserPointer */ - static void setWindowUserPointer(MemorySegment window, MemorySegment pointer) { - try { - glfwSetWindowUserPointer.invokeExact(window, pointer); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowUserPointer") + void setWindowUserPointer(MemorySegment window, MemorySegment pointer); /** * {@return the user pointer of the specified window} @@ -3401,13 +2893,8 @@ static void setWindowUserPointer(MemorySegment window, MemorySegment pointer) { * synchronized. * @see #setWindowUserPointer(MemorySegment, MemorySegment) setWindowUserPointer */ - static MemorySegment getWindowUserPointer(MemorySegment window) { - try { - return (MemorySegment) glfwGetWindowUserPointer.invokeExact(window); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetWindowUserPointer") + MemorySegment getWindowUserPointer(MemorySegment window); /** * Sets the position callback for the specified window. @@ -3430,13 +2917,8 @@ static MemorySegment getWindowUserPointer(MemorySegment window) { * an application to know its global position. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment nsetWindowPosCallback(MemorySegment window, MemorySegment callback) { - try { - return (MemorySegment) glfwSetWindowPosCallback.invokeExact(window, callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowPosCallback") + MemorySegment nsetWindowPosCallback(MemorySegment window, MemorySegment callback); /** * Sets the position callback for the specified window. @@ -3448,7 +2930,8 @@ static MemorySegment nsetWindowPosCallback(MemorySegment window, MemorySegment c * library had not been initialized. * @see #nsetWindowPosCallback(MemorySegment, MemorySegment) nsetWindowPosCallback */ - static MemorySegment setWindowPosCallback(MemorySegment window, @Nullable GLFWWindowPosFun callback) { + @Skip + default MemorySegment setWindowPosCallback(MemorySegment window, @Nullable GLFWWindowPosFun callback) { return nsetWindowPosCallback(window, callback != null ? callback.stub(GLFWCallbacks.create(window)) : MemorySegment.NULL); } @@ -3470,13 +2953,8 @@ static MemorySegment setWindowPosCallback(MemorySegment window, @Nullable GLFWWi * @glfw.errors Possible errors include {@link #NOT_INITIALIZED}. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment nsetWindowSizeCallback(MemorySegment window, MemorySegment callback) { - try { - return (MemorySegment) glfwSetWindowSizeCallback.invokeExact(window, callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowSizeCallback") + MemorySegment nsetWindowSizeCallback(MemorySegment window, MemorySegment callback); /** * Sets the size callback for the specified window. @@ -3488,7 +2966,8 @@ static MemorySegment nsetWindowSizeCallback(MemorySegment window, MemorySegment * library had not been initialized. * @see #nsetWindowSizeCallback(MemorySegment, MemorySegment) nsetWindowSizeCallback */ - static MemorySegment setWindowSizeCallback(MemorySegment window, @Nullable GLFWWindowSizeFun callback) { + @Skip + default MemorySegment setWindowSizeCallback(MemorySegment window, @Nullable GLFWWindowSizeFun callback) { return nsetWindowSizeCallback(window, callback != null ? callback.stub(GLFWCallbacks.create(window)) : MemorySegment.NULL); } @@ -3517,13 +2996,8 @@ static MemorySegment setWindowSizeCallback(MemorySegment window, @Nullable GLFWW * close callback for all windows. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment nsetWindowCloseCallback(MemorySegment window, MemorySegment callback) { - try { - return (MemorySegment) glfwSetWindowCloseCallback.invokeExact(window, callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowCloseCallback") + MemorySegment nsetWindowCloseCallback(MemorySegment window, MemorySegment callback); /** * Sets the close callback for the specified window. @@ -3535,7 +3009,8 @@ static MemorySegment nsetWindowCloseCallback(MemorySegment window, MemorySegment * library had not been initialized. * @see #nsetWindowCloseCallback(MemorySegment, MemorySegment) nsetWindowCloseCallback */ - static MemorySegment setWindowCloseCallback(MemorySegment window, @Nullable GLFWWindowCloseFun callback) { + @Skip + default MemorySegment setWindowCloseCallback(MemorySegment window, @Nullable GLFWWindowCloseFun callback) { return nsetWindowCloseCallback(window, callback != null ? callback.stub(GLFWCallbacks.create(window)) : MemorySegment.NULL); } @@ -3561,13 +3036,8 @@ static MemorySegment setWindowCloseCallback(MemorySegment window, @Nullable GLFW * @glfw.errors Possible errors include {@link #NOT_INITIALIZED}. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment nsetWindowRefreshCallback(MemorySegment window, MemorySegment callback) { - try { - return (MemorySegment) glfwSetWindowRefreshCallback.invokeExact(window, callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowRefreshCallback") + MemorySegment nsetWindowRefreshCallback(MemorySegment window, MemorySegment callback); /** * Sets the refresh callback for the specified window. @@ -3579,7 +3049,8 @@ static MemorySegment nsetWindowRefreshCallback(MemorySegment window, MemorySegme * library had not been initialized. * @see #nsetWindowRefreshCallback(MemorySegment, MemorySegment) nsetWindowRefreshCallback */ - static MemorySegment setWindowRefreshCallback(MemorySegment window, @Nullable GLFWWindowRefreshFun callback) { + @Skip + default MemorySegment setWindowRefreshCallback(MemorySegment window, @Nullable GLFWWindowRefreshFun callback) { return nsetWindowRefreshCallback(window, callback != null ? callback.stub(GLFWCallbacks.create(window)) : MemorySegment.NULL); } @@ -3606,13 +3077,8 @@ static MemorySegment setWindowRefreshCallback(MemorySegment window, @Nullable GL * @glfw.errors Possible errors include {@link #NOT_INITIALIZED}. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment nsetWindowFocusCallback(MemorySegment window, MemorySegment callback) { - try { - return (MemorySegment) glfwSetWindowFocusCallback.invokeExact(window, callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowFocusCallback") + MemorySegment nsetWindowFocusCallback(MemorySegment window, MemorySegment callback); /** * Sets the focus callback for the specified window. @@ -3624,7 +3090,8 @@ static MemorySegment nsetWindowFocusCallback(MemorySegment window, MemorySegment * library had not been initialized. * @see #nsetWindowFocusCallback(MemorySegment, MemorySegment) nsetWindowFocusCallback */ - static MemorySegment setWindowFocusCallback(MemorySegment window, @Nullable GLFWWindowFocusFun callback) { + @Skip + default MemorySegment setWindowFocusCallback(MemorySegment window, @Nullable GLFWWindowFocusFun callback) { return nsetWindowFocusCallback(window, callback != null ? callback.stub(GLFWCallbacks.create(window)) : MemorySegment.NULL); } @@ -3647,13 +3114,8 @@ static MemorySegment setWindowFocusCallback(MemorySegment window, @Nullable GLFW * this callback will never be called. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment nsetWindowIconifyCallback(MemorySegment window, MemorySegment callback) { - try { - return (MemorySegment) glfwSetWindowIconifyCallback.invokeExact(window, callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowIconifyCallback") + MemorySegment nsetWindowIconifyCallback(MemorySegment window, MemorySegment callback); /** * Sets the iconify callback for the specified window. @@ -3665,7 +3127,8 @@ static MemorySegment nsetWindowIconifyCallback(MemorySegment window, MemorySegme * library had not been initialized. * @see #nsetWindowIconifyCallback(MemorySegment, MemorySegment) nsetWindowIconifyCallback */ - static MemorySegment setWindowIconifyCallback(MemorySegment window, @Nullable GLFWWindowIconifyFun callback) { + @Skip + default MemorySegment setWindowIconifyCallback(MemorySegment window, @Nullable GLFWWindowIconifyFun callback) { return nsetWindowIconifyCallback(window, callback != null ? callback.stub(GLFWCallbacks.create(window)) : MemorySegment.NULL); } @@ -3686,13 +3149,8 @@ static MemorySegment setWindowIconifyCallback(MemorySegment window, @Nullable GL * @glfw.errors Possible errors include {@link #NOT_INITIALIZED}. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment nsetWindowMaximizeCallback(MemorySegment window, MemorySegment callback) { - try { - return (MemorySegment) glfwSetWindowMaximizeCallback.invokeExact(window, callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowMaximizeCallback") + MemorySegment nsetWindowMaximizeCallback(MemorySegment window, MemorySegment callback); /** * Sets the maximize callback for the specified window. @@ -3704,7 +3162,8 @@ static MemorySegment nsetWindowMaximizeCallback(MemorySegment window, MemorySegm * library had not been initialized. * @see #nsetWindowMaximizeCallback(MemorySegment, MemorySegment) nsetWindowMaximizeCallback */ - static MemorySegment setWindowMaximizeCallback(MemorySegment window, @Nullable GLFWWindowMaximizeFun callback) { + @Skip + default MemorySegment setWindowMaximizeCallback(MemorySegment window, @Nullable GLFWWindowMaximizeFun callback) { return nsetWindowMaximizeCallback(window, callback != null ? callback.stub(GLFWCallbacks.create(window)) : MemorySegment.NULL); } @@ -3725,13 +3184,8 @@ static MemorySegment setWindowMaximizeCallback(MemorySegment window, @Nullable G * @glfw.errors Possible errors include {@link #NOT_INITIALIZED}. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment nsetFramebufferSizeCallback(MemorySegment window, MemorySegment callback) { - try { - return (MemorySegment) glfwSetFramebufferSizeCallback.invokeExact(window, callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetFramebufferSizeCallback") + MemorySegment nsetFramebufferSizeCallback(MemorySegment window, MemorySegment callback); /** * Sets the framebuffer resize callback for the specified window. @@ -3743,7 +3197,8 @@ static MemorySegment nsetFramebufferSizeCallback(MemorySegment window, MemorySeg * library had not been initialized. * @see #nsetFramebufferSizeCallback(MemorySegment, MemorySegment) nsetFramebufferSizeCallback */ - static MemorySegment setFramebufferSizeCallback(MemorySegment window, @Nullable GLFWFramebufferSizeFun callback) { + @Skip + default MemorySegment setFramebufferSizeCallback(MemorySegment window, @Nullable GLFWFramebufferSizeFun callback) { return nsetFramebufferSizeCallback(window, callback != null ? callback.stub(GLFWCallbacks.create(window)) : MemorySegment.NULL); } @@ -3765,13 +3220,8 @@ static MemorySegment setFramebufferSizeCallback(MemorySegment window, @Nullable * @glfw.thread_safety This function must only be called from the main thread. * @see #ngetWindowContentScale(MemorySegment, MemorySegment, MemorySegment) getWindowContentScale */ - static MemorySegment nsetWindowContentScaleCallback(MemorySegment window, MemorySegment callback) { - try { - return (MemorySegment) glfwSetWindowContentScaleCallback.invokeExact(window, callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetWindowContentScaleCallback") + MemorySegment nsetWindowContentScaleCallback(MemorySegment window, MemorySegment callback); /** * Sets the window content scale callback for the specified window. @@ -3783,7 +3233,8 @@ static MemorySegment nsetWindowContentScaleCallback(MemorySegment window, Memory * library had not been initialized. * @see #nsetWindowContentScaleCallback(MemorySegment, MemorySegment) nsetWindowContentScaleCallback */ - static MemorySegment setWindowContentScaleCallback(MemorySegment window, @Nullable GLFWWindowContentScaleFun callback) { + @Skip + default MemorySegment setWindowContentScaleCallback(MemorySegment window, @Nullable GLFWWindowContentScaleFun callback) { return nsetWindowContentScaleCallback(window, callback != null ? callback.stub(GLFWCallbacks.create(window)) : MemorySegment.NULL); } @@ -3817,13 +3268,8 @@ static MemorySegment setWindowContentScaleCallback(MemorySegment window, @Nullab * @see #waitEvents() waitEvents * @see #waitEventsTimeout(double) waitEventsTimeout */ - static void pollEvents() { - try { - glfwPollEvents.invokeExact(); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwPollEvents") + void pollEvents(); /** * Waits until events are queued and processes them. @@ -3861,13 +3307,8 @@ static void pollEvents() { * @see #pollEvents() pollEvents * @see #waitEventsTimeout(double) waitEventsTimeout */ - static void waitEvents() { - try { - glfwWaitEvents.invokeExact(); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwWaitEvents") + void waitEvents(); /** * Waits with timeout until events are queued and processes them. @@ -3908,13 +3349,8 @@ static void waitEvents() { * @see #pollEvents() pollEvents * @see #waitEvents() waitEvents */ - static void waitEventsTimeout(double timeout) { - try { - glfwWaitEventsTimeout.invokeExact(timeout); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwWaitEventsTimeout") + void waitEventsTimeout(double timeout); /** * Posts an empty event to the event queue. @@ -3928,13 +3364,8 @@ static void waitEventsTimeout(double timeout) { * @see #waitEvents() waitEvents * @see #waitEventsTimeout(double) waitEventsTimeout */ - static void postEmptyEvents() { - try { - glfwPostEmptyEvent.invokeExact(); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwPostEmptyEvent") + void postEmptyEvents(); /** * {@return the value of an input option for the specified window} @@ -3953,13 +3384,8 @@ static void postEmptyEvents() { * @glfw.thread_safety This function must only be called from the main thread. * @see #setInputMode(MemorySegment, int, int) setInputMode */ - static int getInputMode(MemorySegment window, int mode) { - try { - return (int) glfwGetInputMode.invokeExact(window, mode); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetInputMode") + int getInputMode(MemorySegment window, int mode); /** * Sets an input option for the specified window. @@ -4017,13 +3443,8 @@ static int getInputMode(MemorySegment window, int mode) { * @glfw.thread_safety This function must only be called from the main thread. * @see #getInputMode(MemorySegment, int) getInputMode */ - static void setInputMode(MemorySegment window, int mode, int value) { - try { - glfwSetInputMode.invokeExact(window, mode, value); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetInputMode") + void setInputMode(MemorySegment window, int mode, int value); /** * Returns whether raw mouse motion is supported. @@ -4045,13 +3466,9 @@ static void setInputMode(MemorySegment window, int mode, int value) { * @glfw.thread_safety This function must only be called from the main thread. * @see #setInputMode(MemorySegment, int, int) setInputMode */ - static boolean rawMouseMotionSupported() { - try { - return (int) glfwRawMouseMotionSupported.invokeExact() != FALSE; - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Convert(Type.INT) + @Entrypoint("glfwRawMouseMotionSupported") + boolean rawMouseMotionSupported(); /** * Returns the layout-specific name of the specified printable key. @@ -4114,13 +3531,8 @@ static boolean rawMouseMotionSupported() { * should not free it yourself. It is valid until the library is terminated. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment ngetKeyName(int key, int scancode) { - try { - return (MemorySegment) glfwGetKeyName.invokeExact(key, scancode); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetKeyName") + MemorySegment ngetKeyName(int key, int scancode); /** * Returns the layout-specific name of the specified printable key. @@ -4130,11 +3542,9 @@ static MemorySegment ngetKeyName(int key, int scancode) { * @return The UTF-8 encoded, layout-specific name of the key, or {@code null}. * @see #ngetKeyName(int, int) ngetKeyName */ + @Entrypoint("glfwGetKeyName") @Nullable - static String getKeyName(int key, int scancode) { - var pName = ngetKeyName(key, scancode); - return RuntimeHelper.isNullptr(pName) ? null : pName.getString(0); - } + String getKeyName(int key, int scancode); /** * Returns the platform-specific scancode of the specified key. @@ -4153,13 +3563,8 @@ static String getKeyName(int key, int scancode) { * @glfw.errors Possible errors include {@link #NOT_INITIALIZED} and {@link #INVALID_ENUM}. * @glfw.thread_safety This function may be called from any thread. */ - static int getKeyScancode(int key) { - try { - return (int) glfwGetKeyScancode.invokeExact(key); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetKeyScancode") + int getKeyScancode(int key); /** * Returns the last reported state of a keyboard key for the specified @@ -4192,13 +3597,8 @@ static int getKeyScancode(int key) { * {@link #INVALID_ENUM}. * @glfw.thread_safety This function must only be called from the main thread. */ - static int getKey(MemorySegment window, int key) { - try { - return (int) glfwGetKey.invokeExact(window, key); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetKey") + int getKey(MemorySegment window, int key); /** * Returns the last reported state of a mouse button for the specified @@ -4219,13 +3619,8 @@ static int getKey(MemorySegment window, int key) { * {@link #INVALID_ENUM}. * @glfw.thread_safety This function must only be called from the main thread. */ - static int getMouseButton(MemorySegment window, int button) { - try { - return (int) glfwGetMouseButton.invokeExact(window, button); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetMouseButton") + int getMouseButton(MemorySegment window, int button); /** * Retrieves the position of the cursor relative to the content area of @@ -4256,13 +3651,8 @@ static int getMouseButton(MemorySegment window, int button) { * @glfw.thread_safety This function must only be called from the main thread. * @see #setCursorPos(MemorySegment, double, double) setCursorPos */ - static void ngetCursorPos(MemorySegment window, MemorySegment xpos, MemorySegment ypos) { - try { - glfwGetCursorPos.invokeExact(window, xpos, ypos); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetCursorPos") + void ngetCursorPos(MemorySegment window, MemorySegment xpos, MemorySegment ypos); /** * Retrieves the position of the cursor relative to the content area of @@ -4275,23 +3665,8 @@ static void ngetCursorPos(MemorySegment window, MemorySegment xpos, MemorySegmen * top edge of the content area, or {@code null}. * @see #ngetCursorPos(MemorySegment, MemorySegment, MemorySegment) ngetCursorPos */ - static void getCursorPos(MemorySegment window, double @Nullable [] xpos, double @Nullable [] ypos) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var px = xpos != null ? stack.callocDouble() : MemorySegment.NULL; - var py = ypos != null ? stack.callocDouble() : MemorySegment.NULL; - ngetCursorPos(window, px, py); - if (xpos != null && xpos.length > 0) { - xpos[0] = px.get(JAVA_DOUBLE, 0); - } - if (ypos != null && ypos.length > 0) { - ypos[0] = py.get(JAVA_DOUBLE, 0); - } - } finally { - stack.setPointer(stackPointer); - } - } + @Entrypoint("glfwGetCursorPos") + void getCursorPos(MemorySegment window, @Ref double @Nullable [] xpos, @Ref double @Nullable [] ypos); /** * Retrieves the position of the cursor relative to the content area of @@ -4301,16 +3676,13 @@ static void getCursorPos(MemorySegment window, double @Nullable [] xpos, double * @return the cursor xy-coordinate, relative to the left and top edge of the content area. * @see #ngetCursorPos(MemorySegment, MemorySegment, MemorySegment) ngetCursorPos */ - static Pair.OfDouble getCursorPos(MemorySegment window) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var px = stack.callocDouble(); - var py = stack.callocDouble(); + @Skip + default Pair.OfDouble getCursorPos(MemorySegment window) { + try (MemoryStack stack = MemoryStack.stackPush()) { + var px = stack.doubles(0D); + var py = stack.doubles(0D); ngetCursorPos(window, px, py); return new Pair.OfDouble(px.get(JAVA_DOUBLE, 0), py.get(JAVA_DOUBLE, 0)); - } finally { - stack.setPointer(stackPointer); } } @@ -4344,13 +3716,8 @@ static Pair.OfDouble getCursorPos(MemorySegment window) { * @glfw.thread_safety This function must only be called from the main thread. * @see #ngetCursorPos(MemorySegment, MemorySegment, MemorySegment) getCursorPos */ - static void setCursorPos(MemorySegment window, double xpos, double ypos) { - try { - glfwSetCursorPos.invokeExact(window, xpos, ypos); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetCursorPos") + void setCursorPos(MemorySegment window, double xpos, double ypos); /** * Creates a custom cursor. @@ -4380,13 +3747,8 @@ static void setCursorPos(MemorySegment window, double xpos, double ypos) { * @see #destroyCursor(MemorySegment) destroyCursor * @see #createStandardCursor(int) createStandardCursor */ - static MemorySegment ncreateCursor(MemorySegment image, int xhot, int yhot) { - try { - return (MemorySegment) glfwCreateCursor.invokeExact(image, xhot, yhot); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwCreateCursor") + MemorySegment ncreateCursor(MemorySegment image, int xhot, int yhot); /** * Creates a custom cursor. @@ -4398,9 +3760,8 @@ static MemorySegment ncreateCursor(MemorySegment image, int xhot, int yhot) { * error occurred. * @see #ncreateCursor(MemorySegment, int, int) ncreateCursor */ - static MemorySegment createCursor(GLFWImage image, int xhot, int yhot) { - return ncreateCursor(image.segment(), xhot, yhot); - } + @Entrypoint("glfwCreateCursor") + MemorySegment createCursor(GLFWImage image, int xhot, int yhot); /** * Creates a cursor with a standard shape. @@ -4417,13 +3778,8 @@ static MemorySegment createCursor(GLFWImage image, int xhot, int yhot) { * @glfw.thread_safety This function must only be called from the main thread. * @see #ncreateCursor(MemorySegment, int, int) createCursor */ - static MemorySegment createStandardCursor(int shape) { - try { - return (MemorySegment) glfwCreateStandardCursor.invokeExact(shape); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwCreateStandardCursor") + MemorySegment createStandardCursor(int shape); /** * Destroys a cursor. @@ -4442,13 +3798,8 @@ static MemorySegment createStandardCursor(int shape) { * @glfw.thread_safety This function must only be called from the main thread. * @see #ncreateCursor(MemorySegment, int, int) createCursor */ - static void destroyCursor(MemorySegment cursor) { - try { - glfwDestroyCursor.invokeExact(cursor); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwDestroyCursor") + void destroyCursor(MemorySegment cursor); /** * Sets the cursor for the window. @@ -4468,13 +3819,8 @@ static void destroyCursor(MemorySegment cursor) { * {@link #PLATFORM_ERROR}. * @glfw.thread_safety This function must only be called from the main thread. */ - static void setCursor(MemorySegment window, MemorySegment cursor) { - try { - glfwSetCursor.invokeExact(window, cursor); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetCursor") + void setCursor(MemorySegment window, MemorySegment cursor); /** * Sets the key callback. @@ -4513,13 +3859,8 @@ static void setCursor(MemorySegment window, MemorySegment cursor) { * @glfw.errors Possible errors include {@link #NOT_INITIALIZED}. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment nsetKeyCallback(MemorySegment window, MemorySegment callback) { - try { - return (MemorySegment) glfwSetKeyCallback.invokeExact(window, callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetKeyCallback") + MemorySegment nsetKeyCallback(MemorySegment window, MemorySegment callback); /** * Sets the key callback. @@ -4531,7 +3872,8 @@ static MemorySegment nsetKeyCallback(MemorySegment window, MemorySegment callbac * library had not been initialized. * @see #nsetKeyCallback(MemorySegment, MemorySegment) nsetKeyCallback */ - static MemorySegment setKeyCallback(MemorySegment window, @Nullable GLFWKeyFun callback) { + @Skip + default MemorySegment setKeyCallback(MemorySegment window, @Nullable GLFWKeyFun callback) { return nsetKeyCallback(window, callback != null ? callback.stub(GLFWCallbacks.create(window)) : MemorySegment.NULL); } @@ -4564,13 +3906,8 @@ static MemorySegment setKeyCallback(MemorySegment window, @Nullable GLFWKeyFun c * @glfw.errors Possible errors include {@link #NOT_INITIALIZED}. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment nsetCharCallback(MemorySegment window, MemorySegment callback) { - try { - return (MemorySegment) glfwSetCharCallback.invokeExact(window, callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetCharCallback") + MemorySegment nsetCharCallback(MemorySegment window, MemorySegment callback); /** * Sets the Unicode character callback. @@ -4582,7 +3919,8 @@ static MemorySegment nsetCharCallback(MemorySegment window, MemorySegment callba * library had not been initialized. * @see #nsetCharCallback(MemorySegment, MemorySegment) nsetCharCallback */ - static MemorySegment setCharCallback(MemorySegment window, @Nullable GLFWCharFun callback) { + @Skip + default MemorySegment setCharCallback(MemorySegment window, @Nullable GLFWCharFun callback) { return nsetCharCallback(window, callback != null ? callback.stub(GLFWCallbacks.create(window)) : MemorySegment.NULL); } @@ -4609,13 +3947,8 @@ static MemorySegment setCharCallback(MemorySegment window, @Nullable GLFWCharFun * @glfw.errors Possible errors include {@link #NOT_INITIALIZED}. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment nsetMouseButtonCallback(MemorySegment window, MemorySegment callback) { - try { - return (MemorySegment) glfwSetMouseButtonCallback.invokeExact(window, callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetMouseButtonCallback") + MemorySegment nsetMouseButtonCallback(MemorySegment window, MemorySegment callback); /** * Sets the mouse button callback. @@ -4627,7 +3960,8 @@ static MemorySegment nsetMouseButtonCallback(MemorySegment window, MemorySegment * library had not been initialized. * @see #nsetMouseButtonCallback(MemorySegment, MemorySegment) nsetMouseButtonCallback */ - static MemorySegment setMouseButtonCallback(MemorySegment window, @Nullable GLFWMouseButtonFun callback) { + @Skip + default MemorySegment setMouseButtonCallback(MemorySegment window, @Nullable GLFWMouseButtonFun callback) { return nsetMouseButtonCallback(window, callback != null ? callback.stub(GLFWCallbacks.create(window)) : MemorySegment.NULL); } @@ -4650,13 +3984,8 @@ static MemorySegment setMouseButtonCallback(MemorySegment window, @Nullable GLFW * @glfw.errors Possible errors include {@link #NOT_INITIALIZED}. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment nsetCursorPosCallback(MemorySegment window, MemorySegment callback) { - try { - return (MemorySegment) glfwSetCursorPosCallback.invokeExact(window, callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetCursorPosCallback") + MemorySegment nsetCursorPosCallback(MemorySegment window, MemorySegment callback); /** * Sets the cursor position callback. @@ -4668,7 +3997,8 @@ static MemorySegment nsetCursorPosCallback(MemorySegment window, MemorySegment c * library had not been initialized. * @see #nsetCursorPosCallback(MemorySegment, MemorySegment) nsetCursorPosCallback */ - static MemorySegment setCursorPosCallback(MemorySegment window, @Nullable GLFWCursorPosFun callback) { + @Skip + default MemorySegment setCursorPosCallback(MemorySegment window, @Nullable GLFWCursorPosFun callback) { return nsetCursorPosCallback(window, callback != null ? callback.stub(GLFWCallbacks.create(window)) : MemorySegment.NULL); } @@ -4690,13 +4020,8 @@ static MemorySegment setCursorPosCallback(MemorySegment window, @Nullable GLFWCu * @glfw.errors Possible errors include {@link #NOT_INITIALIZED}. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment nsetCursorEnterCallback(MemorySegment window, MemorySegment callback) { - try { - return (MemorySegment) glfwSetCursorEnterCallback.invokeExact(window, callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetCursorEnterCallback") + MemorySegment nsetCursorEnterCallback(MemorySegment window, MemorySegment callback); /** * Sets the cursor enter/leave callback. @@ -4708,7 +4033,8 @@ static MemorySegment nsetCursorEnterCallback(MemorySegment window, MemorySegment * library had not been initialized. * @see #nsetCursorEnterCallback(MemorySegment, MemorySegment) nsetCursorEnterCallback */ - static MemorySegment setCursorEnterCallback(MemorySegment window, @Nullable GLFWCursorEnterFun callback) { + @Skip + default MemorySegment setCursorEnterCallback(MemorySegment window, @Nullable GLFWCursorEnterFun callback) { return nsetCursorEnterCallback(window, callback != null ? callback.stub(GLFWCallbacks.create(window)) : MemorySegment.NULL); } @@ -4733,13 +4059,8 @@ static MemorySegment setCursorEnterCallback(MemorySegment window, @Nullable GLFW * @glfw.errors Possible errors include {@link #NOT_INITIALIZED}. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment nsetScrollCallback(MemorySegment window, MemorySegment callback) { - try { - return (MemorySegment) glfwSetScrollCallback.invokeExact(window, callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetScrollCallback") + MemorySegment nsetScrollCallback(MemorySegment window, MemorySegment callback); /** * Sets the scroll callback. @@ -4751,7 +4072,8 @@ static MemorySegment nsetScrollCallback(MemorySegment window, MemorySegment call * library had not been initialized. * @see #nsetScrollCallback(MemorySegment, MemorySegment) nsetScrollCallback */ - static MemorySegment setScrollCallback(MemorySegment window, @Nullable GLFWScrollFun callback) { + @Skip + default MemorySegment setScrollCallback(MemorySegment window, @Nullable GLFWScrollFun callback) { return nsetScrollCallback(window, callback != null ? callback.stub(GLFWCallbacks.create(window)) : MemorySegment.NULL); } @@ -4778,13 +4100,8 @@ static MemorySegment setScrollCallback(MemorySegment window, @Nullable GLFWScrol * @glfw.remark Wayland: File drop is currently unimplemented. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment nsetDropCallback(MemorySegment window, MemorySegment callback) { - try { - return (MemorySegment) glfwSetDropCallback.invokeExact(window, callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetDropCallback") + MemorySegment nsetDropCallback(MemorySegment window, MemorySegment callback); /** * Sets the path drop callback. @@ -4796,7 +4113,8 @@ static MemorySegment nsetDropCallback(MemorySegment window, MemorySegment callba * library had not been initialized. * @see #nsetDropCallback(MemorySegment, MemorySegment) nsetDropCallback */ - static MemorySegment setDropCallback(MemorySegment window, @Nullable GLFWDropFun callback) { + @Skip + default MemorySegment setDropCallback(MemorySegment window, @Nullable GLFWDropFun callback) { return nsetDropCallback(window, callback != null ? callback.stub(GLFWCallbacks.create(window)) : MemorySegment.NULL); } @@ -4815,13 +4133,9 @@ static MemorySegment setDropCallback(MemorySegment window, @Nullable GLFWDropFun * {@link #INVALID_ENUM} and {@link #PLATFORM_ERROR}. * @glfw.thread_safety This function must only be called from the main thread. */ - static boolean joystickPresent(int jid) { - try { - return (int) glfwJoystickPresent.invokeExact(jid) != FALSE; - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Convert(Type.INT) + @Entrypoint("glfwJoystickPresent") + boolean joystickPresent(int jid); /** * Returns the values of all axes of the specified joystick. @@ -4847,13 +4161,8 @@ static boolean joystickPresent(int jid) { * disconnected or the library is terminated. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment ngetJoystickAxes(int jid, MemorySegment count) { - try { - return (MemorySegment) glfwGetJoystickAxes.invokeExact(jid, count); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetJoystickAxes") + MemorySegment ngetJoystickAxes(int jid, MemorySegment count); /** * Returns the values of all axes of the specified joystick. @@ -4864,20 +4173,15 @@ static MemorySegment ngetJoystickAxes(int jid, MemorySegment count) { * occurred. * @see #ngetJoystickAxes(int, MemorySegment) ngetJoystickAxes */ - static float @Nullable [] getJoystickAxes(int jid) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - MemorySegment pAxes; - final int count; - try { - var pCount = stack.callocInt(); - pAxes = ngetJoystickAxes(jid, pCount); - count = pCount.get(JAVA_INT, 0); - } finally { - stack.setPointer(stackPointer); + @Skip + default float @Nullable [] getJoystickAxes(int jid) { + try (MemoryStack stack = MemoryStack.stackPush()) { + var pCount = stack.ints(0); + MemorySegment pAxes = ngetJoystickAxes(jid, pCount); + final int count = pCount.get(JAVA_INT, 0); + if (count == 0) return null; + return Unmarshal.unmarshalAsFloatArray(pAxes.reinterpret(JAVA_FLOAT.scale(0L, count))); } - if (count == 0) return null; - return RuntimeHelper.toArray(pAxes, new float[count]); } /** @@ -4910,13 +4214,8 @@ static MemorySegment ngetJoystickAxes(int jid, MemorySegment count) { * disconnected or the library is terminated. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment ngetJoystickButtons(int jid, MemorySegment count) { - try { - return (MemorySegment) glfwGetJoystickButtons.invokeExact(jid, count); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetJoystickButtons") + MemorySegment ngetJoystickButtons(int jid, MemorySegment count); /** * Returns the state of all buttons of the specified joystick. @@ -4926,24 +4225,15 @@ static MemorySegment ngetJoystickButtons(int jid, MemorySegment count) { * or an error occurred. * @see #ngetJoystickButtons(int, MemorySegment) ngetJoystickButtons */ - static boolean @Nullable [] getJoystickButtons(int jid) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - MemorySegment pButtons; - final int count; - try { - var pCount = stack.callocInt(); - pButtons = ngetJoystickButtons(jid, pCount); - count = pCount.get(JAVA_INT, 0); - } finally { - stack.setPointer(stackPointer); - } - if (count == 0) return null; - boolean[] buttons = new boolean[count]; - for (int i = 0; i < count; i++) { - buttons[i] = pButtons.getAtIndex(JAVA_INT, i) == PRESS; + @Skip + default int @Nullable [] getJoystickButtons(int jid) { + try (MemoryStack stack = MemoryStack.stackPush()) { + var pCount = stack.ints(0); + MemorySegment pButtons = ngetJoystickButtons(jid, pCount); + final int count = pCount.get(JAVA_INT, 0); + if (count == 0) return null; + return Unmarshal.unmarshalAsIntArray(pButtons.reinterpret(JAVA_INT.scale(0L, count))); } - return buttons; } /** @@ -4969,7 +4259,6 @@ static MemorySegment ngetJoystickButtons(int jid, MemorySegment count) { * The diagonal directions are bitwise combinations of the primary (up, right, * down and left) directions, and you can test for these individually by ANDing * it with the corresponding direction. - * * {@snippet lang = java: * if (hats[2] & HAT_RIGHT) { * // State of hat 2 could be right-up, right or right-down @@ -4993,13 +4282,8 @@ static MemorySegment ngetJoystickButtons(int jid, MemorySegment count) { * is terminated. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment ngetJoystickHats(int jid, MemorySegment count) { - try { - return (MemorySegment) glfwGetJoystickHats.invokeExact(jid, count); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetJoystickHats") + MemorySegment ngetJoystickHats(int jid, MemorySegment count); /** * Returns the state of all hats of the specified joystick. @@ -5009,15 +4293,12 @@ static MemorySegment ngetJoystickHats(int jid, MemorySegment count) { * or an error occurred. * @see #ngetJoystickHats(int, MemorySegment) ngetJoystickHats */ - static byte[] getJoystickHats(int jid) { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - try { - var pCount = stack.callocInt(); + @Skip + default byte[] getJoystickHats(int jid) { + try (MemoryStack stack = MemoryStack.stackPush()) { + var pCount = stack.ints(0); var pHats = ngetJoystickHats(jid, pCount); - return RuntimeHelper.toArray(pHats, new byte[pCount.get(JAVA_INT, 0)]); - } finally { - stack.setPointer(stackPointer); + return Unmarshal.unmarshalAsByteArray(pHats.reinterpret(JAVA_BYTE.scale(0L, pCount.get(JAVA_INT, 0)))); } } @@ -5042,13 +4323,8 @@ static byte[] getJoystickHats(int jid) { * disconnected or the library is terminated. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment ngetJoystickName(int jid) { - try { - return (MemorySegment) glfwGetJoystickName.invokeExact(jid); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetJoystickName") + MemorySegment ngetJoystickName(int jid); /** * Returns the name of the specified joystick. @@ -5058,11 +4334,9 @@ static MemorySegment ngetJoystickName(int jid) { * is not present or an error occurred. * @see #ngetJoystickName(int) ngetJoystickName */ + @Entrypoint("glfwGetJoystickName") @Nullable - static String getJoystickName(int jid) { - var pName = ngetJoystickName(jid); - return RuntimeHelper.isNullptr(pName) ? null : pName.getString(0); - } + String getJoystickName(int jid); /** * Returns the SDL compatible GUID of the specified joystick. @@ -5095,13 +4369,8 @@ static String getJoystickName(int jid) { * disconnected or the library is terminated. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment ngetJoystickGUID(int jid) { - try { - return (MemorySegment) glfwGetJoystickGUID.invokeExact(jid); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetJoystickGUID") + MemorySegment ngetJoystickGUID(int jid); /** * Returns the SDL compatible GUID of the specified joystick. @@ -5111,11 +4380,9 @@ static MemorySegment ngetJoystickGUID(int jid) { * is not present or an error occurred. * @see #ngetJoystickGUID(int) ngetJoystickGUID */ + @Entrypoint("glfwGetJoystickGUID") @Nullable - static String getJoystickGUID(int jid) { - var pGUID = ngetJoystickGUID(jid); - return RuntimeHelper.isNullptr(pGUID) ? null : pGUID.getString(0); - } + String getJoystickGUID(int jid); /** * Sets the user pointer of the specified joystick. @@ -5134,13 +4401,8 @@ static String getJoystickGUID(int jid) { * synchronized. * @see #getJoystickUserPointer(int) getJoystickUserPointer */ - static void setJoystickUserPointer(int jid, MemorySegment pointer) { - try { - glfwSetJoystickUserPointer.invokeExact(jid, pointer); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetJoystickUserPointer") + void setJoystickUserPointer(int jid, MemorySegment pointer); /** * {@return the user pointer of the specified joystick} @@ -5157,13 +4419,8 @@ static void setJoystickUserPointer(int jid, MemorySegment pointer) { * synchronized. * @see #setJoystickUserPointer(int, MemorySegment) setJoystickUserPointer */ - static MemorySegment getJoystickUserPointer(int jid) { - try { - return (MemorySegment) glfwGetJoystickUserPointer.invokeExact(jid); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetJoystickUserPointer") + MemorySegment getJoystickUserPointer(int jid); /** * Returns whether the specified joystick has a gamepad mapping. @@ -5184,13 +4441,9 @@ static MemorySegment getJoystickUserPointer(int jid) { * @glfw.thread_safety This function must only be called from the main thread. * @see #ngetGamepadState(int, MemorySegment) getGamepadState */ - static boolean joystickIsGamepad(int jid) { - try { - return (int) glfwJoystickIsGamepad.invokeExact(jid) != FALSE; - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Convert(Type.INT) + @Entrypoint("glfwJoystickIsGamepad") + boolean joystickIsGamepad(int jid); /** * Sets the joystick configuration callback. @@ -5216,13 +4469,8 @@ static boolean joystickIsGamepad(int jid) { * @glfw.errors Possible errors include {@link #NOT_INITIALIZED}. * @glfw.thread_safety This function must only be called from the main thread. */ - static MemorySegment nsetJoystickCallback(MemorySegment callback) { - try { - return (MemorySegment) glfwSetJoystickCallback.invokeExact(callback); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetJoystickCallback") + MemorySegment nsetJoystickCallback(MemorySegment callback); /** * Sets the joystick configuration callback. @@ -5233,7 +4481,8 @@ static MemorySegment nsetJoystickCallback(MemorySegment callback) { * library had not been initialized. * @see #nsetJoystickCallback(MemorySegment) nsetJoystickCallback */ - static MemorySegment setJoystickCallback(@Nullable GLFWJoystickFun callback) { + @Skip + default MemorySegment setJoystickCallback(@Nullable GLFWJoystickFun callback) { return nsetJoystickCallback(callback != null ? callback.stub(Arena.ofAuto()) : MemorySegment.NULL); } @@ -5263,13 +4512,9 @@ static MemorySegment setJoystickCallback(@Nullable GLFWJoystickFun callback) { * @see #joystickIsGamepad(int) joystickIsGamepad * @see #ngetGamepadName(int) getGamepadName */ - static boolean nupdateGamepadMappings(MemorySegment string) { - try { - return (int) glfwUpdateGamepadMappings.invokeExact(string) != FALSE; - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Convert(Type.INT) + @Entrypoint("glfwUpdateGamepadMappings") + boolean nupdateGamepadMappings(MemorySegment string); /** * Adds the specified SDL_GameControllerDB gamepad mappings. @@ -5279,15 +4524,9 @@ static boolean nupdateGamepadMappings(MemorySegment string) { * error occurred. * @see #nupdateGamepadMappings(MemorySegment) nupdateGamepadMappings */ - static boolean updateGamepadMappings(String string) { - final MemoryStack stack = MemoryStack.stackGet(); - final long stackPointer = stack.getPointer(); - try { - return nupdateGamepadMappings(stack.allocateFrom(string)); - } finally { - stack.setPointer(stackPointer); - } - } + @Convert(Type.INT) + @Entrypoint("glfwUpdateGamepadMappings") + boolean updateGamepadMappings(String string); /** * Returns the human-readable gamepad name for the specified joystick. @@ -5311,13 +4550,8 @@ static boolean updateGamepadMappings(String string) { * @glfw.thread_safety This function must only be called from the main thread. * @see #joystickIsGamepad(int) joystickIsGamepad */ - static MemorySegment ngetGamepadName(int jid) { - try { - return (MemorySegment) glfwGetGamepadName.invokeExact(jid); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetGamepadName") + MemorySegment ngetGamepadName(int jid); /** * Returns the human-readable gamepad name for the specified joystick. @@ -5328,11 +4562,9 @@ static MemorySegment ngetGamepadName(int jid) { * error occurred. * @see #ngetGamepadName(int) ngetGamepadName */ + @Entrypoint("glfwGetGamepadName") @Nullable - static String getGamepadName(int jid) { - var pName = ngetGamepadName(jid); - return RuntimeHelper.isNullptr(pName) ? null : pName.getString(0); - } + String getGamepadName(int jid); /** * Retrieves the state of the specified joystick remapped as a gamepad. @@ -5363,13 +4595,9 @@ static String getGamepadName(int jid) { * @see #nupdateGamepadMappings(MemorySegment) updateGamepadMappings * @see #joystickIsGamepad(int) joystickIsGamepad */ - static boolean ngetGamepadState(int jid, MemorySegment state) { - try { - return (int) glfwGetGamepadState.invokeExact(jid, state) != FALSE; - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Convert(Type.INT) + @Entrypoint("glfwGetGamepadState") + boolean ngetGamepadState(int jid, MemorySegment state); /** * Retrieves the state of the specified joystick remapped as a gamepad. @@ -5381,9 +4609,9 @@ static boolean ngetGamepadState(int jid, MemorySegment state) { * occurred. * @see #ngetGamepadState(int, MemorySegment) ngetGamepadState */ - static boolean getGamepadState(int jid, GLFWGamepadState state) { - return ngetGamepadState(jid, state.segment()); - } + @Convert(Type.INT) + @Entrypoint("glfwGetGamepadState") + boolean getGamepadState(int jid, GLFWGamepadState state); /** * Sets the clipboard to the specified string. @@ -5391,6 +4619,7 @@ static boolean getGamepadState(int jid, GLFWGamepadState state) { * This function sets the system clipboard to the specified, UTF-8 encoded * string. * + * @param window window Deprecated. Any valid window or {@code NULL}. * @param string A UTF-8 encoded string. * @glfw.errors Possible errors include {@link #NOT_INITIALIZED} and * {@link #PLATFORM_ERROR}. @@ -5399,12 +4628,26 @@ static boolean getGamepadState(int jid, GLFWGamepadState state) { * @glfw.thread_safety This function must only be called from the main thread. * @see #ngetClipboardString() getClipboardString */ - static void nsetClipboardString(MemorySegment string) { - try { - glfwSetClipboardString.invokeExact(MemorySegment.NULL, string); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } + @Entrypoint("glfwSetClipboardString") + void nsetClipboardString(MemorySegment window, MemorySegment string); + + /** + * Sets the clipboard to the specified string. + *

+ * This function sets the system clipboard to the specified, UTF-8 encoded + * string. + * + * @param string A UTF-8 encoded string. + * @glfw.errors Possible errors include {@link #NOT_INITIALIZED} and + * {@link #PLATFORM_ERROR}. + * @glfw.pointer_lifetime The specified string is copied before this function + * returns. + * @glfw.thread_safety This function must only be called from the main thread. + * @see #ngetClipboardString() getClipboardString + */ + @Skip + default void nsetClipboardString(MemorySegment string) { + nsetClipboardString(MemorySegment.NULL, string); } /** @@ -5413,13 +4656,10 @@ static void nsetClipboardString(MemorySegment string) { * @param string A UTF-8 encoded string. * @see #nsetClipboardString(MemorySegment) nsetClipboardString */ - static void setClipboardString(String string) { - final MemoryStack stack = MemoryStack.stackGet(); - final long stackPointer = stack.getPointer(); - try { + @Skip + default void setClipboardString(String string) { + try (MemoryStack stack = MemoryStack.stackPush()) { nsetClipboardString(stack.allocateFrom(string)); - } finally { - stack.setPointer(stackPointer); } } @@ -5431,6 +4671,7 @@ static void setClipboardString(String string) { * if its contents cannot be converted, {@link MemorySegment#NULL NULL} is returned and a * {@link #FORMAT_UNAVAILABLE} error is generated. * + * @param window Deprecated. Any valid window or {@code NULL}. * @return The contents of the clipboard as a UTF-8 encoded string, or {@link MemorySegment#NULL NULL} * if an error occurred. * @glfw.errors Possible errors include {@link #NOT_INITIALIZED}, @@ -5443,12 +4684,33 @@ static void setClipboardString(String string) { * @glfw.thread_safety This function must only be called from the main thread. * @see #nsetClipboardString(MemorySegment) setClipboardString */ - static MemorySegment ngetClipboardString() { - try { - return (MemorySegment) glfwGetClipboardString.invokeExact(MemorySegment.NULL); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } + @Entrypoint("glfwGetClipboardString") + @SizedSeg(Unmarshal.STR_SIZE) + MemorySegment ngetClipboardString(MemorySegment window); + + /** + * Returns the contents of the clipboard as a string. + *

+ * This function returns the contents of the system clipboard, if it contains + * or is convertible to a UTF-8 encoded string. If the clipboard is empty or + * if its contents cannot be converted, {@link MemorySegment#NULL NULL} is returned and a + * {@link #FORMAT_UNAVAILABLE} error is generated. + * + * @return The contents of the clipboard as a UTF-8 encoded string, or {@link MemorySegment#NULL NULL} + * if an error occurred. + * @glfw.errors Possible errors include {@link #NOT_INITIALIZED}, + * {@link #FORMAT_UNAVAILABLE} and {@link #PLATFORM_ERROR}. + * @glfw.pointer_lifetime The returned string is allocated and freed by GLFW. You + * should not free it yourself. It is valid until the next call to + * {@code getClipboardString} or + * {@link #nsetClipboardString(MemorySegment) setClipboardString}, + * or until the library is terminated. + * @glfw.thread_safety This function must only be called from the main thread. + * @see #nsetClipboardString(MemorySegment) setClipboardString + */ + @Skip + default MemorySegment ngetClipboardString() { + return ngetClipboardString(MemorySegment.NULL); } /** @@ -5458,10 +4720,10 @@ static MemorySegment ngetClipboardString() { * if an error occurred. * @see #ngetClipboardString() ngetClipboardString */ + @Skip @Nullable - static String getClipboardString(@Deprecated MemorySegment window) { - var pString = ngetClipboardString(); - return RuntimeHelper.isNullptr(pString) ? null : pString.getString(0); + default String getClipboardString() { + return ngetClipboardString().getString(0L); } /** @@ -5485,13 +4747,8 @@ static String getClipboardString(@Deprecated MemorySegment window) { * writing of the internal base time is not atomic, so it needs to be * externally synchronized with calls to {@link #setTime}. */ - static double getTime() { - try { - return (double) glfwGetTime.invokeExact(); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetTime") + double getTime(); /** * Sets the GLFW time. @@ -5513,13 +4770,8 @@ static double getTime() { * writing of the internal base time is not atomic, so it needs to be * externally synchronized with calls to {@link #getTime}. */ - static void setTime(double time) { - try { - glfwSetTime.invokeExact(time); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSetTime") + void setTime(double time); /** * Returns the current value of the raw timer. @@ -5534,13 +4786,8 @@ static void setTime(double time) { * @glfw.thread_safety This function may be called from any thread. * @see #getTimerFrequency */ - static long getTimerValue() { - try { - return (long) glfwGetTimerValue.invokeExact(); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetTimerValue") + long getTimerValue(); /** * Returns the frequency, in Hz, of the raw timer. @@ -5553,13 +4800,8 @@ static long getTimerValue() { * @glfw.thread_safety This function may be called from any thread. * @see #getTimerValue */ - static long getTimerFrequency() { - try { - return (long) glfwGetTimerFrequency.invokeExact(); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetTimerFrequency") + long getTimerFrequency(); /** * Makes the context of the specified window current for the calling @@ -5597,13 +4839,8 @@ static long getTimerFrequency() { * @glfw.thread_safety This function may be called from any thread. * @see #getCurrentContext */ - static void makeContextCurrent(MemorySegment window) { - try { - glfwMakeContextCurrent.invokeExact(window); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwMakeContextCurrent") + void makeContextCurrent(MemorySegment window); /** * Returns the window whose context is current on the calling thread. @@ -5617,13 +4854,8 @@ static void makeContextCurrent(MemorySegment window) { * @glfw.thread_safety This function may be called from any thread. * @see #makeContextCurrent */ - static MemorySegment getCurrentContext() { - try { - return (MemorySegment) glfwGetCurrentContext.invokeExact(); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetCurrentContext") + MemorySegment getCurrentContext(); /** * Swaps the front and back buffers of the specified window. @@ -5647,13 +4879,8 @@ static MemorySegment getCurrentContext() { * @glfw.thread_safety This function may be called from any thread. * @see #swapInterval */ - static void swapBuffers(MemorySegment window) { - try { - glfwSwapBuffers.invokeExact(window); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSwapBuffers") + void swapBuffers(MemorySegment window); /** * Sets the swap interval for the current context. @@ -5690,13 +4917,8 @@ static void swapBuffers(MemorySegment window) { * @glfw.thread_safety This function may be called from any thread. * @see #swapBuffers */ - static void swapInterval(int interval) { - try { - glfwSwapInterval.invokeExact(interval); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwSwapInterval") + void swapInterval(int interval); /** * Returns whether the specified extension is available. @@ -5727,13 +4949,9 @@ static void swapInterval(int interval) { * @glfw.thread_safety This function may be called from any thread. * @see #ngetProcAddress */ - static boolean nextensionSupported(MemorySegment extension) { - try { - return (int) glfwExtensionSupported.invokeExact(extension) != FALSE; - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Convert(Type.INT) + @Entrypoint("glfwExtensionSupported") + boolean nextensionSupported(MemorySegment extension); /** * Returns whether the specified extension is available. @@ -5743,15 +4961,9 @@ static boolean nextensionSupported(MemorySegment extension) { * otherwise. * @see #nextensionSupported(MemorySegment) nextensionSupported */ - static boolean extensionSupported(String extension) { - final MemoryStack stack = MemoryStack.stackGet(); - final long stackPointer = stack.getPointer(); - try { - return nextensionSupported(stack.allocateFrom(extension)); - } finally { - stack.setPointer(stackPointer); - } - } + @Convert(Type.INT) + @Entrypoint("glfwExtensionSupported") + boolean extensionSupported(@StrCharset("US-ASCII") String extension); /** * Returns the address of the specified function for the current @@ -5784,13 +4996,8 @@ static boolean extensionSupported(String extension) { * @glfw.thread_safety This function may be called from any thread. * @see #nextensionSupported */ - static MemorySegment ngetProcAddress(MemorySegment procName) { - try { - return (MemorySegment) glfwGetProcAddress.invokeExact(procName); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetProcAddress") + MemorySegment ngetProcAddress(MemorySegment procName); /** * Returns the address of the specified function for the current @@ -5801,15 +5008,8 @@ static MemorySegment ngetProcAddress(MemorySegment procName) { * error occurred. * @see #ngetProcAddress(MemorySegment) ngetProcAddress */ - static MemorySegment getProcAddress(String procName) { - final MemoryStack stack = MemoryStack.stackGet(); - final long stackPointer = stack.getPointer(); - try { - return ngetProcAddress(stack.allocateFrom(procName)); - } finally { - stack.setPointer(stackPointer); - } - } + @Entrypoint("glfwGetProcAddress") + MemorySegment getProcAddress(String procName); /** * Returns whether the Vulkan loader and an ICD have been found. @@ -5829,13 +5029,9 @@ static MemorySegment getProcAddress(String procName) { * @glfw.errors Possible errors include {@link #NOT_INITIALIZED}. * @glfw.thread_safety This function may be called from any thread. */ - static boolean vulkanSupported() { - try { - return (int) glfwVulkanSupported.invokeExact() != FALSE; - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Convert(Type.INT) + @Entrypoint("glfwVulkanSupported") + boolean vulkanSupported(); /** * Returns the Vulkan instance extensions required by GLFW. @@ -5869,13 +5065,8 @@ static boolean vulkanSupported() { * library is terminated. * @glfw.thread_safety This function may be called from any thread. */ - static MemorySegment ngetRequiredInstanceExtensions(MemorySegment count) { - try { - return (MemorySegment) glfwGetRequiredInstanceExtensions.invokeExact(count); - } catch (Throwable e) { - throw new AssertionError("should not reach here", e); - } - } + @Entrypoint("glfwGetRequiredInstanceExtensions") + MemorySegment ngetRequiredInstanceExtensions(MemorySegment count); /** * Returns the Vulkan instance extensions required by GLFW. @@ -5884,19 +5075,14 @@ static MemorySegment ngetRequiredInstanceExtensions(MemorySegment count) { * error occurred. * @see #ngetRequiredInstanceExtensions(MemorySegment) ngetRequiredInstanceExtensions */ - static String @Nullable [] getRequiredInstanceExtensions() { - var stack = MemoryStack.stackGet(); - long stackPointer = stack.getPointer(); - MemorySegment pExt; - final int count; - try { - var pCount = stack.callocInt(); - pExt = ngetRequiredInstanceExtensions(pCount); - count = pCount.get(JAVA_INT, 0); - } finally { - stack.setPointer(stackPointer); + @Skip + default String @Nullable [] getRequiredInstanceExtensions() { + try (MemoryStack stack = MemoryStack.stackPush()) { + var pCount = stack.ints(0); + MemorySegment pExt = ngetRequiredInstanceExtensions(pCount); + final int count = pCount.get(JAVA_INT, 0); + if (count == 0) return null; + return Unmarshal.unmarshalAsStringArray(pExt.reinterpret(ADDRESS.scale(0L, count))); } - if (count == 0) return null; - return RuntimeHelper.toUnboundedArray(pExt, new String[count]); } } diff --git a/modules/overrungl.glfw/src/main/java/overrungl/glfw/GLFWCallbacks.java b/modules/overrungl.glfw/src/main/java/overrungl/glfw/GLFWCallbacks.java index 8aebde72..99d03e85 100644 --- a/modules/overrungl.glfw/src/main/java/overrungl/glfw/GLFWCallbacks.java +++ b/modules/overrungl.glfw/src/main/java/overrungl/glfw/GLFWCallbacks.java @@ -52,22 +52,23 @@ public static Arena create(MemorySegment window) { */ public static void free(MemorySegment window) { if (ARENA_MAP.containsKey(window)) { - GLFW.setCharCallback(window, null); - GLFW.setCursorEnterCallback(window, null); - GLFW.setCursorPosCallback(window, null); - GLFW.setDropCallback(window, null); - GLFW.setFramebufferSizeCallback(window, null); - GLFW.setKeyCallback(window, null); - GLFW.setMouseButtonCallback(window, null); - GLFW.setScrollCallback(window, null); - GLFW.setWindowCloseCallback(window, null); - GLFW.setWindowContentScaleCallback(window, null); - GLFW.setWindowFocusCallback(window, null); - GLFW.setWindowIconifyCallback(window, null); - GLFW.setWindowMaximizeCallback(window, null); - GLFW.setWindowPosCallback(window, null); - GLFW.setWindowRefreshCallback(window, null); - GLFW.setWindowSizeCallback(window, null); + final GLFW glfw = GLFW.INSTANCE; + glfw.setCharCallback(window, null); + glfw.setCursorEnterCallback(window, null); + glfw.setCursorPosCallback(window, null); + glfw.setDropCallback(window, null); + glfw.setFramebufferSizeCallback(window, null); + glfw.setKeyCallback(window, null); + glfw.setMouseButtonCallback(window, null); + glfw.setScrollCallback(window, null); + glfw.setWindowCloseCallback(window, null); + glfw.setWindowContentScaleCallback(window, null); + glfw.setWindowFocusCallback(window, null); + glfw.setWindowIconifyCallback(window, null); + glfw.setWindowMaximizeCallback(window, null); + glfw.setWindowPosCallback(window, null); + glfw.setWindowRefreshCallback(window, null); + glfw.setWindowSizeCallback(window, null); ARENA_MAP.remove(window).close(); } } diff --git a/modules/overrungl.glfw/src/main/java/overrungl/glfw/GLFWErrorFun.java b/modules/overrungl.glfw/src/main/java/overrungl/glfw/GLFWErrorFun.java index 93a333ed..a8751f40 100644 --- a/modules/overrungl.glfw/src/main/java/overrungl/glfw/GLFWErrorFun.java +++ b/modules/overrungl.glfw/src/main/java/overrungl/glfw/GLFWErrorFun.java @@ -68,10 +68,10 @@ default void ninvoke(int errorCode, @NativeType("const char*") @SizedSeg(Unmarsh /** * Sets the error callback. * - * @return The previous callback or {@code NULL}. + * @return The previously set callback, or {@link MemorySegment#NULL NULL} if no callback was set. */ default MemorySegment set() { - return GLFW.setErrorCallback(this); + return GLFW.INSTANCE.setErrorCallback(this); } @Override diff --git a/modules/overrungl.nfd/src/main/java/overrungl/nfd/NFDNFilterItem.java b/modules/overrungl.nfd/src/main/java/overrungl/nfd/NFDNFilterItem.java index e8f5317a..5856d329 100644 --- a/modules/overrungl.nfd/src/main/java/overrungl/nfd/NFDNFilterItem.java +++ b/modules/overrungl.nfd/src/main/java/overrungl/nfd/NFDNFilterItem.java @@ -99,8 +99,8 @@ public static NFDNFilterItem create(SegmentAllocator allocator, Pair... final NFDNFilterItem buffer = new NFDNFilterItem(allocator.allocate(LAYOUT, items.length), items.length); for (int i = 0, len = items.length; i < len; i++) { Pair item = items[i]; - buffer._name.set(allocator, i, item.key()); - buffer._spec.set(allocator, i, item.value()); + buffer._name.set(i, allocator, item.key()); + buffer._spec.set(i, allocator, item.value()); } return buffer; } diff --git a/modules/overrungl.nfd/src/main/java/overrungl/nfd/NFDU8FilterItem.java b/modules/overrungl.nfd/src/main/java/overrungl/nfd/NFDU8FilterItem.java index cb206a89..81a2e229 100644 --- a/modules/overrungl.nfd/src/main/java/overrungl/nfd/NFDU8FilterItem.java +++ b/modules/overrungl.nfd/src/main/java/overrungl/nfd/NFDU8FilterItem.java @@ -99,8 +99,8 @@ public static NFDU8FilterItem create(SegmentAllocator allocator, Pair... final NFDU8FilterItem buffer = new NFDU8FilterItem(allocator.allocate(LAYOUT, items.length), items.length); for (int i = 0, len = items.length; i < len; i++) { Pair item = items[i]; - buffer._name.set(allocator, i, item.key()); - buffer._spec.set(allocator, i, item.value()); + buffer._name.set(i, allocator, item.key()); + buffer._spec.set(i, allocator, item.value()); } return buffer; } diff --git a/modules/samples/src/test/java/overrungl/demo/glfw/GLFWJoystickTest.java b/modules/samples/src/test/java/overrungl/demo/glfw/GLFWJoystickTest.java index 535eb9fe..cf5e508c 100644 --- a/modules/samples/src/test/java/overrungl/demo/glfw/GLFWJoystickTest.java +++ b/modules/samples/src/test/java/overrungl/demo/glfw/GLFWJoystickTest.java @@ -32,6 +32,7 @@ * @since 0.1.0 */ public final class GLFWJoystickTest { + private final GLFW glfw = GLFW.INSTANCE; private MemorySegment window; public void run() { @@ -39,38 +40,38 @@ public void run() { loop(); GLFWCallbacks.free(window); - GLFW.destroyWindow(window); + glfw.destroyWindow(window); - GLFW.terminate(); - GLFW.setErrorCallback(null); + glfw.terminate(); + glfw.setErrorCallback(null); } private void init() { GLFWErrorCallback.createPrint().set(); - CheckUtil.check(GLFW.init(), "Unable to initialize GLFW"); - GLFW.defaultWindowHints(); - GLFW.windowHint(GLFW.VISIBLE, false); - GLFW.windowHint(GLFW.RESIZABLE, true); - GLFW.windowHint(GLFW.CLIENT_API, GLFW.NO_API); - window = GLFW.createWindow(200, 100, "Holder", MemorySegment.NULL, MemorySegment.NULL); + CheckUtil.check(glfw.init(), "Unable to initialize GLFW"); + glfw.defaultWindowHints(); + glfw.windowHint(GLFW.VISIBLE, false); + glfw.windowHint(GLFW.RESIZABLE, true); + glfw.windowHint(GLFW.CLIENT_API, GLFW.NO_API); + window = glfw.createWindow(200, 100, "Holder", MemorySegment.NULL, MemorySegment.NULL); CheckUtil.checkNotNullptr(window, "Failed to create the GLFW window"); - GLFW.setKeyCallback(window, (_, key, _, action, _) -> { + glfw.setKeyCallback(window, (_, key, _, action, _) -> { if (key == GLFW.KEY_ESCAPE && action == GLFW.RELEASE) { - GLFW.setWindowShouldClose(window, true); + glfw.setWindowShouldClose(window, true); } }); - GLFW.setJoystickCallback((jid, event) -> { + glfw.setJoystickCallback((jid, event) -> { switch (event) { case GLFW.CONNECTED -> { - boolean isGamepad = GLFW.joystickIsGamepad(jid); + boolean isGamepad = glfw.joystickIsGamepad(jid); var prefix = isGamepad ? "Gamepad " : "Joystick "; - System.out.println(STR."\{prefix}\{jid}: \"\{(isGamepad ? GLFW.getGamepadName(jid) : GLFW.getJoystickName(jid))}\" has connected"); + System.out.println(STR."\{prefix}\{jid}: \"\{(isGamepad ? glfw.getGamepadName(jid) : glfw.getJoystickName(jid))}\" has connected"); } case GLFW.DISCONNECTED -> System.out.println(STR."Joystick \{jid} has disconnected"); } }); - GLFW.showWindow(window); + glfw.showWindow(window); } private void loop() { @@ -78,14 +79,14 @@ private void loop() { for (int i = 0; i < states.length; i++) { states[i] = new GLFWGamepadState(Arena.ofAuto()); } - while (!GLFW.windowShouldClose(window)) { + while (!glfw.windowShouldClose(window)) { for (int i = 0; i <= GLFW.JOYSTICK_LAST; i++) { - if (GLFW.joystickPresent(i)) { - if (GLFW.joystickIsGamepad(i)) { + if (glfw.joystickPresent(i)) { + if (glfw.joystickIsGamepad(i)) { var state = states[i]; - if (GLFW.getGamepadState(i, state)) { + if (glfw.getGamepadState(i, state)) { System.out.println(STR.""" - Get gamepad state for [jid=\{i},name=\{GLFW.getGamepadName(i)}] successful: + Get gamepad state for [jid=\{i},name=\{glfw.getGamepadName(i)}] successful: Buttons: [A(Cross)=\{state.button(GLFW.GAMEPAD_BUTTON_A)}, B(Circle)=\{state.button(GLFW.GAMEPAD_BUTTON_B)}, X(Square)=\{state.button(GLFW.GAMEPAD_BUTTON_X)}, Y(Triangle)=\{state.button(GLFW.GAMEPAD_BUTTON_Y)}, Left bumper=\{state.button(GLFW.GAMEPAD_BUTTON_LEFT_BUMPER)}, Right bumper=\{state.button(GLFW.GAMEPAD_BUTTON_RIGHT_BUMPER)}, Back=\{state.button(GLFW.GAMEPAD_BUTTON_BACK)}, Start=\{state.button(GLFW.GAMEPAD_BUTTON_START)}, Guide=\{state.button(GLFW.GAMEPAD_BUTTON_GUIDE)}, Left thumb=\{state.button(GLFW.GAMEPAD_BUTTON_LEFT_THUMB)}, Right thumb=\{state.button(GLFW.GAMEPAD_BUTTON_RIGHT_THUMB)}, @@ -96,7 +97,7 @@ private void loop() { } } } - GLFW.waitEventsTimeout(3); + glfw.waitEventsTimeout(3); } } diff --git a/modules/samples/src/test/java/overrungl/demo/glfw/GLFWWindowIconTest.java b/modules/samples/src/test/java/overrungl/demo/glfw/GLFWWindowIconTest.java index cacff5c4..1443f4c0 100644 --- a/modules/samples/src/test/java/overrungl/demo/glfw/GLFWWindowIconTest.java +++ b/modules/samples/src/test/java/overrungl/demo/glfw/GLFWWindowIconTest.java @@ -40,6 +40,7 @@ * @since 0.1.0 */ public final class GLFWWindowIconTest { + private final GLFW glfw = GLFW.INSTANCE; private MemorySegment window; public void run() { @@ -50,19 +51,19 @@ public void run() { loop(); GLFWCallbacks.free(window); - GLFW.destroyWindow(window); + glfw.destroyWindow(window); - GLFW.terminate(); - GLFW.setErrorCallback(null); + glfw.terminate(); + glfw.setErrorCallback(null); } private void init(Arena arena) { GLFWErrorCallback.createPrint().set(); - CheckUtil.check(GLFW.init(), "Unable to initialize GLFW"); - GLFW.defaultWindowHints(); - GLFW.windowHint(GLFW.VISIBLE, false); - GLFW.windowHint(GLFW.RESIZABLE, true); - window = GLFW.createWindow(300, 300, "Hello World!", MemorySegment.NULL, MemorySegment.NULL); + CheckUtil.check(glfw.init(), "Unable to initialize GLFW"); + glfw.defaultWindowHints(); + glfw.windowHint(GLFW.VISIBLE, false); + glfw.windowHint(GLFW.RESIZABLE, true); + window = glfw.createWindow(300, 300, "Hello World!", MemorySegment.NULL, MemorySegment.NULL); CheckUtil.checkNotNullptr(window, "Failed to create the GLFW window"); try { @@ -78,48 +79,48 @@ private void init(Arena arena) { image.width.set(px.get(JAVA_INT, 0)); image.height.set(py.get(JAVA_INT, 0)); image.pixels.set(data); - GLFW.setWindowIcon(window, image); + glfw.setWindowIcon(window, image); stbImage.free(data); } catch (IOException e) { throw new RuntimeException(e); } - GLFW.setKeyCallback(window, (_, key, _, action, _) -> { + glfw.setKeyCallback(window, (_, key, _, action, _) -> { if (key == GLFW.KEY_ESCAPE && action == GLFW.RELEASE) { - GLFW.setWindowShouldClose(window, true); + glfw.setWindowShouldClose(window, true); } }); - GLFW.setFramebufferSizeCallback(window, (_, width, height) -> + glfw.setFramebufferSizeCallback(window, (_, width, height) -> GL.viewport(0, 0, width, height)); - var vidMode = GLFW.getVideoMode(GLFW.getPrimaryMonitor()); + var vidMode = glfw.getVideoMode(glfw.getPrimaryMonitor()); if (vidMode != null) { - var size = GLFW.getWindowSize(window); - GLFW.setWindowPos( + var size = glfw.getWindowSize(window); + glfw.setWindowPos( window, (vidMode.width() - size.x()) / 2, (vidMode.height() - size.y()) / 2 ); } - GLFW.makeContextCurrent(window); - GLFW.swapInterval(1); + glfw.makeContextCurrent(window); + glfw.swapInterval(1); - GLFW.showWindow(window); + glfw.showWindow(window); } private void load() { - Objects.requireNonNull(GLLoader.load(GLFW::getProcAddress, true), "Failed to load OpenGL"); + Objects.requireNonNull(GLLoader.load(glfw::getProcAddress, true), "Failed to load OpenGL"); GL.clearColor(0.4f, 0.6f, 0.9f, 1.0f); } private void loop() { - while (!GLFW.windowShouldClose(window)) { + while (!glfw.windowShouldClose(window)) { GL.clear(GL.COLOR_BUFFER_BIT | GL.DEPTH_BUFFER_BIT); - GLFW.swapBuffers(window); + glfw.swapBuffers(window); - GLFW.pollEvents(); + glfw.pollEvents(); } } diff --git a/modules/samples/src/test/java/overrungl/demo/opengl/GL10Test.java b/modules/samples/src/test/java/overrungl/demo/opengl/GL10Test.java index 4dbf2a8e..5cc93b34 100644 --- a/modules/samples/src/test/java/overrungl/demo/opengl/GL10Test.java +++ b/modules/samples/src/test/java/overrungl/demo/opengl/GL10Test.java @@ -34,6 +34,7 @@ * @since 0.1.0 */ public final class GL10Test { + private final GLFW glfw = GLFW.INSTANCE; private MemorySegment window; public void run() { @@ -42,51 +43,51 @@ public void run() { loop(); GLFWCallbacks.free(window); - GLFW.destroyWindow(window); + glfw.destroyWindow(window); - GLFW.terminate(); - GLFW.setErrorCallback(null); + glfw.terminate(); + glfw.setErrorCallback(null); } private void init() { GLFWErrorCallback.createPrint().set(); - CheckUtil.check(GLFW.init(), "Unable to initialize GLFW"); - GLFW.defaultWindowHints(); - GLFW.windowHint(GLFW.VISIBLE, false); - GLFW.windowHint(GLFW.RESIZABLE, true); - window = GLFW.createWindow(300, 300, "Hello World!", MemorySegment.NULL, MemorySegment.NULL); + CheckUtil.check(glfw.init(), "Unable to initialize GLFW"); + glfw.defaultWindowHints(); + glfw.windowHint(GLFW.VISIBLE, false); + glfw.windowHint(GLFW.RESIZABLE, true); + window = glfw.createWindow(300, 300, "Hello World!", MemorySegment.NULL, MemorySegment.NULL); CheckUtil.checkNotNullptr(window, "Failed to create the GLFW window"); - GLFW.setKeyCallback(window, (_, key, _, action, _) -> { + glfw.setKeyCallback(window, (_, key, _, action, _) -> { if (key == GLFW.KEY_ESCAPE && action == GLFW.RELEASE) { - GLFW.setWindowShouldClose(window, true); + glfw.setWindowShouldClose(window, true); } }); - GLFW.setFramebufferSizeCallback(window, (_, width, height) -> + glfw.setFramebufferSizeCallback(window, (_, width, height) -> GL.viewport(0, 0, width, height)); - var vidMode = GLFW.getVideoMode(GLFW.getPrimaryMonitor()); + var vidMode = glfw.getVideoMode(glfw.getPrimaryMonitor()); if (vidMode != null) { - var size = GLFW.getWindowSize(window); - GLFW.setWindowPos( + var size = glfw.getWindowSize(window); + glfw.setWindowPos( window, (vidMode.width() - size.x()) / 2, (vidMode.height() - size.y()) / 2 ); } - GLFW.makeContextCurrent(window); - GLFW.swapInterval(1); + glfw.makeContextCurrent(window); + glfw.swapInterval(1); - GLFW.showWindow(window); + glfw.showWindow(window); } private void load() { - Objects.requireNonNull(GLLoader.load(GLFW::getProcAddress), "Failed to load OpenGL"); + Objects.requireNonNull(GLLoader.load(glfw::getProcAddress), "Failed to load OpenGL"); GL.clearColor(0.4f, 0.6f, 0.9f, 1.0f); } private void loop() { - while (!GLFW.windowShouldClose(window)) { + while (!glfw.windowShouldClose(window)) { GL.clear(GL.COLOR_BUFFER_BIT | GL.DEPTH_BUFFER_BIT); // Draw triangle @@ -99,9 +100,9 @@ private void loop() { GL10.vertex2f(0.5f, -0.5f); GL10.end(); - GLFW.swapBuffers(window); + glfw.swapBuffers(window); - GLFW.pollEvents(); + glfw.pollEvents(); } } diff --git a/modules/samples/src/test/java/overrungl/demo/opengl/GL15Test.java b/modules/samples/src/test/java/overrungl/demo/opengl/GL15Test.java index 768103ba..076543de 100644 --- a/modules/samples/src/test/java/overrungl/demo/opengl/GL15Test.java +++ b/modules/samples/src/test/java/overrungl/demo/opengl/GL15Test.java @@ -40,6 +40,7 @@ * @since 0.1.0 */ public final class GL15Test { + private final GLFW glfw = GLFW.INSTANCE; private MemorySegment window; private int vbo, tex; @@ -54,45 +55,45 @@ public void run() { GL.deleteTexture(tex); GLFWCallbacks.free(window); - GLFW.destroyWindow(window); + glfw.destroyWindow(window); - GLFW.terminate(); - GLFW.setErrorCallback(null); + glfw.terminate(); + glfw.setErrorCallback(null); } private void init() { GLFWErrorCallback.createPrint().set(); - CheckUtil.check(GLFW.init(), "Unable to initialize GLFW"); - GLFW.defaultWindowHints(); - GLFW.windowHint(GLFW.VISIBLE, false); - GLFW.windowHint(GLFW.RESIZABLE, true); - window = GLFW.createWindow(640, 480, "OpenGL 1.5", MemorySegment.NULL, MemorySegment.NULL); + CheckUtil.check(glfw.init(), "Unable to initialize GLFW"); + glfw.defaultWindowHints(); + glfw.windowHint(GLFW.VISIBLE, false); + glfw.windowHint(GLFW.RESIZABLE, true); + window = glfw.createWindow(640, 480, "OpenGL 1.5", MemorySegment.NULL, MemorySegment.NULL); CheckUtil.checkNotNullptr(window, "Failed to create the GLFW window"); - GLFW.setKeyCallback(window, (_, key, _, action, _) -> { + glfw.setKeyCallback(window, (_, key, _, action, _) -> { if (key == GLFW.KEY_ESCAPE && action == GLFW.RELEASE) { - GLFW.setWindowShouldClose(window, true); + glfw.setWindowShouldClose(window, true); } }); - GLFW.setFramebufferSizeCallback(window, (_, width, height) -> + glfw.setFramebufferSizeCallback(window, (_, width, height) -> GL.viewport(0, 0, width, height)); - var vidMode = GLFW.getVideoMode(GLFW.getPrimaryMonitor()); + var vidMode = glfw.getVideoMode(glfw.getPrimaryMonitor()); if (vidMode != null) { - var size = GLFW.getWindowSize(window); - GLFW.setWindowPos( + var size = glfw.getWindowSize(window); + glfw.setWindowPos( window, (vidMode.width() - size.x()) / 2, (vidMode.height() - size.y()) / 2 ); } - GLFW.makeContextCurrent(window); - GLFW.swapInterval(1); + glfw.makeContextCurrent(window); + glfw.swapInterval(1); - GLFW.showWindow(window); + glfw.showWindow(window); } private void load(Arena arena) { - Objects.requireNonNull(GLLoader.load(GLFW::getProcAddress), "Failed to load OpenGL"); + Objects.requireNonNull(GLLoader.load(glfw::getProcAddress), "Failed to load OpenGL"); GL.clearColor(0.4f, 0.6f, 0.9f, 1.0f); GL.enable(GL.TEXTURE_2D); @@ -137,7 +138,7 @@ private void load(Arena arena) { } private void loop() { - while (!GLFW.windowShouldClose(window)) { + while (!glfw.windowShouldClose(window)) { GL.clear(GL.COLOR_BUFFER_BIT | GL.DEPTH_BUFFER_BIT); // Draw triangle @@ -158,9 +159,9 @@ private void loop() { GL.bindBuffer(GL.ARRAY_BUFFER, 0); GL.bindTexture(GL.TEXTURE_2D, 0); - GLFW.swapBuffers(window); + glfw.swapBuffers(window); - GLFW.pollEvents(); + glfw.pollEvents(); } } diff --git a/modules/samples/src/test/java/overrungl/demo/opengl/GL30Test.java b/modules/samples/src/test/java/overrungl/demo/opengl/GL30Test.java index 5d3cee9b..95200ff4 100644 --- a/modules/samples/src/test/java/overrungl/demo/opengl/GL30Test.java +++ b/modules/samples/src/test/java/overrungl/demo/opengl/GL30Test.java @@ -40,6 +40,7 @@ * @since 0.1.0 */ public final class GL30Test { + private final GLFW glfw = GLFW.INSTANCE; private MemorySegment window; private int program; private int colorFactor; @@ -60,45 +61,45 @@ public void run() { GL.deleteTexture(tex); GLFWCallbacks.free(window); - GLFW.destroyWindow(window); + glfw.destroyWindow(window); - GLFW.terminate(); - GLFW.setErrorCallback(null); + glfw.terminate(); + glfw.setErrorCallback(null); } private void init() { GLFWErrorCallback.createPrint().set(); - CheckUtil.check(GLFW.init(), "Unable to initialize GLFW"); - GLFW.defaultWindowHints(); - GLFW.windowHint(GLFW.VISIBLE, false); - GLFW.windowHint(GLFW.RESIZABLE, true); - window = GLFW.createWindow(640, 480, "OpenGL 3.0", MemorySegment.NULL, MemorySegment.NULL); + CheckUtil.check(glfw.init(), "Unable to initialize GLFW"); + glfw.defaultWindowHints(); + glfw.windowHint(GLFW.VISIBLE, false); + glfw.windowHint(GLFW.RESIZABLE, true); + window = glfw.createWindow(640, 480, "OpenGL 3.0", MemorySegment.NULL, MemorySegment.NULL); CheckUtil.checkNotNullptr(window, "Failed to create the GLFW window"); - GLFW.setKeyCallback(window, (_, key, _, action, _) -> { + glfw.setKeyCallback(window, (_, key, _, action, _) -> { if (key == GLFW.KEY_ESCAPE && action == GLFW.RELEASE) { - GLFW.setWindowShouldClose(window, true); + glfw.setWindowShouldClose(window, true); } }); - GLFW.setFramebufferSizeCallback(window, (_, width, height) -> + glfw.setFramebufferSizeCallback(window, (_, width, height) -> GL.viewport(0, 0, width, height)); - var vidMode = GLFW.getVideoMode(GLFW.getPrimaryMonitor()); + var vidMode = glfw.getVideoMode(glfw.getPrimaryMonitor()); if (vidMode != null) { - var size = GLFW.getWindowSize(window); - GLFW.setWindowPos( + var size = glfw.getWindowSize(window); + glfw.setWindowPos( window, (vidMode.width() - size.x()) / 2, (vidMode.height() - size.y()) / 2 ); } - GLFW.makeContextCurrent(window); - GLFW.swapInterval(1); + glfw.makeContextCurrent(window); + glfw.swapInterval(1); - GLFW.showWindow(window); + glfw.showWindow(window); } private void load(Arena arena) { - Objects.requireNonNull(GLLoader.load(GLFW::getProcAddress, true), "Failed to load OpenGL"); + Objects.requireNonNull(GLLoader.load(glfw::getProcAddress, true), "Failed to load OpenGL"); GL.clearColor(0.4f, 0.6f, 0.9f, 1.0f); @@ -201,22 +202,22 @@ void main() { } private void loop() { - while (!GLFW.windowShouldClose(window)) { + while (!glfw.windowShouldClose(window)) { GL.clear(GL.COLOR_BUFFER_BIT | GL.DEPTH_BUFFER_BIT); // Draw triangle GL.bindTexture(GL.TEXTURE_2D, tex); GL.useProgram(program); - GL.uniform1f(colorFactor, (float) ((Math.sin(GLFW.getTime() * 2) + 1 * 0.5) * 0.6 + 0.4)); + GL.uniform1f(colorFactor, (float) ((Math.sin(glfw.getTime() * 2) + 1 * 0.5) * 0.6 + 0.4)); GL.bindVertexArray(vao); GL.drawElements(GL.TRIANGLES, 6, GL.UNSIGNED_BYTE, MemorySegment.NULL); GL.bindVertexArray(0); GL.useProgram(0); GL.bindTexture(GL.TEXTURE_2D, 0); - GLFW.swapBuffers(window); + glfw.swapBuffers(window); - GLFW.pollEvents(); + glfw.pollEvents(); } } diff --git a/modules/samples/src/test/java/overrungl/demo/opengl/GL33Test.java b/modules/samples/src/test/java/overrungl/demo/opengl/GL33Test.java index 420a0ad9..7eef2b79 100644 --- a/modules/samples/src/test/java/overrungl/demo/opengl/GL33Test.java +++ b/modules/samples/src/test/java/overrungl/demo/opengl/GL33Test.java @@ -43,6 +43,7 @@ public class GL33Test { private static final int INSTANCE_COUNT = square(10); private static final String WND_TITLE = "OpenGL 3.3"; private static final boolean VSYNC = true; + private final GLFW glfw = GLFW.INSTANCE; private MemorySegment window; private int program; private int rotationMat; @@ -68,49 +69,49 @@ public void run() { } GLFWCallbacks.free(window); - GLFW.destroyWindow(window); + glfw.destroyWindow(window); debugProc.close(); - GLFW.terminate(); - GLFW.setErrorCallback(null); + glfw.terminate(); + glfw.setErrorCallback(null); } private void init() { GLFWErrorCallback.createPrint().set(); - CheckUtil.check(GLFW.init(), "Unable to initialize GLFW"); - GLFW.defaultWindowHints(); - GLFW.windowHint(GLFW.VISIBLE, false); - GLFW.windowHint(GLFW.RESIZABLE, true); - GLFW.windowHint(GLFW.CONTEXT_VERSION_MAJOR, 3); - GLFW.windowHint(GLFW.CONTEXT_VERSION_MINOR, 3); - GLFW.windowHint(GLFW.OPENGL_PROFILE, GLFW.OPENGL_CORE_PROFILE); - window = GLFW.createWindow(640, 480, WND_TITLE, MemorySegment.NULL, MemorySegment.NULL); + CheckUtil.check(glfw.init(), "Unable to initialize GLFW"); + glfw.defaultWindowHints(); + glfw.windowHint(GLFW.VISIBLE, false); + glfw.windowHint(GLFW.RESIZABLE, true); + glfw.windowHint(GLFW.CONTEXT_VERSION_MAJOR, 3); + glfw.windowHint(GLFW.CONTEXT_VERSION_MINOR, 3); + glfw.windowHint(GLFW.OPENGL_PROFILE, GLFW.OPENGL_CORE_PROFILE); + window = glfw.createWindow(640, 480, WND_TITLE, MemorySegment.NULL, MemorySegment.NULL); CheckUtil.checkNotNullptr(window, "Failed to create the GLFW window"); - GLFW.setKeyCallback(window, (_, key, _, action, _) -> { + glfw.setKeyCallback(window, (_, key, _, action, _) -> { if (key == GLFW.KEY_ESCAPE && action == GLFW.RELEASE) { - GLFW.setWindowShouldClose(window, true); + glfw.setWindowShouldClose(window, true); } }); - GLFW.setFramebufferSizeCallback(window, (_, width, height) -> + glfw.setFramebufferSizeCallback(window, (_, width, height) -> GL.viewport(0, 0, width, height)); - var vidMode = GLFW.getVideoMode(GLFW.getPrimaryMonitor()); + var vidMode = glfw.getVideoMode(glfw.getPrimaryMonitor()); if (vidMode != null) { - var size = GLFW.getWindowSize(window); - GLFW.setWindowPos( + var size = glfw.getWindowSize(window); + glfw.setWindowPos( window, (vidMode.width() - size.x()) / 2, (vidMode.height() - size.y()) / 2 ); } - GLFW.makeContextCurrent(window); - if (VSYNC) GLFW.swapInterval(1); + glfw.makeContextCurrent(window); + if (VSYNC) glfw.swapInterval(1); - GLFW.showWindow(window); + glfw.showWindow(window); } private void load(Arena arena) { - Objects.requireNonNull(GLLoader.load(GLFW::getProcAddress, true), "Failed to load OpenGL"); + Objects.requireNonNull(GLLoader.load(glfw::getProcAddress, true), "Failed to load OpenGL"); debugProc = GLUtil.setupDebugMessageCallback(); GL.clearColor(0.4f, 0.6f, 0.9f, 1.0f); @@ -222,9 +223,9 @@ private void loop() { var matrix = new Matrix4f(); var pRotationMat = Matrixn.allocate(Arena.ofAuto(), matrix); - var timer = Timer.ofGetter(20, GLFW::getTime); + var timer = Timer.ofGetter(20, glfw::getTime); - while (!GLFW.windowShouldClose(window)) { + while (!glfw.windowShouldClose(window)) { timer.advanceTime(); timer.performTicks(null); @@ -243,13 +244,13 @@ private void loop() { GL.bindVertexArray(0); GL.useProgram(0); - GLFW.swapBuffers(window); + glfw.swapBuffers(window); - GLFW.pollEvents(); + glfw.pollEvents(); // using lambda gets higher FPS ?? timer.calcFPS(fps -> { - GLFW.setWindowTitle(window, STR."\{WND_TITLE} FPS: \{fps}"); + glfw.setWindowTitle(window, STR."\{WND_TITLE} FPS: \{fps}"); }); } } diff --git a/modules/samples/src/test/java/overrungl/demo/util/IOUtil.java b/modules/samples/src/test/java/overrungl/demo/util/IOUtil.java index f2336550..089e04df 100644 --- a/modules/samples/src/test/java/overrungl/demo/util/IOUtil.java +++ b/modules/samples/src/test/java/overrungl/demo/util/IOUtil.java @@ -69,7 +69,8 @@ public static MemorySegment ioResourceToSegment(Arena arena, String resource, lo Objects.requireNonNull(IOUtil.class.getClassLoader().getResourceAsStream(resource), STR."Failed to load resource '\{resource}'!") ) { - MemorySegment segment = arena.allocate(segmentSize); + Arena readArena = Arena.ofConfined(); + MemorySegment segment = readArena.allocate(segmentSize); // Creates a byte array to avoid creating it each loop final byte[] bytes = new byte[bufferSize]; @@ -77,13 +78,17 @@ public static MemorySegment ioResourceToSegment(Arena arena, String resource, lo int count; while ((count = is.read(bytes)) > 0) { if (pos + count >= segment.byteSize()) { - segment = resizeSegment(arena, segment, Math.ceilDiv(segment.byteSize() * 3, 2)); // 50% + Arena newArena = Arena.ofConfined(); + segment = resizeSegment(newArena, segment, Math.ceilDiv(segment.byteSize() * 3, 2)); // 50% + readArena.close(); + readArena = newArena; } MemorySegment.copy(bytes, 0, segment, ValueLayout.JAVA_BYTE, pos, count); pos += count; } + readArena.close(); - return segment.asSlice(0, pos); + return segment.asSlice(0, pos).reinterpret(arena, null); } catch (URISyntaxException e) { throw new IllegalArgumentException(STR."Illegal URI: \{resource}", e); }