StreamOwn::operator=: различия между версиями

Материал из CAMaaS preliminary wiki
Перейти к навигации Перейти к поиску
(Новая страница: «{{function_begin|StreamOwn& operator{{=}}(StreamOwn&& right); //1 template <class RightAdapterType> StreamOwn& operator{{=}}(RightAdapterType&& right); //2 |{{Str…»)
 
 
(не показаны 2 промежуточные версии этого же участника)
Строка 3: Строка 3:
StreamOwn& operator{{=}}(RightAdapterType&& right); //2
StreamOwn& operator{{=}}(RightAdapterType&& right); //2
|{{StreamOwn::operator{{=}} brief}}
|{{StreamOwn::operator{{=}} brief}}
# Оператор присваивания с перемещением, который переносит владение владение реализацией потока адаптеру {{cpp_this}}. Присваивание адаптеру разрешено, только если он не был до этого проинициализирован действительным адресом реализации потока или  был сброшен с помощью [[StreamOwn::release_ownership]] или [[StreamOwn::reset_ownership]] без параметров. В противном случае генерируются исключения - Chusov::Exceptions::UnsupportedCallException, если {{param|right}} не содержит реализации [[IStream]], и Chusov::Exceptions::InvalidParameterException - в противном случае.
# Оператор присваивания с перемещением, который переносит владение реализацией потока адаптеру {{cpp_this}}. Присваивание адаптеру разрешено, только если он не был до этого проинициализирован действительным адресом реализации потока или  был сброшен с помощью [[StreamOwn::release_ownership]] или [[StreamOwn::reset_ownership]] без параметров. В противном случае генерируются исключения - [https://www.chusov.org/doxygen/struct_chusov_1_1_exceptions_1_1_unsupported_call_exception.html Chusov::Exceptions::UnsupportedCallException], если {{param|right}} не содержит реализации [[IStream]], и [https://www.chusov.org/doxygen/struct_chusov_1_1_exceptions_1_1_invalid_parameter_exception.html Chusov::Exceptions::InvalidParameterException] - в противном случае.
# Аналогично, но с приведением типа указателя на реализацию с <source lang="cpp" inline>typename std::remove_reference_t<RightAdapterType>::interface_type*</source> к типу <source lang="cpp" inline>IStream*</source>. Данная перегрузка участвует в процедуре разрешения перегрузок, только если <source lang="cpp" inline>RightAdapterType&&</source> является rvalue-ссылкой, тип <source lang="cpp" inline>std::decay_t<RightAdapterType></source> является [[владеющий адаптер|адаптером с владением]] с подтипом <tt>interface_type</tt>, указатель на который неявно приводим к <source lang="cpp" inline>IStream*</source>.}}
# Аналогично, но с приведением типа указателя на реализацию с <source lang="cpp" inline>typename std::remove_reference_t<RightAdapterType>::interface_type*</source> к типу <source lang="cpp" inline>IStream*</source>. Данная перегрузка участвует в процедуре разрешения перегрузок, только если <source lang="cpp" inline>RightAdapterType&&</source> является rvalue-ссылкой, тип <source lang="cpp" inline>std::decay_t<RightAdapterType></source> является [[владеющий адаптер|адаптером с владением]] с подтипом <tt>interface_type</tt>, указатель на который неявно приводим к <source lang="cpp" inline>IStream*</source>.}}
{{function template paramlist begin}}
{{function template paramlist begin}}
{{function template paramlist add|RightAdapterType|Тип адаптера с владением реализацией интерфейса [[IStream]] (или неявно приводимого к нему интерфейса), которая передается экземпляру {{cpp_this}} адаптера перегрузкой 2. Тип <source lang="cpp" inline>std::decay_t<RightAdapterType></source> должен задавать адаптер с влядением через указатель, приводимый к типу <source lang="cpp" inline>IStream*</source>.}}
{{function template paramlist add|RightAdapterType|Тип адаптера с владением реализацией интерфейса [[IStream]] (или неявно приводимого к нему интерфейса), которая передается экземпляру {{cpp_this}} адаптера перегрузкой 2. Тип <source lang="cpp" inline>std::decay_t<RightAdapterType></source> должен задавать адаптер с владением через указатель, приводимый к типу <source lang="cpp" inline>IStream*</source>.}}
{{function template paramlist end}}
{{function template paramlist end}}
{{function_paramlist begin}}
{{function_paramlist begin}}
{{function_paramlist add|right|Адаптер, передающий владение своим интерфейсным указателем, если он есть, создаваемому экземпляру [[StreamOwn]], как если бы был выполнен вызов <source lang="cpp" inline>right.release_ownership()</source>.}}
{{function_paramlist add|right|Адаптер, передающий владение своим интерфейсным указателем, если он есть, создаваемому экземпляру [[StreamOwn]], как если бы был выполнен вызов <source lang="cpp" inline>right.release_ownership()</source>.}}
{{function_paramlist end}}
{{function_paramlist end}}
{{function_return_value|Ссылка на <source lang="cpp" inline>*this</source>.}}
{{function_end}}
{{function_end}}

Текущая версия на 22:06, 11 августа 2019

StreamOwn& operator=(StreamOwn&& right); //1
template <class RightAdapterType>
StreamOwn& operator=(RightAdapterType&& right); //2

Операторы присваивания адаптера с владением.

  1. Оператор присваивания с перемещением, который переносит владение реализацией потока адаптеру this. Присваивание адаптеру разрешено, только если он не был до этого проинициализирован действительным адресом реализации потока или был сброшен с помощью StreamOwn::release_ownership или StreamOwn::reset_ownership без параметров. В противном случае генерируются исключения - Chusov::Exceptions::UnsupportedCallException, если right не содержит реализации IStream, и Chusov::Exceptions::InvalidParameterException - в противном случае.
  2. Аналогично, но с приведением типа указателя на реализацию с typename std::remove_reference_t<RightAdapterType>::interface_type* к типу IStream*. Данная перегрузка участвует в процедуре разрешения перегрузок, только если RightAdapterType&& является rvalue-ссылкой, тип std::decay_t<RightAdapterType> является адаптером с владением с подтипом interface_type, указатель на который неявно приводим к IStream*.
Параметры шаблона
RightAdapterTypeТип адаптера с владением реализацией интерфейса IStream (или неявно приводимого к нему интерфейса), которая передается экземпляру this адаптера перегрузкой 2. Тип std::decay_t<RightAdapterType> должен задавать адаптер с владением через указатель, приводимый к типу IStream*.
Параметры
rightАдаптер, передающий владение своим интерфейсным указателем, если он есть, создаваемому экземпляру StreamOwn, как если бы был выполнен вызов right.release_ownership().
Возвращаемое значение:
Ссылка на *this.