Module: Sinatra::UrlForHelper
- Defined in:
- lib/sinatra/url_for.rb
Instance Method Summary collapse
- #root_url ⇒ Object
-
#url_for(url_fragment, mode = :path_only) ⇒ Object
Construct a link to
url_fragment
, which should be given relative to the base of this Sinatra app.
Instance Method Details
#root_url ⇒ Object
45 46 47 |
# File 'lib/sinatra/url_for.rb', line 45 def root_url url_for '/' end |
#url_for(url_fragment, mode = :path_only) ⇒ Object
Construct a link to url_fragment
, which should be given relative to the base of this Sinatra app. The mode should be either :path_only
, which will generate an absolute path within the current domain (the default), or :full
, which will include the site name and port number. (The latter is typically necessary for links in RSS feeds.) Example usage:
url_for "/" # Returns "/myapp/"
url_for "/foo" # Returns "/myapp/foo"
url_for "/foo", :full # Returns "http://example.com/myapp/foo"
– See README.rdoc for a list of some of the people who helped me clean up earlier versions of this code.
18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 |
# File 'lib/sinatra/url_for.rb', line 18 def url_for url_fragment, mode=:path_only case mode when :path_only base = request.script_name when :full scheme = request.scheme if (scheme == 'http' && request.port == 80 || scheme == 'https' && request.port == 443) port = "" else port = ":#{request.port}" end request_host = HOSTNAME ? HOSTNAME : request.host base = "#{scheme}://#{request_host}#{port}#{request.script_name}" else raise TypeError, "Unknown url_for mode #{mode}" end url_escape = URI.escape(url_fragment) # Don't add the base fragment if url_for gets called more than once # per url or the url_fragment passed in is an absolute url if url_escape.match(/^#{base}/) or url_escape.match(/^http/) url_escape else "#{base}#{url_escape}" end end |