@ -123,13 +123,13 @@ class Flask(_PackageBoundObject):
. . versionadded : : 0.11
. . versionadded : : 0.11
The ` root_path ` parameter was added .
The ` root_path ` parameter was added .
. . versionadded : : 0.13
. . versionadded : : 1. 0
The ` host_matching ` and ` static_host ` parameters were added .
The ` ` host_matching ` ` and ` ` static_host ` ` parameters were added .
. . versionadded : : 1.0
. . versionadded : : 1.0
The ` subdomain_matching ` parameter was added . Subdomain matching
The ` ` subdomain_matching ` ` parameter was added . Subdomain
needs to be enabled manually now . Setting ` SERVER_NAME ` does not
matching needs to be enabled manually now . Setting
implicitly enable it .
: data : ` SERVER_NAME ` does not implicitly enable it .
: param import_name : the name of the application package
: param import_name : the name of the application package
: param static_url_path : can be used to specify a different path for the
: param static_url_path : can be used to specify a different path for the
@ -138,11 +138,13 @@ class Flask(_PackageBoundObject):
: param static_folder : the folder with static files that should be served
: param static_folder : the folder with static files that should be served
at ` static_url_path ` . Defaults to the ` ` ' static ' ` `
at ` static_url_path ` . Defaults to the ` ` ' static ' ` `
folder in the root path of the application .
folder in the root path of the application .
: param host_matching : sets the app ' s ``url_map.host_matching`` to the given
: param static_host : the host to use when adding the static route .
value . Defaults to False .
Defaults to None . Required when using ` ` host_matching = True ` `
: param static_host : the host to use when adding the static route . Defaults
with a ` ` static_folder ` ` configured .
to None . Required when using ` ` host_matching = True ` `
: param host_matching : set ` ` url_map . host_matching ` ` attribute .
with a ` ` static_folder ` ` configured .
Defaults to False .
: param subdomain_matching : consider the subdomain relative to
: data : ` SERVER_NAME ` when matching routes . Defaults to False .
: param template_folder : the folder that contains the templates that should
: param template_folder : the folder that contains the templates that should
be used by the application . Defaults to
be used by the application . Defaults to
` ` ' templates ' ` ` folder in the root path of the
` ` ' templates ' ` ` folder in the root path of the
@ -1984,26 +1986,30 @@ class Flask(_PackageBoundObject):
return rv
return rv
def create_url_adapter ( self , request ) :
def create_url_adapter ( self , request ) :
""" Creates a URL adapter for the given request. The URL adapter
""" Creates a URL adapter for the given request. The URL adapter
is created at a point where the request context is not yet set up
is created at a point where the request context is not yet set
so the request is passed explicitly .
up so the request is passed explicitly .
. . versionadded : : 0.6
. . versionadded : : 0.6
. . versionchanged : : 0.9
. . versionchanged : : 0.9
This can now also be called without a request object when the
This can now also be called without a request object when the
URL adapter is created for the application context .
URL adapter is created for the application context .
. . versionchanged : : 1.0
: data : ` SERVER_NAME ` no longer implicitly enables subdomain
matching . Use : attr : ` subdomain_matching ` instead .
"""
"""
if request is not None :
if request is not None :
rv = self . url_map . bind_to_environ ( request . environ ,
# If subdomain matching is disabled (the default), use the
server_name = self . config [ ' SERVER_NAME ' ] )
# default subdomain in all cases. This should be the default
# If subdomain matching is not enabled (which is the default
# in Werkzeug but it currently does not have that feature.
# we put back the default subdomain in all cases. This really
subdomain = ( ( self . url_map . default_subdomain or None )
# should be the default in Werkzeug but it currently does not
if not self . subdomain_matching else None )
# have that feature.
return self . url_map . bind_to_environ (
if not self . subdomain_matching :
request . environ ,
rv . subdomain = self . url_map . default_subdomain
server_name = self . config [ ' SERVER_NAME ' ] ,
return rv
subdomain = subdomain )
# We need at the very least the server name to be set for this
# We need at the very least the server name to be set for this
# to work.
# to work.
if self . config [ ' SERVER_NAME ' ] is not None :
if self . config [ ' SERVER_NAME ' ] is not None :