class opaque_container_output_resource


template <
    typename Container
>
class opaque_container_output_resource
    : public virtual seekable_output_resource<std::int64_t>
    , public virtual impl::ctr_essence<Container>

Description

An opaque container output resource is an output resource that writes to a container that it owns.

Public Aliases

using content_type = Container

The type of content referenced by this opaque container output resource.

using element_type = typename Container::value_type

The type of element of the content referenced by this opaque container output resource.

Public Member Functions

explicit
opaque_container_output_resource (
    std::size_t buffer_capacity = 0
)

Constructs an opaque container output resource with the given buffer capacity and a default-constructed content object.

Parameters:
  • buffer_capacity:

    The capacity of the I/O buffer. If this is zero, the opaque container output resource is completely unbuffered.

explicit
opaque_container_output_resource (
    const content_type& initial_content,
    std::size_t buffer_capacity = 0
)

Constructs an opaque container output resource with the given initial content and buffer capacity.

Parameters:
  • initial_content:

    The content that this opaque container output resource will reference.

  • buffer_capacity:

    The capacity of the I/O buffer. If this is zero, the opaque container output resource is completely unbuffered.

explicit
opaque_container_output_resource (
    content_type&& initial_content,
    std::size_t buffer_capacity = 0
)

Constructs an opaque container output resource with the given initial content and buffer capacity.

Parameters:
  • initial_content:

    The content that this opaque container output resource will reference.

  • buffer_capacity:

    The capacity of the I/O buffer. If this is zero, the opaque container output resource is completely unbuffered.

opaque_container_output_resource (
    const opaque_container_output_resource& other
)

Copy-constructs an opaque_container_output_resource from an existing one.

Parameters:
  • other:

    The opaque_container_output_resource to copy from.

opaque_container_output_resource&
operator = (
    const opaque_container_output_resource& other
)

Copy-assigns an opaque_container_output_resource into this one.

Parameters:
  • other:

    The opaque_container_output_resource to copy from.

opaque_container_output_resource (
    opaque_container_output_resource&& other
)
noexcept

Move-constructs an opaque_container_output_resource from an existing one.

Parameters:
  • other:

    The opaque_container_output_resource to move from.

opaque_container_output_resource&
operator = (
    opaque_container_output_resource&& other
)
noexcept

Move-assigns an opaque_container_output_resource into this one.

Parameters:
  • other:

    The opaque_container_output_resource to move from.

bool
is_at_end ()
const noexcept override

Returns true if this opaque container output resource is at the end of its referenced content. Otherwise, returns false.

std::int64_t
get_position ()
const noexcept override

Returns the position this opaque container output resource is at, that is, the position at which write operations will take place next.

content_type&
grab_content ()
noexcept

Returns a non-constant reference to the referenced content.

const content_type&
grab_content ()
const noexcept

Returns a constant reference to the referenced content.

Protected Member Functions

void
set_position_raw (
    std::int64_t new_position,
    position_reference pr
)
noexcept override
std::size_t
write_raw (
    const std::byte* data,
    std::size_t byte_count
)
override

Writes byte_count bytes from the data array to this opaque container output resource.

Parameters:
  • data:

    The array of bytes that will be written to this output resource.

  • byte_count:

    The number of bytes to write to this output resource.



Copyright © 2022-2025 Daniel T. McGinnis

CCL was first published in 2022, and is still actively maintained.

This website was first published in 2022, and is still actively maintained.

This specific web page was first published in 2023.