Record Class SDL_InitState
- All Implemented Interfaces:
IPointer
,ISDL_InitState
A structure used for thread-safe initialization and shutdown.
Here is an example of using this:
static SDL_AtomicInitState init;
bool InitSystem(void)
{
if (!SDL_ShouldInit(&init)) {
// The system is initialized
return true;
}
// At this point, you should not leave this function without calling SDL_SetInitialized()
bool initialized = DoInitTasks();
SDL_SetInitialized(&init, initialized);
return initialized;
}
bool UseSubsystem(void)
{
if (SDL_ShouldInit(&init)) {
// Error, the subsystem isn't initialized
SDL_SetInitialized(&init, false);
return false;
}
// Do work using the initialized subsystem
return true;
}
void QuitSystem(void)
{
if (!SDL_ShouldQuit(&init)) {
// The system is not initialized
return;
}
// At this point, you should not leave this function without calling SDL_SetInitialized()
DoQuitTasks();
SDL_SetInitialized(&init, false);
}
Note that this doesn't protect any resources created during initialization, or guarantee that nobody is using those resources during cleanup. You should use other mechanisms to protect those, if that's a concern for your code.
Since: This struct is available since SDL 3.2.0.
Structure
typedef struct SDL_InitState {
SDL_AtomicInt
status
;
SDL_ThreadID thread
;
void* reserved;
} SDL_InitState;
Contracts
The property segment()
should always be not-null
(segment != NULL && !segment.equals(MemorySegment.NULL)
), and properly aligned to
LAYOUT.byteAlignment()
bytes. To represent null pointer, you may use a Java
null
instead. See the documentation of IPointer.segment()
for more details.
The constructor of this class is marked as UnsafeConstructor
, because it does not
perform any runtime check. The constructor can be useful for automatic code generators.
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic final record
Represents a pointer to / an array of null structure(s) in native memory. -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final long
static final StructLayout
static final StructLayout
static final ValueLayout.OfLong
static final long
static final long
static final MemoryLayout.PathElement
static final MemoryLayout.PathElement
static final long
static final long
-
Constructor Summary
ConstructorsConstructorDescriptionSDL_InitState
(@NotNull MemorySegment segment) Creates an instance of aSDL_InitState
record class. -
Method Summary
Modifier and TypeMethodDescriptionstatic SDL_InitState
static SDL_InitState.Ptr
static SDL_InitState
clone
(Arena arena, SDL_InitState src) final boolean
Indicates whether some other object is "equal to" this one.final int
hashCode()
Returns a hash code value for this object.@NotNull MemorySegment
segment()
Returns the value of thesegment
record component.@NotNull SDL_AtomicInt
status()
status
(@NotNull SDL_AtomicInt value) status
(Consumer<@NotNull SDL_AtomicInt> consumer) long
thread()
thread
(long value) final String
toString()
Returns a string representation of this record class.
-
Field Details
-
LAYOUT
-
BYTES
public static final long BYTES -
PATH$status
-
PATH$thread
-
LAYOUT$status
-
LAYOUT$thread
-
SIZE$status
public static final long SIZE$status -
SIZE$thread
public static final long SIZE$thread -
OFFSET$status
public static final long OFFSET$status -
OFFSET$thread
public static final long OFFSET$thread
-
-
Constructor Details
-
SDL_InitState
Creates an instance of aSDL_InitState
record class.- Parameters:
segment
- the value for thesegment
record component
-
-
Method Details
-
allocate
-
allocate
-
clone
-
status
-
status
-
status
-
thread
-
thread
-
toString
-
hashCode
-
equals
Indicates whether some other object is "equal to" this one. The objects are equal if the other object is of the same class and if all the record components are equal. All components in this record class are compared withObjects::equals(Object,Object)
. -
segment
Returns the value of thesegment
record component.
-