[#boost-urls-segments_encoded_ref-assign] = xref:boost.adoc[boost]::xref:boost/urls.adoc[urls]::xref:boost/urls/segments_encoded_ref.adoc[segments_encoded_ref]::assign :relfileprefix: ../../../ :mrdocs: Assign segments == Synopsis Declared in `<https://www.github.com/boostorg/url/blob/develop/include/boost/url/segments_encoded_ref.hpp#L320[boost/url/segments_encoded_ref.hpp]>` [source,cpp,subs="verbatim,replacements,macros,-callouts"] ---- void xref:boost/urls/segments_encoded_ref/assign-0e.adoc[assign](std::initializer_list<xref:boost/urls/pct_string_view.adoc[pct_string_view]> init); ---- [.small]#xref:boost/urls/segments_encoded_ref/assign-0e.adoc[_» more..._]# [source,cpp,subs="verbatim,replacements,macros,-callouts"] ---- template<class FwdIt> void xref:boost/urls/segments_encoded_ref/assign-0b.adoc[assign]( FwdIt first, FwdIt last); ---- [.small]#xref:boost/urls/segments_encoded_ref/assign-0b.adoc[_» more..._]# == Description The existing contents are replaced by a copy of the contents of the initializer list. Reserved characters in the list are automatically escaped. Escapes in the list are preserved. All iterators are invalidated. [NOTE] None of the character buffers referenced by the list may overlap the character buffer of the underlying url, or else the behavior is undefined. === Example [,cpp] ---- url u; u.segments().assign( {"path", "to", "file.txt"} ); ---- === Complexity Linear in `init.size() + this‐>url().encoded_query().size() + this‐>url().encoded_fragment().size()`. === Exception Safety Strong guarantee. Calls to allocate may throw. Exceptions thrown on invalid input. == Exceptions |=== | Name | Thrown on | `system_error` | The list contains an invalid percent‐encoding. |=== == Parameters |=== | Name | Description | *init* | The list of segments to assign. | *first* | The first element in the range. | *last* | One past the last element in the range. |=== [.small]#Created with https://www.mrdocs.com[MrDocs]#