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

org.lwjgl.util.nfd.NativeFileDialog Maven / Gradle / Ivy

Go to download

A tiny, neat C library that portably invokes native file open and save dialogs.

The newest version!
/*
 * Copyright LWJGL. All rights reserved.
 * License terms: https://www.lwjgl.org/license
 * MACHINE GENERATED FILE, DO NOT EDIT
 */
package org.lwjgl.util.nfd;

import org.jspecify.annotations.*;

import java.nio.*;

import org.lwjgl.*;

import org.lwjgl.system.*;

import static org.lwjgl.system.Checks.*;
import static org.lwjgl.system.MemoryStack.*;
import static org.lwjgl.system.MemoryUtil.*;

/**
 * Bindings to Native File Dialog Extended, a small C library that portably invokes native
 * file open, folder select and file save dialogs. Write dialog code once and have it pop up native dialogs on all supported platforms.
 * 
 * 

Usage

* * * *

File Filter Syntax

* *

Files can be filtered by file extension groups:

* *

 * nfdfilteritem_t filterItem[2] = { { "Source code", "c,cpp,cc" }, { "Headers", "h,hpp" } };
* *

A file filter is a pair of strings comprising the friendly name and the specification (multiple file extensions are comma-separated).

* *

A list of file filters can be passed as an argument when invoking the library.

* *

A wildcard filter is always added to every dialog.

* *

Note: On MacOS, the file dialogs do not have friendly names and there is no way to switch between filters, so the filter specifications are combined * (e.g. "c,cpp,cc,h,hpp"). The filter specification is also never explicitly shown to the user. This is usual MacOS behaviour and users expect it.

* *

Note 2: You must ensure that the specification string is non-empty and that every file extension has at least one character. Otherwise, bad things * might ensue (i.e. undefined behaviour).

* *

Note 3: On Linux, the file extension is appended (if missing) when the user presses down the "Save" button. The appended file extension will remain * visible to the user, even if an overwrite prompt is shown and the user then presses "Cancel".

* *

Note 4: On Windows, the default folder parameter is only used if there is no recently used folder available. Otherwise, the default folder will be the * folder that was last used. Internally, the Windows implementation calls {@code IFileDialog::SetDefaultFolder(IShellItem)}. This is usual Windows * behaviour and users expect it.

* *

Iterating Over PathSets

* *

A file open dialog that supports multiple selection produces a {@code PathSet}, which is a thin abstraction over the platform-specific collection. * There are two ways to iterate over a {@code PathSet}:

* *

Accessing by index

* *

This method does array-like access on the {@code PathSet}, and is the easiest to use. However, on certain platforms (Linux, and possibly Windows), it * takes O(N2) time in total to iterate the entire {@code PathSet}, because the underlying platform-specific implementation uses a linked list.

* *

Using an enumerator

* *

This method uses an enumerator object to iterate the paths in the {@code PathSet}. It is guaranteed to take O(N) time in total to iterate the entire * {@code PathSet}.

* *

Usage with a Platform Abstraction Framework

* *

NFDe is known to work with SDL2 and GLFW, and should also work with other platform abstraction framworks. However, you should initialize NFDe after * initializing the framework, and probably should deinitialize NFDe before deinitializing the framework. This is because some frameworks expect to be * initialized on a "clean slate", and they may configure the system in a different way from NFDe. {@link #NFD_Init Init} is generally very careful not to disrupt the * existing configuration unless necessary, and {@link #NFD_Quit Quit} restores the configuration back exactly to what it was before initialization.

* *

Known Limitations

* *
    *
  • No support for Windows XP's legacy dialogs such as {@code GetOpenFileName}.
  • *
  • GTK dialogs don't set the existing window as parent, so if users click the existing window while the dialog is open then the dialog will go behind * it. GTK writes a warning to {@code stdout} or {@code stderr} about this.
  • *
  • This library does not explicitly dispatch calls to the UI thread. This may lead to crashes if you call functions from other threads when the * platform does not support it (e.g. MacOS). Users are generally expected to call NFDe from an appropriate UI thread (i.e. the thread performing the * UI event loop).
  • *
*/ public class NativeFileDialog { static { LibNFD.initialize(); } /** * Result values. ({@code nfdresult_t}) * *
Enum values:
* *
    *
  • {@link #NFD_ERROR ERROR} - Programmatic error.
  • *
  • {@link #NFD_OKAY OKAY} - User pressed okay, or successful return.
  • *
  • {@link #NFD_CANCEL CANCEL} - User pressed cancel.
  • *
*/ public static final int NFD_ERROR = 0, NFD_OKAY = 1, NFD_CANCEL = 2; /** * The native window handle type. * *
Enum values:
* *
    *
  • {@link #NFD_WINDOW_HANDLE_TYPE_UNSET WINDOW_HANDLE_TYPE_UNSET}
  • *
  • {@link #NFD_WINDOW_HANDLE_TYPE_WINDOWS WINDOW_HANDLE_TYPE_WINDOWS} - Windows: handle is {@code HWND} (the Windows API typedefs this to {@code void*})
  • *
  • {@link #NFD_WINDOW_HANDLE_TYPE_COCOA WINDOW_HANDLE_TYPE_COCOA} - Cocoa: handle is {@code NSWindow*}
  • *
  • {@link #NFD_WINDOW_HANDLE_TYPE_X11 WINDOW_HANDLE_TYPE_X11} - X11: handle is {@code Window}
  • *
*/ public static final int NFD_WINDOW_HANDLE_TYPE_UNSET = 0, NFD_WINDOW_HANDLE_TYPE_WINDOWS = 1, NFD_WINDOW_HANDLE_TYPE_COCOA = 2, NFD_WINDOW_HANDLE_TYPE_X11 = 3; protected NativeFileDialog() { throw new UnsupportedOperationException(); } // --- [ NFD_FreePath ] --- /** Unsafe version of: {@link #NFD_FreePath FreePath} */ public static native void nNFD_FreePath(long filePath); /** Free a file path that was returned by the dialogs. */ public static void NFD_FreePath(@NativeType("nfdchar_t *") ByteBuffer filePath) { if (CHECKS) { checkNT1(filePath); } nNFD_FreePath(memAddress(filePath)); } /** Free a file path that was returned by the dialogs. */ public static void NFD_FreePath(@NativeType("nfdchar_t *") long filePath) { nNFD_FreePath(filePath); } // --- [ NFD_Init ] --- /** Initialize NFD - call this for every thread that might use NFD, before calling any other NFD functions on that thread. */ @NativeType("nfdresult_t") public static native int NFD_Init(); // --- [ NFD_Quit ] --- /** Call this to de-initialize NFD, if {@link #NFD_Init Init} returned {@link #NFD_OKAY OKAY}. */ public static native void NFD_Quit(); // --- [ NFD_OpenDialog ] --- /** * Unsafe version of: {@link #NFD_OpenDialog OpenDialog} * * @param filterCount if zero, {@code filterList} is ignored (you can use {@code NULL}) */ public static native int nNFD_OpenDialog(long outPath, long filterList, int filterCount, long defaultPath); /** * Single file open dialog. * *

It is the caller's responsibility to free {@code outPath} via {@link #NFD_FreePath FreePath} if this function returns {@link #NFD_OKAY OKAY}.

* * @param defaultPath if {@code NULL}, the operating system will decide */ @NativeType("nfdresult_t") public static int NFD_OpenDialog(@NativeType("nfdchar_t **") PointerBuffer outPath, @NativeType("nfdfilteritem_t const *") NFDFilterItem.@Nullable Buffer filterList, @NativeType("nfdchar_t const *") @Nullable ByteBuffer defaultPath) { if (CHECKS) { check(outPath, 1); checkNT1Safe(defaultPath); if (filterList != null) { Struct.validate(filterList.address(), remainingSafe(filterList), NFDFilterItem.SIZEOF, NFDFilterItem::validate); } } return nNFD_OpenDialog(memAddress(outPath), memAddressSafe(filterList), remainingSafe(filterList), memAddressSafe(defaultPath)); } /** * Single file open dialog. * *

It is the caller's responsibility to free {@code outPath} via {@link #NFD_FreePath FreePath} if this function returns {@link #NFD_OKAY OKAY}.

* * @param defaultPath if {@code NULL}, the operating system will decide */ @NativeType("nfdresult_t") public static int NFD_OpenDialog(@NativeType("nfdchar_t **") PointerBuffer outPath, @NativeType("nfdfilteritem_t const *") NFDFilterItem.@Nullable Buffer filterList, @NativeType("nfdchar_t const *") @Nullable CharSequence defaultPath) { if (CHECKS) { check(outPath, 1); if (filterList != null) { Struct.validate(filterList.address(), remainingSafe(filterList), NFDFilterItem.SIZEOF, NFDFilterItem::validate); } } MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nUTF8Safe(defaultPath, true); long defaultPathEncoded = defaultPath == null ? NULL : stack.getPointerAddress(); return nNFD_OpenDialog(memAddress(outPath), memAddressSafe(filterList), remainingSafe(filterList), defaultPathEncoded); } finally { stack.setPointer(stackPointer); } } // --- [ NFD_OpenDialog_With ] --- /** Unsafe version of: {@link #NFD_OpenDialog_With OpenDialog_With} */ public static native int nNFD_OpenDialog_With(long outPath, long args); /** * Single file open dialog, with additional parameters. * *

