diff options
author | Marius Balteanu <marius.balteanu@zitec.com> | 2021-10-20 22:18:49 +0000 |
---|---|---|
committer | Marius Balteanu <marius.balteanu@zitec.com> | 2021-10-20 22:18:49 +0000 |
commit | 7125fd70cebea60b4e692c33b37bd0ea71c6ffbf (patch) | |
tree | d0970cfae92c0f6f6a023bc1729c3cb5f41002ff /lib/redmine/wiki_formatting.rb | |
parent | a256addaf79a6bc8edb77874145c21a312a2b8e3 (diff) | |
download | redmine-7125fd70cebea60b4e692c33b37bd0ea71c6ffbf.tar.gz redmine-7125fd70cebea60b4e692c33b37bd0ea71c6ffbf.zip |
Split multiple classes and modules that existed in the same file (#29914, #32938).
Patch by Mizuki ISHIKAWA.
git-svn-id: http://svn.redmine.org/redmine/trunk@21252 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'lib/redmine/wiki_formatting.rb')
-rw-r--r-- | lib/redmine/wiki_formatting.rb | 83 |
1 files changed, 0 insertions, 83 deletions
diff --git a/lib/redmine/wiki_formatting.rb b/lib/redmine/wiki_formatting.rb index 99058462b..471082edc 100644 --- a/lib/redmine/wiki_formatting.rb +++ b/lib/redmine/wiki_formatting.rb @@ -115,89 +115,6 @@ module Redmine end end - module LinksHelper - AUTO_LINK_RE = %r{ - ( # leading text - <\w+[^>]*?>| # leading HTML tag, or - [\s\(\[,;]| # leading punctuation, or - ^ # beginning of line - ) - ( - (?:https?://)| # protocol spec, or - (?:s?ftps?://)| - (?:www\.) # www.* - ) - ( - ([^<]\S*?) # url - (\/)? # slash - ) - ((?:>)?|[^[:alnum:]_\=\/;\(\)\-]*?) # post - (?=<|\s|$) - }x unless const_defined?(:AUTO_LINK_RE) - - # Destructively replaces urls into clickable links - def auto_link!(text) - text.gsub!(AUTO_LINK_RE) do - all, leading, proto, url, post = $&, $1, $2, $3, $6 - if /<a\s/i.match?(leading) || /![<>=]?/.match?(leading) - # don't replace URLs that are already linked - # and URLs prefixed with ! !> !< != (textile images) - all - else - # Idea below : an URL with unbalanced parenthesis and - # ending by ')' is put into external parenthesis - if url[-1] == ")" and ((url.count("(") - url.count(")")) < 0) - url = url[0..-2] # discard closing parenthesis from url - post = ")" + post # add closing parenthesis to post - end - content = proto + url - href = "#{proto=="www."?"http://www.":proto}#{url}" - %(#{leading}<a class="external" href="#{ERB::Util.html_escape href}">#{ERB::Util.html_escape content}</a>#{post}).html_safe - end - end - end - - # Destructively replaces email addresses into clickable links - def auto_mailto!(text) - text.gsub!(/([\w\.!#\$%\-+.\/]+@[A-Za-z0-9\-]+(\.[A-Za-z0-9\-]+)+)/) do - mail = $1 - if /<a\b[^>]*>(.*)(#{Regexp.escape(mail)})(.*)<\/a>/.match?(text) - mail - else - %(<a class="email" href="mailto:#{ERB::Util.html_escape mail}">#{ERB::Util.html_escape mail}</a>).html_safe - end - end - end - - def restore_redmine_links(html) - # restore wiki links eg. [[Foo]] - html.gsub!(%r{\[<a href="(.*?)">(.*?)</a>\]}) do - "[[#{$2}]]" - end - # restore Redmine links with double-quotes, eg. version:"1.0" - html.gsub!(/(\w):"(.+?)"/) do - "#{$1}:\"#{$2}\"" - end - # restore user links with @ in login name eg. [@jsmith@somenet.foo] - html.gsub!(%r{[@\A]<a(\sclass="email")? href="mailto:(.*?)">(.*?)</a>}) do - "@#{$2}" - end - # restore user links with @ in login name eg. [user:jsmith@somenet.foo] - html.gsub!(%r{\buser:<a(\sclass="email")? href="mailto:(.*?)">(.*?)<\/a>}) do - "user:#{$2}" - end - # restore attachments links with @ in file name eg. [attachment:image@2x.png] - html.gsub!(%r{\battachment:<a(\sclass="email")? href="mailto:(.*?)">(.*?)</a>}) do - "attachment:#{$2}" - end - # restore hires images which are misrecognized as email address eg. [printscreen@2x.png] - html.gsub!(%r{<a(\sclass="email")? href="mailto:[^"]+@\dx\.(bmp|gif|jpg|jpe|jpeg|png)">(.*?)</a>}) do - "#{$3}" - end - html - end - end - # Default formatter module module NullFormatter class Formatter |