diff options
author | zeripath <art27@cantab.net> | 2021-03-14 16:36:51 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-03-14 16:36:51 +0000 |
commit | 164e35ead3c1b9b82d4a23644f6fe96652a747eb (patch) | |
tree | 259818dbb68a5361b7f329b163ded6c124795112 | |
parent | 6463483ec5d441879037d43b0de24f5e92f927d0 (diff) | |
download | gitea-164e35ead3c1b9b82d4a23644f6fe96652a747eb.tar.gz gitea-164e35ead3c1b9b82d4a23644f6fe96652a747eb.zip |
Make sure sibling images get a link too (#14979)
* Make sure sibling images get a link too
Due a problem with the ast.Walker in the our transformer in goldmark
an image with a sibling image will not be transformed to gain a parent
link. This PR fixes this.
Fix #12925
Signed-off-by: Andrew Thornton <art27@cantab.net>
-rw-r--r-- | modules/markup/markdown/goldmark.go | 33 | ||||
-rw-r--r-- | modules/markup/markdown/markdown_test.go | 11 |
2 files changed, 43 insertions, 1 deletions
diff --git a/modules/markup/markdown/goldmark.go b/modules/markup/markdown/goldmark.go index f9fd6eb976..148067f1b0 100644 --- a/modules/markup/markdown/goldmark.go +++ b/modules/markup/markdown/goldmark.go @@ -10,6 +10,7 @@ import ( "regexp" "strings" + "code.gitea.io/gitea/modules/log" "code.gitea.io/gitea/modules/markup" "code.gitea.io/gitea/modules/markup/common" "code.gitea.io/gitea/modules/setting" @@ -101,11 +102,41 @@ func (g *ASTTransformer) Transform(node *ast.Document, reader text.Reader, pc pa parent := n.Parent() // Create a link around image only if parent is not already a link if _, ok := parent.(*ast.Link); !ok && parent != nil { + next := n.NextSibling() + + // Create a link wrapper wrap := ast.NewLink() wrap.Destination = link wrap.Title = v.Title + + // Duplicate the current image node + image := ast.NewImage(ast.NewLink()) + image.Destination = link + image.Title = v.Title + for _, attr := range v.Attributes() { + image.SetAttribute(attr.Name, attr.Value) + } + for child := v.FirstChild(); child != nil; { + next := child.NextSibling() + image.AppendChild(image, child) + child = next + } + + // Append our duplicate image to the wrapper link + wrap.AppendChild(wrap, image) + + // Wire in the next sibling + wrap.SetNextSibling(next) + + // Replace the current node with the wrapper link parent.ReplaceChild(parent, n, wrap) - wrap.AppendChild(wrap, n) + + // But most importantly ensure the next sibling is still on the old image too + v.SetNextSibling(next) + + } else { + log.Debug("ast.Image: %s has parent: %v", link, parent) + } case *ast.Link: // Links need their href to munged to be a real value diff --git a/modules/markup/markdown/markdown_test.go b/modules/markup/markdown/markdown_test.go index 89005fc25d..3196beea1f 100644 --- a/modules/markup/markdown/markdown_test.go +++ b/modules/markup/markdown/markdown_test.go @@ -308,3 +308,14 @@ func TestRender_RenderParagraphs(t *testing.T) { test(t, "A\n\nB\nC\n", 2) test(t, "A\n\n\nB\nC\n", 2) } + +func TestRenderSiblingImages_Issue12925(t *testing.T) { + testcase := `![image1](/image1) +![image2](/image2) +` + expected := `<p><a href="/image1" rel="nofollow"><img src="/image1" alt="image1"></a><br> +<a href="/image2" rel="nofollow"><img src="/image2" alt="image2"></a></p> +` + res := string(RenderRaw([]byte(testcase), "", false)) + assert.Equal(t, expected, res) +} |