It is the caller's responsibility to free {@code outPath} via {@link #NFD_FreePath FreePath} if this function returns {@link #NFD_OKAY OKAY}.

*/ @NativeType("nfdresult_t") public static int NFD_OpenDialog_With(@NativeType("nfdchar_t **") PointerBuffer outPath, @NativeType("nfdopendialogu8args_t const *") NFDOpenDialogArgs args) { if (CHECKS) { check(outPath, 1); NFDOpenDialogArgs.validate(args.address()); } return nNFD_OpenDialog_With(memAddress(outPath), args.address()); } // --- [ NFD_OpenDialogMultiple ] --- /** * Unsafe version of: {@link #NFD_OpenDialogMultiple OpenDialogMultiple} * * @param filterCount if zero, {@code filterList} is ignored (you can use {@code NULL}) */ public static native int nNFD_OpenDialogMultiple(long outPath, long filterList, int filterCount, long defaultPath); /** * Multiple file open dialog. * *

It is the caller's responsibility to free {@code outPaths} via {@link #NFD_PathSet_Free PathSet_Free} if this function returns {@link #NFD_OKAY OKAY}.

* * @param defaultPath if {@code NULL}, the operating system will decide */ @NativeType("nfdresult_t") public static int NFD_OpenDialogMultiple(@NativeType("nfdpathset_t const **") PointerBuffer outPath, @NativeType("nfdfilteritem_t const *") NFDFilterItem.@Nullable Buffer filterList, @NativeType("nfdchar_t const *") @Nullable ByteBuffer defaultPath) { if (CHECKS) { check(outPath, 1); checkNT1Safe(defaultPath); if (filterList != null) { Struct.validate(filterList.address(), remainingSafe(filterList), NFDFilterItem.SIZEOF, NFDFilterItem::validate); } } return nNFD_OpenDialogMultiple(memAddress(outPath), memAddressSafe(filterList), remainingSafe(filterList), memAddressSafe(defaultPath)); } /** * Multiple file open dialog. * *

It is the caller's responsibility to free {@code outPaths} via {@link #NFD_PathSet_Free PathSet_Free} if this function returns {@link #NFD_OKAY OKAY}.

* * @param defaultPath if {@code NULL}, the operating system will decide */ @NativeType("nfdresult_t") public static int NFD_OpenDialogMultiple(@NativeType("nfdpathset_t const **") PointerBuffer outPath, @NativeType("nfdfilteritem_t const *") NFDFilterItem.@Nullable Buffer filterList, @NativeType("nfdchar_t const *") @Nullable CharSequence defaultPath) { if (CHECKS) { check(outPath, 1); if (filterList != null) { Struct.validate(filterList.address(), remainingSafe(filterList), NFDFilterItem.SIZEOF, NFDFilterItem::validate); } } MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nUTF8Safe(defaultPath, true); long defaultPathEncoded = defaultPath == null ? NULL : stack.getPointerAddress(); return nNFD_OpenDialogMultiple(memAddress(outPath), memAddressSafe(filterList), remainingSafe(filterList), defaultPathEncoded); } finally { stack.setPointer(stackPointer); } } // --- [ NFD_OpenDialogMultiple_With ] --- /** Unsafe version of: {@link #NFD_OpenDialogMultiple_With OpenDialogMultiple_With} */ public static native int nNFD_OpenDialogMultiple_With(long outPath, long args); /** * Multiple file open dialog, with additional parameters. * *

