mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 08:30:25 +08:00 
			
		
		
		
	Backport #14979 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>
This commit is contained in:
		@@ -10,6 +10,7 @@ import (
 | 
				
			|||||||
	"regexp"
 | 
						"regexp"
 | 
				
			||||||
	"strings"
 | 
						"strings"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"code.gitea.io/gitea/modules/log"
 | 
				
			||||||
	"code.gitea.io/gitea/modules/markup"
 | 
						"code.gitea.io/gitea/modules/markup"
 | 
				
			||||||
	"code.gitea.io/gitea/modules/markup/common"
 | 
						"code.gitea.io/gitea/modules/markup/common"
 | 
				
			||||||
	"code.gitea.io/gitea/modules/setting"
 | 
						"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()
 | 
								parent := n.Parent()
 | 
				
			||||||
			// Create a link around image only if parent is not already a link
 | 
								// Create a link around image only if parent is not already a link
 | 
				
			||||||
			if _, ok := parent.(*ast.Link); !ok && parent != nil {
 | 
								if _, ok := parent.(*ast.Link); !ok && parent != nil {
 | 
				
			||||||
 | 
									next := n.NextSibling()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									// Create a link wrapper
 | 
				
			||||||
				wrap := ast.NewLink()
 | 
									wrap := ast.NewLink()
 | 
				
			||||||
				wrap.Destination = link
 | 
									wrap.Destination = link
 | 
				
			||||||
				wrap.Title = v.Title
 | 
									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)
 | 
									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:
 | 
							case *ast.Link:
 | 
				
			||||||
			// Links need their href to munged to be a real value
 | 
								// Links need their href to munged to be a real value
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -308,3 +308,14 @@ func TestRender_RenderParagraphs(t *testing.T) {
 | 
				
			|||||||
	test(t, "A\n\nB\nC\n", 2)
 | 
						test(t, "A\n\nB\nC\n", 2)
 | 
				
			||||||
	test(t, "A\n\n\nB\nC\n", 2)
 | 
						test(t, "A\n\n\nB\nC\n", 2)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func TestRenderSiblingImages_Issue12925(t *testing.T) {
 | 
				
			||||||
 | 
						testcase := `
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					`
 | 
				
			||||||
 | 
						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)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user