[#boost-urls-segments_ref-assign-0d] = xref:boost.adoc[boost]::xref:boost/urls.adoc[urls]::xref:boost/urls/segments_ref.adoc[segments_ref]::assign :relfileprefix: ../../../ :mrdocs: Assign segments == Synopsis Declared in `<https://www.github.com/boostorg/url/blob/develop/include/boost/url/segments_ref.hpp#L342[boost/url/segments_ref.hpp]>` [source,cpp,subs="verbatim,replacements,macros,-callouts"] ---- template<class FwdIt> void assign( FwdIt first, FwdIt last); ---- == Description The existing contents are replaced by a copy of the contents of the range. Reserved characters in the range are automatically escaped. All iterators are invalidated. [NOTE] None of the character buffers referenced by the range may overlap the character buffer of the underlying url, or else the behavior is undefined. === Mandates [,cpp] ---- std::is_convertible< std::iterator_traits< FwdIt >::reference_type, core::string_view >::value == true ---- === Complexity Linear in `std::distance( first, last ) + this‐>url().encoded_query().size() + this‐>url().encoded_fragment().size()`. === Exception Safety Strong guarantee. Calls to allocate may throw. == Parameters |=== | Name | Description | *first* | The beginning of the range of segments to assign. | *last* | The end of the range of segments to assign. |=== [.small]#Created with https://www.mrdocs.com[MrDocs]#