[#boost-urls-url_view_base-scheme_id]
= xref:boost.adoc[boost]::xref:boost/urls.adoc[urls]::xref:boost/urls/url_view_base.adoc[url_view_base]::scheme_id
:relfileprefix: ../../../
:mrdocs:


Return the scheme

== Synopsis


Declared in `<https://www.github.com/boostorg/url/blob/develop/include/boost/url/url_view_base.hpp#L435[boost/url/url_view_base.hpp]>`

[source,cpp,subs="verbatim,replacements,macros,-callouts"]
----
xref:boost/urls.adoc[urls]::xref:boost/urls/scheme.adoc[scheme]
scheme_id() const noexcept;
----

== Description


This function returns a value which        depends on the scheme in the url:

* If the scheme is a well‐known        scheme, corresponding value from
        the enumeration 
urls::scheme
        is returned.
* If a scheme is present but is not        a well‐known scheme, the value
        returned is 
urls::scheme::unknown
.
* Otherwise, if the scheme is absent        the value returned is
        
urls::scheme::none
.


=== Example

[,cpp]
----
assert( url_view( "wss://www.example.com/crypto.cgi" ).scheme_id() == scheme::wss );
----

=== Complexity

Constant.


=== Exception Safety

Throws nothing.


=== BNF

[,cpp]
----
URI             = scheme ":" hier-part [ "?" query ] [ "#" fragment ]

absolute-URI    = scheme ":" hier-part [ "?" query ]

scheme          = ALPHA *( ALPHA / DIGIT / "+" / "-" / "." )
----

=== Specification

* link:https://datatracker.ietf.org/doc/html/rfc3986#section-3.1[3.1. Scheme (rfc3986)]



== See Also


xref:boost/urls/url_view_base/has_scheme.adoc[has_scheme],            xref:boost/urls/url_view_base/scheme.adoc[scheme].






[.small]#Created with https://www.mrdocs.com[MrDocs]#