diff --git a/app/helpers/gitlab_markdown_helper.rb b/app/helpers/gitlab_markdown_helper.rb index ae6ba46ffb7704767a103fe5bf519866cd53004f..1ec82cd57014167759726f7548777db8a188141c 100644 --- a/app/helpers/gitlab_markdown_helper.rb +++ b/app/helpers/gitlab_markdown_helper.rb @@ -59,10 +59,10 @@ module GitlabMarkdownHelper end end - def create_relative_links(text, project_path_with_namespace) - to_be_fixed = text.split("\n").map { |a| a.scan(/\]\(([^(]+)\)/) }.reject{|b| b.empty? }.flatten.reject{|c| c.include?("http" || "www")} - to_be_fixed.each do |string| - text.gsub!(string, "/#{project_path_with_namespace}/blob/master/#{string}") + def create_relative_links(text, project_path_with_namespace, ref) + links = text.split("\n").map { |a| a.scan(/\]\(([^(]+)\)/) }.reject{|b| b.empty? }.flatten.reject{|c| c.include?("http" || "www")} + links.each do |string| + text.gsub!(string, "/#{project_path_with_namespace}/blob/#{ref}/#{string}") end text end diff --git a/lib/redcarpet/render/gitlab_html.rb b/lib/redcarpet/render/gitlab_html.rb index c0e858bab7dc27851556de6c5b0f2e62f7c14278..2277caef953154013431a7785a746bc4ced9b899 100644 --- a/lib/redcarpet/render/gitlab_html.rb +++ b/lib/redcarpet/render/gitlab_html.rb @@ -6,6 +6,7 @@ class Redcarpet::Render::GitlabHTML < Redcarpet::Render::HTML def initialize(template, options = {}) @template = template @project = @template.instance_variable_get("@project") + @ref = @template.instance_variable_get("@ref") super options end @@ -33,7 +34,7 @@ class Redcarpet::Render::GitlabHTML < Redcarpet::Render::HTML end def preprocess(full_document) - h.create_relative_links(full_document, @project.path_with_namespace) + h.create_relative_links(full_document, @project.path_with_namespace, @ref) end def postprocess(full_document)