Package org.lwjgl.vulkan
Class VkPushDescriptorSetWithTemplateInfo
java.lang.Object
org.lwjgl.system.Pointer.Default
org.lwjgl.system.Struct<VkPushDescriptorSetWithTemplateInfo>
org.lwjgl.vulkan.VkPushDescriptorSetWithTemplateInfo
- All Implemented Interfaces:
AutoCloseable,org.lwjgl.system.NativeResource,org.lwjgl.system.Pointer
- Direct Known Subclasses:
VkPushDescriptorSetWithTemplateInfoKHR
public class VkPushDescriptorSetWithTemplateInfo
extends org.lwjgl.system.Struct<VkPushDescriptorSetWithTemplateInfo>
implements org.lwjgl.system.NativeResource
Structure specifying a descriptor set push operation using a descriptor update template.
Valid Usage
- The
pipelineBindPointspecified during the creation of the descriptor update template must be supported by thecommandBuffer’s parentVkCommandPool’s queue family pDatamust be a valid pointer to a memory containing one or more valid instances ofVkDescriptorImageInfo,VkDescriptorBufferInfo, orVkBufferViewin a layout defined bydescriptorUpdateTemplatewhen it was created withCreateDescriptorUpdateTemplatelayoutmust be compatible with the layout used to createdescriptorUpdateTemplatedescriptorUpdateTemplatemust have been created with atemplateTypeofDESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORSsetmust be the same value used to createdescriptorUpdateTemplatesetmust be less thanVkPipelineLayoutCreateInfo::setLayoutCountprovided whenlayoutwas createdsetmust be the unique set number in the pipeline layout that uses a descriptor set layout that was created withDESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT
- If the
dynamicPipelineLayoutfeature is not enabled,layoutmust be a validVkPipelineLayouthandle - If
layoutisNULL_HANDLE, thepNextchain must include a validVkPipelineLayoutCreateInfostructure
Valid Usage (Implicit)
sTypemust beSTRUCTURE_TYPE_PUSH_DESCRIPTOR_SET_WITH_TEMPLATE_INFOpNextmust beNULLor a pointer to a valid instance ofVkPipelineLayoutCreateInfo- The
sTypevalue of each struct in thepNextchain must be unique descriptorUpdateTemplatemust be a validVkDescriptorUpdateTemplatehandle- If
layoutis notNULL_HANDLE,layoutmust be a validVkPipelineLayouthandle pDatamust be a pointer value- Both of
descriptorUpdateTemplate, andlayoutthat are valid handles of non-ignored parameters must have been created, allocated, or retrieved from the sameVkDevice
See Also
CmdPushDescriptorSetWithTemplate2, CmdPushDescriptorSetWithTemplate2KHR
Layout
struct VkPushDescriptorSetWithTemplateInfo {
VkStructureType sType();
void const * pNext();
VkDescriptorUpdateTemplate descriptorUpdateTemplate();
VkPipelineLayout layout();
uint32_t set();
void const * pData();
}-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classAn array ofVkPushDescriptorSetWithTemplateInfostructs.Nested classes/interfaces inherited from class org.lwjgl.system.Struct
org.lwjgl.system.Struct.StructValidationNested classes/interfaces inherited from interface org.lwjgl.system.Pointer
org.lwjgl.system.Pointer.Default -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final intThe struct alignment in bytes.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct member offsets.static final intThe struct size in bytes.static final intThe struct member offsets.Fields inherited from interface org.lwjgl.system.Pointer
BITS32, BITS64, CLONG_SHIFT, CLONG_SIZE, POINTER_SHIFT, POINTER_SIZE -
Constructor Summary
ConstructorsConstructorDescriptionVkPushDescriptorSetWithTemplateInfo(ByteBuffer container) Creates aVkPushDescriptorSetWithTemplateInfoinstance at the current position of the specifiedByteBuffercontainer. -
Method Summary
Modifier and TypeMethodDescriptioncalloc()Returns a newVkPushDescriptorSetWithTemplateInfoinstance allocated withmemCalloc.calloc(int capacity) Returns a newVkPushDescriptorSetWithTemplateInfo.Bufferinstance allocated withmemCalloc.calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkPushDescriptorSetWithTemplateInfo.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.calloc(org.lwjgl.system.MemoryStack stack) Returns a newVkPushDescriptorSetWithTemplateInfoinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.create()Returns a newVkPushDescriptorSetWithTemplateInfoinstance allocated withBufferUtils.create(int capacity) Returns a newVkPushDescriptorSetWithTemplateInfo.Bufferinstance allocated withBufferUtils.create(long address) Returns a newVkPushDescriptorSetWithTemplateInfoinstance for the specified memory address.create(long address, int capacity) Create aVkPushDescriptorSetWithTemplateInfo.Bufferinstance at the specified memory.static @Nullable VkPushDescriptorSetWithTemplateInfocreateSafe(long address) static @Nullable VkPushDescriptorSetWithTemplateInfo.BuffercreateSafe(long address, int capacity) longa descriptor update template defining how to interpret the descriptor information inpData.descriptorUpdateTemplate(long value) Sets the specified value to thedescriptorUpdateTemplate()field.longlayout()aVkPipelineLayoutobject used to program the bindings.layout(long value) Sets the specified value to thelayout()field.malloc()Returns a newVkPushDescriptorSetWithTemplateInfoinstance allocated withmemAlloc.malloc(int capacity) Returns a newVkPushDescriptorSetWithTemplateInfo.Bufferinstance allocated withmemAlloc.malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkPushDescriptorSetWithTemplateInfo.Bufferinstance allocated on the specifiedMemoryStack.malloc(org.lwjgl.system.MemoryStack stack) Returns a newVkPushDescriptorSetWithTemplateInfoinstance allocated on the specifiedMemoryStack.static longndescriptorUpdateTemplate(long struct) Unsafe version ofdescriptorUpdateTemplate().static voidndescriptorUpdateTemplate(long struct, long value) Unsafe version ofdescriptorUpdateTemplate.static longnlayout(long struct) Unsafe version oflayout().static voidnlayout(long struct, long value) Unsafe version oflayout.static longnpData(long struct) Unsafe version ofpData().static voidnpData(long struct, long value) Unsafe version ofpData.static longnpNext(long struct) Unsafe version ofpNext().static voidnpNext(long struct, long value) Unsafe version ofpNext.static intnset(long struct) Unsafe version ofset().static voidnset(long struct, int value) Unsafe version ofset.static intnsType(long struct) Unsafe version ofsType().static voidnsType(long struct, int value) Unsafe version ofsType.longpData()a pointer to memory containing descriptors for the templated update.pData(long value) Sets the specified value to thepData()field.longpNext()NULLor a pointer to a structure extending this structure.pNext(long value) Sets the specified value to thepNext()field.pNext(VkPipelineLayoutCreateInfo value) Prepends the specifiedVkPipelineLayoutCreateInfovalue to thepNextchain.intset()the set number of the descriptor set in the pipeline layout that will be updated.set(int value) Sets the specified value to theset()field.set(int sType, long pNext, long descriptorUpdateTemplate, long layout, int set, long pData) Initializes this struct with the specified values.Copies the specified struct data to this struct.intsizeof()intsType()aVkStructureTypevalue identifying this structure.sType(int value) Sets the specified value to thesType()field.Sets theSTRUCTURE_TYPE_PUSH_DESCRIPTOR_SET_WITH_TEMPLATE_INFOvalue to thesType()field.static voidvalidate(long struct) Validates pointer members that should not beNULL.Methods inherited from class org.lwjgl.system.Struct
clear, free, isNull, validate, validateMethods inherited from class org.lwjgl.system.Pointer.Default
address, equals, hashCode, toStringMethods inherited from interface org.lwjgl.system.NativeResource
close, free
-
Field Details
-
SIZEOF
public static final int SIZEOFThe struct size in bytes. -
ALIGNOF
public static final int ALIGNOFThe struct alignment in bytes. -
STYPE
public static final int STYPEThe struct member offsets. -
PNEXT
public static final int PNEXTThe struct member offsets. -
DESCRIPTORUPDATETEMPLATE
public static final int DESCRIPTORUPDATETEMPLATEThe struct member offsets. -
LAYOUT
public static final int LAYOUTThe struct member offsets. -
SET
public static final int SETThe struct member offsets. -
PDATA
public static final int PDATAThe struct member offsets.
-
-
Constructor Details
-
VkPushDescriptorSetWithTemplateInfo
Creates aVkPushDescriptorSetWithTemplateInfoinstance at the current position of the specifiedByteBuffercontainer. Changes to the buffer's content will be visible to the struct instance and vice versa.The created instance holds a strong reference to the container object.
-
-
Method Details
-
sizeof
public int sizeof()- Specified by:
sizeofin classorg.lwjgl.system.Struct<VkPushDescriptorSetWithTemplateInfo>
-
sType
public int sType()aVkStructureTypevalue identifying this structure. -
pNext
public long pNext()NULLor a pointer to a structure extending this structure. -
descriptorUpdateTemplate
public long descriptorUpdateTemplate()a descriptor update template defining how to interpret the descriptor information inpData. -
layout
public long layout()aVkPipelineLayoutobject used to program the bindings. It must be compatible with the layout used to create thedescriptorUpdateTemplatehandle. If thedynamicPipelineLayoutfeature is enabled,layoutcan beNULL_HANDLEand the layout must be specified by chainingVkPipelineLayoutCreateInfostructure off thepNext -
set
public int set()the set number of the descriptor set in the pipeline layout that will be updated. This must be the same number used to create thedescriptorUpdateTemplatehandle. -
pData
public long pData()a pointer to memory containing descriptors for the templated update. -
sType
Sets the specified value to thesType()field. -
sType$Default
Sets theSTRUCTURE_TYPE_PUSH_DESCRIPTOR_SET_WITH_TEMPLATE_INFOvalue to thesType()field. -
pNext
Sets the specified value to thepNext()field. -
pNext
Prepends the specifiedVkPipelineLayoutCreateInfovalue to thepNextchain. -
descriptorUpdateTemplate
Sets the specified value to thedescriptorUpdateTemplate()field. -
layout
Sets the specified value to thelayout()field. -
set
Sets the specified value to theset()field. -
pData
Sets the specified value to thepData()field. -
set
public VkPushDescriptorSetWithTemplateInfo set(int sType, long pNext, long descriptorUpdateTemplate, long layout, int set, long pData) Initializes this struct with the specified values. -
set
Copies the specified struct data to this struct.- Parameters:
src- the source struct- Returns:
- this struct
-
malloc
Returns a newVkPushDescriptorSetWithTemplateInfoinstance allocated withmemAlloc. The instance must be explicitly freed. -
calloc
Returns a newVkPushDescriptorSetWithTemplateInfoinstance allocated withmemCalloc. The instance must be explicitly freed. -
create
Returns a newVkPushDescriptorSetWithTemplateInfoinstance allocated withBufferUtils. -
create
Returns a newVkPushDescriptorSetWithTemplateInfoinstance for the specified memory address. -
createSafe
-
malloc
Returns a newVkPushDescriptorSetWithTemplateInfo.Bufferinstance allocated withmemAlloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
calloc
Returns a newVkPushDescriptorSetWithTemplateInfo.Bufferinstance allocated withmemCalloc. The instance must be explicitly freed.- Parameters:
capacity- the buffer capacity
-
create
Returns a newVkPushDescriptorSetWithTemplateInfo.Bufferinstance allocated withBufferUtils.- Parameters:
capacity- the buffer capacity
-
create
Create aVkPushDescriptorSetWithTemplateInfo.Bufferinstance at the specified memory.- Parameters:
address- the memory addresscapacity- the buffer capacity
-
createSafe
public static @Nullable VkPushDescriptorSetWithTemplateInfo.Buffer createSafe(long address, int capacity) -
malloc
Returns a newVkPushDescriptorSetWithTemplateInfoinstance allocated on the specifiedMemoryStack.- Parameters:
stack- the stack from which to allocate
-
calloc
Returns a newVkPushDescriptorSetWithTemplateInfoinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
stack- the stack from which to allocate
-
malloc
public static VkPushDescriptorSetWithTemplateInfo.Buffer malloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkPushDescriptorSetWithTemplateInfo.Bufferinstance allocated on the specifiedMemoryStack.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
calloc
public static VkPushDescriptorSetWithTemplateInfo.Buffer calloc(int capacity, org.lwjgl.system.MemoryStack stack) Returns a newVkPushDescriptorSetWithTemplateInfo.Bufferinstance allocated on the specifiedMemoryStackand initializes all its bits to zero.- Parameters:
capacity- the buffer capacitystack- the stack from which to allocate
-
nsType
public static int nsType(long struct) Unsafe version ofsType(). -
npNext
public static long npNext(long struct) Unsafe version ofpNext(). -
ndescriptorUpdateTemplate
public static long ndescriptorUpdateTemplate(long struct) Unsafe version ofdescriptorUpdateTemplate(). -
nlayout
public static long nlayout(long struct) Unsafe version oflayout(). -
nset
public static int nset(long struct) Unsafe version ofset(). -
npData
public static long npData(long struct) Unsafe version ofpData(). -
nsType
public static void nsType(long struct, int value) Unsafe version ofsType. -
npNext
public static void npNext(long struct, long value) Unsafe version ofpNext. -
ndescriptorUpdateTemplate
public static void ndescriptorUpdateTemplate(long struct, long value) Unsafe version ofdescriptorUpdateTemplate. -
nlayout
public static void nlayout(long struct, long value) Unsafe version oflayout. -
nset
public static void nset(long struct, int value) Unsafe version ofset. -
npData
public static void npData(long struct, long value) Unsafe version ofpData. -
validate
public static void validate(long struct) Validates pointer members that should not beNULL.- Parameters:
struct- the struct to validate
-