Record Class SDL_TextEditingEvent
java.lang.Object
java.lang.Record
club.doki7.sdl3.datatype.SDL_TextEditingEvent
- All Implemented Interfaces:
IPointer
,ISDL_TextEditingEvent
@ValueBasedCandidate
@UnsafeConstructor
public record SDL_TextEditingEvent(@NotNull MemorySegment segment)
extends Record
implements ISDL_TextEditingEvent
Keyboard text editing event structure (event.edit.*)
The start cursor is the position, in UTF-8 characters, where new typing will be inserted into the editing text. The length is the number of UTF-8 characters that will be replaced by new typing.
Since: This struct is available since SDL 3.2.0.
Structure
typedef struct SDL_TextEditingEvent {
SDL_EventType
type
;
Uint32 reserved;
Uint64 timestamp
;
SDL_WindowID windowID
;
char const* text
;
Sint32 start
;
Sint32 length
;
} SDL_TextEditingEvent;
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 ValueLayout.OfInt
static final ValueLayout.OfInt
static final AddressLayout
static final ValueLayout.OfLong
static final ValueLayout.OfInt
static final ValueLayout.OfInt
static final long
static final long
static final long
static final long
static final long
static final long
static final MemoryLayout.PathElement
static final MemoryLayout.PathElement
static final MemoryLayout.PathElement
static final MemoryLayout.PathElement
static final MemoryLayout.PathElement
static final MemoryLayout.PathElement
static final long
static final long
static final long
static final long
static final long
static final long
-
Constructor Summary
ConstructorsConstructorDescriptionSDL_TextEditingEvent
(@NotNull MemorySegment segment) Creates an instance of aSDL_TextEditingEvent
record class. -
Method Summary
Modifier and TypeMethodDescriptionstatic SDL_TextEditingEvent
static SDL_TextEditingEvent.Ptr
static SDL_TextEditingEvent
clone
(Arena arena, SDL_TextEditingEvent src) final boolean
Indicates whether some other object is "equal to" this one.final int
hashCode()
Returns a hash code value for this object.int
length()
length
(int value) @NotNull MemorySegment
segment()
Returns the value of thesegment
record component.int
start()
start
(int value) @Nullable BytePtr
text()
Note: the returnedBytePtr
does not have correctBytePtr.size()
property.textRaw()
void
textRaw
(MemorySegment value) long
timestamp
(long value) final String
toString()
Returns a string representation of this record class.int
type()
type
(int value) int
windowID()
windowID
(int value)
-
Field Details
-
LAYOUT
-
BYTES
public static final long BYTES -
PATH$type
-
PATH$timestamp
-
PATH$windowID
-
PATH$text
-
PATH$start
-
PATH$length
-
LAYOUT$type
-
LAYOUT$timestamp
-
LAYOUT$windowID
-
LAYOUT$text
-
LAYOUT$start
-
LAYOUT$length
-
SIZE$type
public static final long SIZE$type -
SIZE$timestamp
public static final long SIZE$timestamp -
SIZE$windowID
public static final long SIZE$windowID -
SIZE$text
public static final long SIZE$text -
SIZE$start
public static final long SIZE$start -
SIZE$length
public static final long SIZE$length -
OFFSET$type
public static final long OFFSET$type -
OFFSET$timestamp
public static final long OFFSET$timestamp -
OFFSET$windowID
public static final long OFFSET$windowID -
OFFSET$text
public static final long OFFSET$text -
OFFSET$start
public static final long OFFSET$start -
OFFSET$length
public static final long OFFSET$length
-
-
Constructor Details
-
SDL_TextEditingEvent
Creates an instance of aSDL_TextEditingEvent
record class.- Parameters:
segment
- the value for thesegment
record component
-
-
Method Details
-
allocate
-
allocate
-
clone
-
type
-
type
-
timestamp
-
timestamp
-
windowID
-
windowID
-
text
Note: the returnedBytePtr
does not have correctBytePtr.size()
property. It's up to user to track the size of the buffer, and useBytePtr.reinterpret(long)
to set the size before actually reading from or writing to the buffer. -
text
-
textRaw
-
textRaw
-
start
-
start
-
length
-
length
-
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.
-