logo
pub struct ImmutableBuffer<T, A = PotentialDedicatedAllocation<StdMemoryPoolAlloc>> where
    T: BufferContents + ?Sized
{ /* private fields */ }
Expand description

Buffer that is written once then read for as long as it is alive.

Implementations

Builds an ImmutableBuffer that copies its data from another buffer.

This function returns two objects: the newly-created buffer, and a future representing the initial upload operation. In order to be allowed to use the ImmutableBuffer, you must either submit your operation after this future, or execute this future and wait for it to be finished before submitting your own operation.

Builds an ImmutableBuffer from some data.

This function builds a memory-mapped intermediate buffer, writes the data to it, builds a command buffer that copies from this intermediate buffer to the final buffer, and finally submits the command buffer as a future.

This function returns two objects: the newly-created buffer, and a future representing the initial upload operation. In order to be allowed to use the ImmutableBuffer, you must either submit your operation after this future, or execute this future and wait for it to be finished before submitting your own operation.

Panics
  • Panics if T has zero size.

Builds a new buffer with uninitialized data. Only allowed for sized data.

Returns two things: the buffer, and a special access that should be used for the initial upload to the buffer.

You will get an error if you try to use the buffer before using the initial upload access. However this function doesn’t check whether you actually used this initial upload to fill the buffer like you’re supposed to do.

You will also get an error if you try to get exclusive access to the final buffer.

Safety
  • The ImmutableBufferInitialization should be used to fill the buffer with some initial data, otherwise the content is undefined.
Panics
  • Panics if T has zero size.
Panics
  • Panics if T has zero size.
  • Panics if data is empty.

Builds a new buffer with uninitialized data. Can be used for arrays.

Returns two things: the buffer, and a special access that should be used for the initial upload to the buffer.

You will get an error if you try to use the buffer before using the initial upload access. However this function doesn’t check whether you actually used this initial upload to fill the buffer like you’re supposed to do.

You will also get an error if you try to get exclusive access to the final buffer.

Safety
  • The ImmutableBufferInitialization should be used to fill the buffer with some initial data, otherwise the content is undefined.
Panics
  • Panics if T has zero size.
  • Panics if len is zero.

Builds a new buffer without checking the size and granting free access for the initial upload.

Returns two things: the buffer, and a special access that should be used for the initial upload to the buffer. You will get an error if you try to use the buffer before using the initial upload access. However this function doesn’t check whether you used this initial upload to fill the buffer. You will also get an error if you try to get exclusive access to the final buffer.

Safety
  • You must ensure that the size that you pass is correct for T.
  • The ImmutableBufferInitialization should be used to fill the buffer with some initial data.
Panics
  • Panics if size is zero.

Returns the device used to create this buffer.

Returns the queue families this buffer can be used on.

Trait Implementations

Returns the inner information about this buffer.

Returns the size of the buffer in bytes.

Returns a key that uniquely identifies the buffer. Two buffers or images that potentially overlap in memory must return the same key. Read more

Locks the resource for usage on the GPU. Returns an error if the lock can’t be acquired. Read more

Locks the resource for usage on the GPU. Supposes that the resource is already locked, and simply increases the lock by one. Read more

Unlocks the resource previously acquired with try_gpu_lock or increase_gpu_lock. Read more

Returns a BufferSlice covering the whole buffer.

Returns a BufferSlice for a subrange of elements in the buffer. Returns None if out of range. Read more

Returns a BufferSlice for a single element in the buffer. Returns None if out of range. Read more

Gets the device address for this buffer. Read more

Formats the value using the given formatter. Read more

Returns the device that owns Self.

Feeds this value into the given Hasher. Read more

Feeds a slice of this type into the given Hasher. Read more

This method tests for self and other values to be equal, and is used by ==. Read more

This method tests for !=.

The type of the content.

Returns the length of the buffer in number of elements. Read more

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more

Immutably borrows from an owned value. Read more

Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.