It is the caller's responsibility to free {@code outPaths} via {@link #NFD_PathSet_Free PathSet_Free} if this function returns {@link #NFD_OKAY OKAY}.

*/ @NativeType("nfdresult_t") public static int NFD_OpenDialogMultiple_With(@NativeType("nfdpathset_t const **") PointerBuffer outPath, @NativeType("nfdopendialogu8args_t const *") NFDOpenDialogArgs args) { if (CHECKS) { check(outPath, 1); NFDOpenDialogArgs.validate(args.address()); } return nNFD_OpenDialogMultiple_With(memAddress(outPath), args.address()); } // --- [ NFD_SaveDialog ] --- /** * Unsafe version of: {@link #NFD_SaveDialog SaveDialog} * * @param filterCount if zero, {@code filterList} is ignored (you can use {@code NULL}) */ public static native int nNFD_SaveDialog(long outPath, long filterList, int filterCount, long defaultPath, long defaultName); /** * Save dialog. * *

It is the caller's responsibility to free {@code outPath} via {@link #NFD_FreePath FreePath} if this function returns {@link #NFD_OKAY OKAY}.

* * @param defaultPath if {@code NULL}, the operating system will decide */ @NativeType("nfdresult_t") public static int NFD_SaveDialog(@NativeType("nfdchar_t **") PointerBuffer outPath, @NativeType("nfdfilteritem_t const *") NFDFilterItem.@Nullable Buffer filterList, @NativeType("nfdchar_t const *") @Nullable ByteBuffer defaultPath, @NativeType("nfdchar_t const *") @Nullable ByteBuffer defaultName) { if (CHECKS) { check(outPath, 1); checkNT1Safe(defaultPath); checkNT1Safe(defaultName); if (filterList != null) { Struct.validate(filterList.address(), remainingSafe(filterList), NFDFilterItem.SIZEOF, NFDFilterItem::validate); } } return nNFD_SaveDialog(memAddress(outPath), memAddressSafe(filterList), remainingSafe(filterList), memAddressSafe(defaultPath), memAddressSafe(defaultName)); } /** * Save dialog. * *

It is the caller's responsibility to free {@code outPath} via {@link #NFD_FreePath FreePath} if this function returns {@link #NFD_OKAY OKAY}.

* * @param defaultPath if {@code NULL}, the operating system will decide */ @NativeType("nfdresult_t") public static int NFD_SaveDialog(@NativeType("nfdchar_t **") PointerBuffer outPath, @NativeType("nfdfilteritem_t const *") NFDFilterItem.@Nullable Buffer filterList, @NativeType("nfdchar_t const *") @Nullable CharSequence defaultPath, @NativeType("nfdchar_t const *") @Nullable CharSequence defaultName) { if (CHECKS) { check(outPath, 1); if (filterList != null) { Struct.validate(filterList.address(), remainingSafe(filterList), NFDFilterItem.SIZEOF, NFDFilterItem::validate); } } MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nUTF8Safe(defaultPath, true); long defaultPathEncoded = defaultPath == null ? NULL : stack.getPointerAddress(); stack.nUTF8Safe(defaultName, true); long defaultNameEncoded = defaultName == null ? NULL : stack.getPointerAddress(); return nNFD_SaveDialog(memAddress(outPath), memAddressSafe(filterList), remainingSafe(filterList), defaultPathEncoded, defaultNameEncoded); } finally { stack.setPointer(stackPointer); } } // --- [ NFD_SaveDialog_With ] --- /** Unsafe version of: {@link #NFD_SaveDialog_With SaveDialog_With} */ public static native int nNFD_SaveDialog_With(long outPath, long args); /** * Save dialog, with additional parameters. * *

