Difference between revisions of "Module:URL"
		
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
		
		
		
		
		
		
		
	
| imported>Toohool  (use unicode string functions) | imported>Toohool   (fix handling of port numbers and unencoded spaces) | ||
| Line 20: | Line 20: | ||
|          end |          end | ||
|      end |      end | ||
| + | |||
| + |     -- If the URL contains any unencoded spaces, encode them, because MediaWiki will otherwise interpret a space as the end of the URL. | ||
| + |     url = mw.ustring.gsub(url, '%s', function(s) return mw.uri.encode(s, 'PATH') end) | ||
|      local uri = mw.uri.new(url) |      local uri = mw.uri.new(url) | ||
| − |      if uri.protocol  | + | |
| + |     -- Handle URL's without a protocol, e.g. www.example.com/foo or www.example.com:8080/foo | ||
| + |      if not uri.protocol or (uri.protocol and not uri.host) then | ||
|          url = 'http://' .. url |          url = 'http://' .. url | ||
|          uri = mw.uri.new(url) |          uri = mw.uri.new(url) | ||
| Line 30: | Line 35: | ||
|          if uri.path == '/' then uri.path = '' end |          if uri.path == '/' then uri.path = '' end | ||
| − |          text = mw.ustring.lower(uri.host or '') .. uri.relativePath | + |         local port = '' | 
| + |         if uri.port then port = ':' .. uri.port end | ||
| + | |||
| + |          text = mw.ustring.lower(uri.host or '') .. port .. uri.relativePath | ||
|      end |      end | ||
Revision as of 21:17, 26 February 2013
Documentation for this module may be created at Module:URL/doc
--
-- This module implements {{URL}}
--
local p = {}
 
function trim(s)
    return (mw.ustring.gsub(s, "^%s*(.-)%s*$", "%1"))
end
function p._url(url, text)
    url = trim(url or '')
    text = trim(text or '')
    
    if url == '' then
        if text == '' then
            return mw.getCurrentFrame():expandTemplate{ title = 'tlx', args = { 'URL', "''example.com''", "''optional display text''" } }
        else
            return text
        end
    end
    
    -- If the URL contains any unencoded spaces, encode them, because MediaWiki will otherwise interpret a space as the end of the URL.
    url = mw.ustring.gsub(url, '%s', function(s) return mw.uri.encode(s, 'PATH') end)
    
    local uri = mw.uri.new(url)
    
    -- Handle URL's without a protocol, e.g. www.example.com/foo or www.example.com:8080/foo
    if not uri.protocol or (uri.protocol and not uri.host) then
        url = 'http://' .. url
        uri = mw.uri.new(url)
    end
    
    if text == '' then
        if uri.path == '/' then uri.path = '' end
        
        local port = ''
        if uri.port then port = ':' .. uri.port end
        
        text = mw.ustring.lower(uri.host or '') .. port .. uri.relativePath
    end
    return mw.ustring.format('<span class="url">[%s %s]</span>', url, text)
end
function p.url(frame)
    local templateArgs = frame:getParent().args
    local url = templateArgs[1] or ''
    local text = templateArgs[2] or ''
    return p._url(url, text)
end
return p

