mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-26 06:20:48 +01:00 
			
		
		
		
	This PR removes (almost) all path tricks, and introduces "renderhelper" package. Now we can clearly see the rendering behaviors for comment/file/wiki, more details are in "renderhelper" tests. Fix #31411 , fix #18592, fix #25632 and maybe more problems. (ps: fix #32608 by the way)
		
			
				
	
	
		
			78 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2024 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package renderhelper
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"fmt"
 | |
| 	"path"
 | |
| 
 | |
| 	repo_model "code.gitea.io/gitea/models/repo"
 | |
| 	"code.gitea.io/gitea/modules/markup"
 | |
| 	"code.gitea.io/gitea/modules/util"
 | |
| )
 | |
| 
 | |
| type RepoFile struct {
 | |
| 	ctx  *markup.RenderContext
 | |
| 	opts RepoFileOptions
 | |
| 
 | |
| 	commitChecker *commitChecker
 | |
| 	repoLink      string
 | |
| }
 | |
| 
 | |
| func (r *RepoFile) CleanUp() {
 | |
| 	_ = r.commitChecker.Close()
 | |
| }
 | |
| 
 | |
| func (r *RepoFile) IsCommitIDExisting(commitID string) bool {
 | |
| 	return r.commitChecker.IsCommitIDExisting(commitID)
 | |
| }
 | |
| 
 | |
| func (r *RepoFile) ResolveLink(link string, likeType markup.LinkType) string {
 | |
| 	finalLink := link
 | |
| 	switch likeType {
 | |
| 	case markup.LinkTypeApp:
 | |
| 		finalLink = r.ctx.ResolveLinkApp(link)
 | |
| 	case markup.LinkTypeDefault:
 | |
| 		finalLink = r.ctx.ResolveLinkRelative(path.Join(r.repoLink, "src", r.opts.CurrentRefPath), r.opts.CurrentTreePath, link)
 | |
| 	case markup.LinkTypeRaw:
 | |
| 		finalLink = r.ctx.ResolveLinkRelative(path.Join(r.repoLink, "raw", r.opts.CurrentRefPath), r.opts.CurrentTreePath, link)
 | |
| 	case markup.LinkTypeMedia:
 | |
| 		finalLink = r.ctx.ResolveLinkRelative(path.Join(r.repoLink, "media", r.opts.CurrentRefPath), r.opts.CurrentTreePath, link)
 | |
| 	}
 | |
| 	return finalLink
 | |
| }
 | |
| 
 | |
| var _ markup.RenderHelper = (*RepoFile)(nil)
 | |
| 
 | |
| type RepoFileOptions struct {
 | |
| 	DeprecatedRepoName  string // it is only a patch for the non-standard "markup" api
 | |
| 	DeprecatedOwnerName string // it is only a patch for the non-standard "markup" api
 | |
| 
 | |
| 	CurrentRefPath  string // eg: "branch/main"
 | |
| 	CurrentTreePath string // eg: "path/to/file" in the repo
 | |
| }
 | |
| 
 | |
| func NewRenderContextRepoFile(ctx context.Context, repo *repo_model.Repository, opts ...RepoFileOptions) *markup.RenderContext {
 | |
| 	helper := &RepoFile{opts: util.OptionalArg(opts)}
 | |
| 	rctx := markup.NewRenderContext(ctx)
 | |
| 	helper.ctx = rctx
 | |
| 	if repo != nil {
 | |
| 		helper.repoLink = repo.Link()
 | |
| 		helper.commitChecker = newCommitChecker(ctx, repo)
 | |
| 		rctx = rctx.WithMetas(repo.ComposeDocumentMetas(ctx))
 | |
| 	} else {
 | |
| 		// this is almost dead code, only to pass the incorrect tests
 | |
| 		helper.repoLink = fmt.Sprintf("%s/%s", helper.opts.DeprecatedOwnerName, helper.opts.DeprecatedRepoName)
 | |
| 		rctx = rctx.WithMetas(map[string]string{
 | |
| 			"user": helper.opts.DeprecatedOwnerName,
 | |
| 			"repo": helper.opts.DeprecatedRepoName,
 | |
| 
 | |
| 			"markdownLineBreakStyle": "document",
 | |
| 		})
 | |
| 	}
 | |
| 	rctx = rctx.WithHelper(helper)
 | |
| 	return rctx
 | |
| }
 |