It is the caller's responsibility to free {@code outPath} via {@link #NFD_FreePath FreePath} if this function returns {@link #NFD_OKAY OKAY}.

*/ @NativeType("nfdresult_t") public static int NFD_SaveDialog_With(@NativeType("nfdchar_t **") PointerBuffer outPath, @NativeType("nfdsavedialogu8args_t const *") NFDSaveDialogArgs args) { if (CHECKS) { check(outPath, 1); NFDSaveDialogArgs.validate(args.address()); } return nNFD_SaveDialog_With(memAddress(outPath), args.address()); } // --- [ NFD_PickFolder ] --- /** Unsafe version of: {@link #NFD_PickFolder PickFolder} */ public static native int nNFD_PickFolder(long outPath, long defaultPath); /** * Select folder dialog. * *

It is the caller's responsibility to free {@code outPath} via {@link #NFD_FreePath FreePath} if this function returns {@link #NFD_OKAY OKAY}.

* * @param defaultPath if {@code NULL}, the operating system will decide */ @NativeType("nfdresult_t") public static int NFD_PickFolder(@NativeType("nfdchar_t **") PointerBuffer outPath, @NativeType("nfdchar_t const *") @Nullable ByteBuffer defaultPath) { if (CHECKS) { check(outPath, 1); checkNT1Safe(defaultPath); } return nNFD_PickFolder(memAddress(outPath), memAddressSafe(defaultPath)); } /** * Select folder dialog. * *

It is the caller's responsibility to free {@code outPath} via {@link #NFD_FreePath FreePath} if this function returns {@link #NFD_OKAY OKAY}.

* * @param defaultPath if {@code NULL}, the operating system will decide */ @NativeType("nfdresult_t") public static int NFD_PickFolder(@NativeType("nfdchar_t **") PointerBuffer outPath, @NativeType("nfdchar_t const *") @Nullable CharSequence defaultPath) { if (CHECKS) { check(outPath, 1); } MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nUTF8Safe(defaultPath, true); long defaultPathEncoded = defaultPath == null ? NULL : stack.getPointerAddress(); return nNFD_PickFolder(memAddress(outPath), defaultPathEncoded); } finally { stack.setPointer(stackPointer); } } // --- [ NFD_PickFolder_With ] --- /** Unsafe version of: {@link #NFD_PickFolder_With PickFolder_With} */ public static native int nNFD_PickFolder_With(long outPath, long args); /** * Select folder dialog, with additional parameters. * *

