[#boost-urls-segments_view-2constructor-0e] = xref:boost.adoc[boost]::xref:boost/urls.adoc[urls]::xref:boost/urls/segments_view.adoc[segments_view]::segments_view :relfileprefix: ../../../ :mrdocs: Constructor == Synopsis Declared in `<https://www.github.com/boostorg/url/blob/develop/include/boost/url/segments_view.hpp#L163[boost/url/segments_view.hpp]>` [source,cpp,subs="verbatim,replacements,macros,-callouts"] ---- segments_view(core::string_view s); ---- == Description This function constructs segments from a valid path string, which can contain percent escapes. Upon construction, the view references the character buffer pointed to by `s`. caller is responsible for ensuring that the lifetime of the buffer extends until the view is destroyed. === Example [,cpp] ---- segments_view ps( "/path/to/file.txt" ); ---- === Effects [,cpp] ---- return parse_path( s ).value(); ---- === Postconditions [,cpp] ---- this->buffer().data() == s.data() ---- === Complexity Linear in `s`. === Exception Safety Exceptions thrown on invalid input. === BNF [,cpp] ---- path = [ "/" ] [ segment *( "/" segment ) ] segment = *pchar ---- === Specification * link:https://datatracker.ietf.org/doc/html/rfc3986#section-3.3[3.3. Path] Constructor This function constructs segments from a valid path string, which can contain percent escapes. Upon construction, the view references the character buffer pointed to by `s`. caller is responsible for ensuring that the lifetime of the buffer extends until the view is destroyed. === Example [,cpp] ---- segments_view ps( "/path/to/file.txt" ); ---- === Effects [,cpp] ---- return parse_path( s ).value(); ---- === Postconditions [,cpp] ---- this->buffer().data() == s.data() ---- === Complexity Linear in `s`. === Exception Safety Exceptions thrown on invalid input. === BNF [,cpp] ---- path = [ "/" ] [ segment *( "/" segment ) ] segment = *pchar ---- === Specification * link:https://datatracker.ietf.org/doc/html/rfc3986#section-3.3[3.3. Path] == Exceptions |=== | Name | Thrown on | `system_error` | `s` contains an invalid path. | `system_error` | `s` contains an invalid path. |=== == Parameters |=== | Name | Description | *s* | The string to parse. | *s* | The string to parse. |=== [.small]#Created with https://www.mrdocs.com[MrDocs]#