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 recordRepresents a pointer to / an array of null structure(s) in native memory. -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final longstatic final StructLayoutstatic final StructLayoutstatic final ValueLayout.OfLongstatic final longstatic final longstatic final MemoryLayout.PathElementstatic final MemoryLayout.PathElementstatic final longstatic final long -
Constructor Summary
ConstructorsConstructorDescriptionSDL_InitState(@NotNull MemorySegment segment) Creates an instance of aSDL_InitStaterecord class. -
Method Summary
Modifier and TypeMethodDescriptionstatic SDL_InitStatestatic SDL_InitState.Ptrstatic SDL_InitStateclone(Arena arena, SDL_InitState src) final booleanIndicates whether some other object is "equal to" this one.final inthashCode()Returns a hash code value for this object.@NotNull MemorySegmentsegment()Returns the value of thesegmentrecord component.@NotNull SDL_AtomicIntstatus()status(@NotNull SDL_AtomicInt value) status(Consumer<@NotNull SDL_AtomicInt> consumer) longthread()thread(long value) final StringtoString()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_InitStaterecord class.- Parameters:
segment- the value for thesegmentrecord 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 thesegmentrecord component.
-