BufferInfo encapsulates the settings that map to VkDescriptorBufferInfo. More...
#include <BufferInfo.h>


Public Member Functions | |
| BufferInfo (Data *in_data) | |
| BufferInfo (Buffer *in_buffer, VkDeviceSize in_offset, VkDeviceSize in_range, Data *in_data=nullptr) | |
| BufferInfo (const BufferInfo &)=delete | |
| BufferInfo & | operator= (const BufferInfo &)=delete |
| ref_ptr< Object > | clone (const CopyOp ©op={}) const override |
| int | compare (const Object &rhs_object) const override |
| compare two objects, return -1 if this object is less than rhs, return 0 if it's equal, return 1 if rhs is greater, | |
| void | release () |
| void | copyDataToBuffer () |
| void | copyDataToBuffer (uint32_t deviceID) |
| operator bool () const | |
| bool | requiresCopy (uint32_t deviceID) const |
| return true if the BufferInfo's data has been modified and should be copied to the buffer | |
| bool | syncModifiedCounts (uint32_t deviceID) |
| return true if the BufferInfo's data has been modified and should be copied to the buffer, and sync the modification counts | |
Public Member Functions inherited from vsg::Inherit< Object, BufferInfo > | |
| Inherit (Args &&... args) | |
| std::size_t | sizeofObject () const noexcept override |
| const char * | className () const noexcept override |
| const std::type_info & | type_info () const noexcept override |
| bool | is_compatible (const std::type_info &type) const noexcept override |
| int | compare (const Object &rhs) const override |
| void | accept (Visitor &visitor) override |
| void | accept (ConstVisitor &visitor) const override |
| void | accept (RecordTraversal &visitor) const override |
Public Member Functions inherited from vsg::Object | |
| Object (const Object &object, const CopyOp ©op={}) | |
| Object & | operator= (const Object &) |
| template<class T> | |
| T * | cast () |
| template<class T> | |
| const T * | cast () const |
| virtual void | traverse (Visitor &) |
| virtual void | traverse (ConstVisitor &) const |
| virtual void | traverse (RecordTraversal &) const |
| virtual void | read (Input &input) |
| virtual void | write (Output &output) const |
| void | ref () const noexcept |
| void | unref () const noexcept |
| void | unref_nodelete () const noexcept |
| unsigned int | referenceCount () const noexcept |
| template<typename T> | |
| void | setValue (const std::string &key, const T &value) |
| void | setValue (const std::string &key, const char *value) |
| specialization of setValue to handle passing C strings | |
| template<typename T> | |
| bool | getValue (const std::string &key, T &value) const |
| get specified value type, return false if value associated with key is not assigned or is not the correct type | |
| void | setObject (const std::string &key, ref_ptr< Object > object) |
| assign an Object associated with key | |
| Object * | getObject (const std::string &key) |
| get Object pointer associated with key, return nullptr if no object associated with key has been assigned | |
| const Object * | getObject (const std::string &key) const |
| get const Object pointer associated with key, return nullptr if no object associated with key has been assigned | |
| template<class T> | |
| T * | getObject (const std::string &key) |
| get object pointer of specified type associated with key, return nullptr if no object associated with key has been assigned | |
| template<class T> | |
| const T * | getObject (const std::string &key) const |
| get const object pointer of specified type associated with key, return nullptr if no object associated with key has been assigned | |
| ref_ptr< Object > | getRefObject (const std::string &key) |
| get ref_ptr<Object> associated with key, return nullptr if no object associated with key has been assigned | |
| ref_ptr< const Object > | getRefObject (const std::string &key) const |
| get ref_ptr<const Object> pointer associated with key, return nullptr if no object associated with key has been assigned | |
| template<class T> | |
| ref_ptr< T > | getRefObject (const std::string &key) |
| get ref_ptr<T> of specified type associated with key, return nullptr if no object associated with key has been assigned | |
| template<class T> | |
| const ref_ptr< const T > | getRefObject (const std::string &key) const |
| get ref_ptr<const T> of specified type associated with key, return nullptr if no object associated with key has been assigned | |
| void | removeObject (const std::string &key) |
| remove meta object or value associated with key | |
| Auxiliary * | getOrCreateAuxiliary () |
| Auxiliary * | getAuxiliary () |
| const Auxiliary * | getAuxiliary () const |
Public Attributes | |
| ref_ptr< Buffer > | buffer |
| VkDeviceSize | offset = 0 |
| VkDeviceSize | range = 0 |
| ref_ptr< Data > | data |
| ref_ptr< BufferInfo > | parent |
| vk_buffer< ModifiedCount > | copiedModifiedCounts |
Additional Inherited Members | |
Static Public Member Functions inherited from vsg::Inherit< Object, BufferInfo > | |
| static ref_ptr< BufferInfo > | create (Args &&... args) |
| static ref_ptr< BufferInfo > | create_if (bool flag, Args &&... args) |
Static Public Member Functions inherited from vsg::Object | |
| static ref_ptr< Object > | create () |
| static ref_ptr< Object > | create_if (bool flag) |
| static void * | operator new (std::size_t count) |
| provide new and delete to enable custom memory management via the vsg::Allocator singleton, using the MEMORY_AFFINTY_OBJECTS | |
| static void | operator delete (void *ptr) |
Protected Member Functions inherited from vsg::Object | |
| virtual void | _attemptDelete () const |
| void | setAuxiliary (Auxiliary *auxiliary) |
BufferInfo encapsulates the settings that map to VkDescriptorBufferInfo.
clone this object using CopyOp's duplicates map to decide whether to clone or to return the original object. The default clone(CopyOp&) implementation simply returns ref_ptr<> to this object rather attempt to clone.
Reimplemented from vsg::Object.
|
overridevirtual |
compare two objects, return -1 if this object is less than rhs, return 0 if it's equal, return 1 if rhs is greater,
Reimplemented from vsg::Object.
| void vsg::BufferInfo::copyDataToBuffer | ( | ) |
Copy data to the VkBuffer(s) for all Devices associated with vsg::Buffer Requires associated buffer memory to be host visible, for non host visible buffers you must use a staging buffer
| void vsg::BufferInfo::copyDataToBuffer | ( | uint32_t | deviceID | ) |
Copy data to the VkBuffer associated with the specified Device Requires associated buffer memory to be host visible, for non host visible buffers you must use a staging buffer