It is the caller's responsibility to free {@code outPath} via {@link #NFD_FreePath FreePath} if this function returns {@link #NFD_OKAY OKAY}.

*/ @NativeType("nfdresult_t") public static int NFD_PickFolder_With(@NativeType("nfdchar_t **") PointerBuffer outPath, @NativeType("nfdpickfolderu8args_t const *") NFDPickFolderArgs args) { if (CHECKS) { check(outPath, 1); } return nNFD_PickFolder_With(memAddress(outPath), args.address()); } // --- [ NFD_PickFolderMultiple ] --- /** Unsafe version of: {@link #NFD_PickFolderMultiple PickFolderMultiple} */ public static native int nNFD_PickFolderMultiple(long outPaths, long defaultPath); /** * Select multiple folder dialog. * *

It is the caller's responsibility to free {@code outPaths} via {@link #NFD_PathSet_Free PathSet_Free} if this function returns {@link #NFD_OKAY OKAY}.

* * @param defaultPath if {@code NULL}, the operating system will decide */ @NativeType("nfdresult_t") public static int NFD_PickFolderMultiple(@NativeType("nfdpathset_t const **") PointerBuffer outPaths, @NativeType("nfdchar_t const *") @Nullable ByteBuffer defaultPath) { if (CHECKS) { check(outPaths, 1); checkNT1Safe(defaultPath); } return nNFD_PickFolderMultiple(memAddress(outPaths), memAddressSafe(defaultPath)); } /** * Select multiple folder dialog. * *

It is the caller's responsibility to free {@code outPaths} via {@link #NFD_PathSet_Free PathSet_Free} if this function returns {@link #NFD_OKAY OKAY}.

* * @param defaultPath if {@code NULL}, the operating system will decide */ @NativeType("nfdresult_t") public static int NFD_PickFolderMultiple(@NativeType("nfdpathset_t const **") PointerBuffer outPaths, @NativeType("nfdchar_t const *") @Nullable CharSequence defaultPath) { if (CHECKS) { check(outPaths, 1); } MemoryStack stack = stackGet(); int stackPointer = stack.getPointer(); try { stack.nUTF8Safe(defaultPath, true); long defaultPathEncoded = defaultPath == null ? NULL : stack.getPointerAddress(); return nNFD_PickFolderMultiple(memAddress(outPaths), defaultPathEncoded); } finally { stack.setPointer(stackPointer); } } // --- [ NFD_PickFolderMultiple_With ] --- /** Unsafe version of: {@link #NFD_PickFolderMultiple_With PickFolderMultiple_With} */ public static native int nNFD_PickFolderMultiple_With(long outPaths, long args); /** * Select multiple folder dialog, with additional parameters. * *

It is the caller's responsibility to free {@code outPaths} via {@link #NFD_PathSet_Free PathSet_Free} if this function returns {@link #NFD_OKAY OKAY}.

*/ @NativeType("nfdresult_t") public static int NFD_PickFolderMultiple_With(@NativeType("nfdpathset_t const **") PointerBuffer outPaths, @NativeType("nfdpickfolderu8args_t const *") NFDPickFolderArgs args) { if (CHECKS) { check(outPaths, 1); } return nNFD_PickFolderMultiple_With(memAddress(outPaths), args.address()); } // --- [ NFD_GetError ] --- /** Unsafe version of: {@link #NFD_GetError GetError} */ public static native long nNFD_GetError(); /** * Get last error -- set when {@code nfdresult_t} returns {@link #NFD_ERROR ERROR}. * *

Returns the last error that was set, or {@code NULL} if there is no error. The memory is owned by NFD and should not be freed by user code. This is * always ASCII printable characters, so it can be interpreted as UTF-8 without any conversion.

*/ @NativeType("char const *") public static @Nullable String NFD_GetError() { long __result = nNFD_GetError(); return memUTF8Safe(__result); } // --- [ NFD_ClearError ] --- /** Clear the error */ public static native void NFD_ClearError(); // --- [ NFD_PathSet_GetCount ] --- /** Unsafe version of: {@link #NFD_PathSet_GetCount PathSet_GetCount} */ public static native int nNFD_PathSet_GetCount(long pathSet, long count); /** * Gets the number of entries stored in {@code pathSet}. * *

Note that some paths might be invalid ({@link #NFD_ERROR ERROR} will be returned by {@link #NFD_PathSet_GetPath PathSet_GetPath}), so we might not actually have this number of usable paths.

*/ @NativeType("nfdresult_t") public static int NFD_PathSet_GetCount(@NativeType("nfdpathset_t const *") long pathSet, @NativeType("nfdpathsetsize_t *") IntBuffer count) { if (CHECKS) { check(pathSet); check(count, 1); } return nNFD_PathSet_GetCount(pathSet, memAddress(count)); } // --- [ NFD_PathSet_GetPath ] --- /** Unsafe version of: {@link #NFD_PathSet_GetPath PathSet_GetPath} */ public static native int nNFD_PathSet_GetPath(long pathSet, int index, long outPath); /** * Gets the UTF-8 path at offset index. * *

It is the caller's responsibility to free {@code outPath} via {@link #NFD_PathSet_FreePath PathSet_FreePath} if this function returns {@link #NFD_OKAY OKAY}.

*/ @NativeType("nfdresult_t") public static int NFD_PathSet_GetPath(@NativeType("nfdpathset_t const *") long pathSet, @NativeType("nfdpathsetsize_t") int index, @NativeType("nfdchar_t **") PointerBuffer outPath) { if (CHECKS) { check(pathSet); check(outPath, 1); } return nNFD_PathSet_GetPath(pathSet, index, memAddress(outPath)); } // --- [ NFD_PathSet_FreePath ] --- /** Unsafe version of: {@link #NFD_PathSet_FreePath PathSet_FreePath} */ public static native void nNFD_PathSet_FreePath(long filePath); /** Free the path gotten by {@link #NFD_PathSet_GetPath PathSet_GetPath}. */ public static void NFD_PathSet_FreePath(@NativeType("nfdchar_t *") ByteBuffer filePath) { if (CHECKS) { checkNT1(filePath); } nNFD_PathSet_FreePath(memAddress(filePath)); } /** Free the path gotten by {@link #NFD_PathSet_GetPath PathSet_GetPath}. */ public static void NFD_PathSet_FreePath(@NativeType("nfdchar_t *") long filePath) { nNFD_PathSet_FreePath(filePath); } // --- [ NFD_PathSet_GetEnum ] --- /** Unsafe version of: {@link #NFD_PathSet_GetEnum PathSet_GetEnum} */ public static native int nNFD_PathSet_GetEnum(long pathSet, long outEnumerator); /** * Gets an enumerator of the path set. * *

It is the caller's responsibility to free {@code enumerator} via {@link #NFD_PathSet_FreeEnum PathSet_FreeEnum} if this function returns {@link #NFD_OKAY OKAY}, and it should be freed before * freeing the pathset.

*/ @NativeType("nfdresult_t") public static int NFD_PathSet_GetEnum(@NativeType("nfdpathset_t const *") long pathSet, @NativeType("nfdpathsetenum_t *") NFDPathSetEnum outEnumerator) { if (CHECKS) { check(pathSet); } return nNFD_PathSet_GetEnum(pathSet, outEnumerator.address()); } // --- [ NFD_PathSet_FreeEnum ] --- /** Unsafe version of: {@link #NFD_PathSet_FreeEnum PathSet_FreeEnum} */ public static native void nNFD_PathSet_FreeEnum(long enumerator); /** Frees an enumerator of the path set. */ public static void NFD_PathSet_FreeEnum(@NativeType("nfdpathsetenum_t *") NFDPathSetEnum enumerator) { nNFD_PathSet_FreeEnum(enumerator.address()); } // --- [ NFD_PathSet_EnumNext ] --- /** Unsafe version of: {@link #NFD_PathSet_EnumNext PathSet_EnumNext} */ public static native int nNFD_PathSet_EnumNext(long enumerator, long outPath); /** * Gets the next item from the path set enumerator. * *

If there are no more items, then {@code *outPaths} will be set to {@code NULL}.

* *

It is the caller's responsibility to free {@code *outPath} via {@link #NFD_PathSet_FreePath PathSet_FreePath} if this function returns {@link #NFD_OKAY OKAY} and {@code *outPath} is not null.

*/ @NativeType("nfdresult_t") public static int NFD_PathSet_EnumNext(@NativeType("nfdpathsetenum_t *") NFDPathSetEnum enumerator, @NativeType("nfdchar_t **") PointerBuffer outPath) { if (CHECKS) { check(outPath, 1); } return nNFD_PathSet_EnumNext(enumerator.address(), memAddress(outPath)); } // --- [ NFD_PathSet_Free ] --- /** Unsafe version of: {@link #NFD_PathSet_Free PathSet_Free} */ public static native void nNFD_PathSet_Free(long pathSet); /** Free the {@code pathSet}. */ public static void NFD_PathSet_Free(@NativeType("nfdpathset_t const *") long pathSet) { if (CHECKS) { check(pathSet); } nNFD_PathSet_Free(pathSet); } /** Array version of: {@link #nNFD_PathSet_GetCount} */ public static native int nNFD_PathSet_GetCount(long pathSet, int[] count); /** Array version of: {@link #NFD_PathSet_GetCount PathSet_GetCount} */ @NativeType("nfdresult_t") public static int NFD_PathSet_GetCount(@NativeType("nfdpathset_t const *") long pathSet, @NativeType("nfdpathsetsize_t *") int[] count) { if (CHECKS) { check(pathSet); check(count, 1); } return nNFD_PathSet_GetCount(pathSet, count); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy