mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	Fix wrong line number in code search result (#29260)
Fix #29136 Before: The result is a table and all line numbers are all in one row. After: Use a separate table column for the line numbers. --------- Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
This commit is contained in:
		| @@ -22,8 +22,12 @@ type Result struct { | ||||
| 	UpdatedUnix timeutil.TimeStamp | ||||
| 	Language    string | ||||
| 	Color       string | ||||
| 	LineNumbers    []int | ||||
| 	FormattedLines template.HTML | ||||
| 	Lines       []ResultLine | ||||
| } | ||||
|  | ||||
| type ResultLine struct { | ||||
| 	Num              int | ||||
| 	FormattedContent template.HTML | ||||
| } | ||||
|  | ||||
| type SearchResultLanguages = internal.SearchResultLanguages | ||||
| @@ -70,7 +74,7 @@ func searchResult(result *internal.SearchResult, startIndex, endIndex int) (*Res | ||||
| 	var formattedLinesBuffer bytes.Buffer | ||||
|  | ||||
| 	contentLines := strings.SplitAfter(result.Content[startIndex:endIndex], "\n") | ||||
| 	lineNumbers := make([]int, len(contentLines)) | ||||
| 	lines := make([]ResultLine, 0, len(contentLines)) | ||||
| 	index := startIndex | ||||
| 	for i, line := range contentLines { | ||||
| 		var err error | ||||
| @@ -93,11 +97,20 @@ func searchResult(result *internal.SearchResult, startIndex, endIndex int) (*Res | ||||
| 			return nil, err | ||||
| 		} | ||||
|  | ||||
| 		lineNumbers[i] = startLineNum + i | ||||
| 		lines = append(lines, ResultLine{Num: startLineNum + i}) | ||||
| 		index += len(line) | ||||
| 	} | ||||
|  | ||||
| 	highlighted, _ := highlight.Code(result.Filename, "", formattedLinesBuffer.String()) | ||||
| 	// we should highlight the whole code block first, otherwise it doesn't work well with multiple line highlighting | ||||
| 	hl, _ := highlight.Code(result.Filename, "", formattedLinesBuffer.String()) | ||||
| 	highlightedLines := strings.Split(string(hl), "\n") | ||||
|  | ||||
| 	// The lines outputted by highlight.Code might not match the original lines, because "highlight" removes the last `\n` | ||||
| 	lines = lines[:min(len(highlightedLines), len(lines))] | ||||
| 	highlightedLines = highlightedLines[:len(lines)] | ||||
| 	for i := 0; i < len(lines); i++ { | ||||
| 		lines[i].FormattedContent = template.HTML(highlightedLines[i]) | ||||
| 	} | ||||
|  | ||||
| 	return &Result{ | ||||
| 		RepoID:      result.RepoID, | ||||
| @@ -106,8 +119,7 @@ func searchResult(result *internal.SearchResult, startIndex, endIndex int) (*Res | ||||
| 		UpdatedUnix: result.UpdatedUnix, | ||||
| 		Language:    result.Language, | ||||
| 		Color:       result.Color, | ||||
| 		LineNumbers:    lineNumbers, | ||||
| 		FormattedLines: highlighted, | ||||
| 		Lines:       lines, | ||||
| 	}, nil | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -22,20 +22,7 @@ | ||||
| 				<a role="button" class="ui basic tiny button" rel="nofollow" href="{{$repo.Link}}/src/commit/{{$result.CommitID | PathEscape}}/{{.Filename | PathEscapeSegments}}">{{ctx.Locale.Tr "repo.diff.view_file"}}</a> | ||||
| 			</h4> | ||||
| 			<div class="ui attached table segment"> | ||||
| 				<div class="file-body file-code code-view"> | ||||
| 					<table> | ||||
| 						<tbody> | ||||
| 							<tr> | ||||
| 								<td class="lines-num"> | ||||
| 									{{range .LineNumbers}} | ||||
| 										<a href="{{$repo.Link}}/src/commit/{{$result.CommitID | PathEscape}}/{{$result.Filename | PathEscapeSegments}}#L{{.}}"><span>{{.}}</span></a> | ||||
| 									{{end}} | ||||
| 								</td> | ||||
| 								<td class="lines-code chroma"><code class="code-inner">{{.FormattedLines}}</code></td> | ||||
| 							</tr> | ||||
| 						</tbody> | ||||
| 					</table> | ||||
| 				</div> | ||||
| 				{{template "shared/searchfile" dict "RepoLink" $repo.Link "SearchResult" .}} | ||||
| 			</div> | ||||
| 			{{template "shared/searchbottom" dict "root" $ "result" .}} | ||||
| 		</div> | ||||
|   | ||||
| @@ -44,20 +44,7 @@ | ||||
| 								<a role="button" class="ui basic tiny button" rel="nofollow" href="{{$.SourcePath}}/src/commit/{{PathEscape $result.CommitID}}/{{PathEscapeSegments .Filename}}">{{ctx.Locale.Tr "repo.diff.view_file"}}</a> | ||||
| 							</h4> | ||||
| 							<div class="ui attached table segment"> | ||||
| 								<div class="file-body file-code code-view"> | ||||
| 									<table> | ||||
| 										<tbody> | ||||
| 											<tr> | ||||
| 												<td class="lines-num"> | ||||
| 													{{range .LineNumbers}} | ||||
| 														<a href="{{$.SourcePath}}/src/commit/{{PathEscape $result.CommitID}}/{{PathEscapeSegments $result.Filename}}#L{{.}}"><span>{{.}}</span></a> | ||||
| 													{{end}} | ||||
| 												</td> | ||||
| 												<td class="lines-code chroma"><code class="code-inner">{{.FormattedLines}}</code></td> | ||||
| 											</tr> | ||||
| 										</tbody> | ||||
| 									</table> | ||||
| 								</div> | ||||
| 								{{template "shared/searchfile" dict "RepoLink" $.SourcePath "SearchResult" .}} | ||||
| 							</div> | ||||
| 							{{template "shared/searchbottom" dict "root" $ "result" .}} | ||||
| 						</div> | ||||
|   | ||||
							
								
								
									
										14
									
								
								templates/shared/searchfile.tmpl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								templates/shared/searchfile.tmpl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| <div class="file-body file-code code-view"> | ||||
| 	<table> | ||||
| 		<tbody> | ||||
| 			{{range .SearchResult.Lines}} | ||||
| 				<tr> | ||||
| 					<td class="lines-num"> | ||||
| 						<a href="{{$.RepoLink}}/src/commit/{{PathEscape $.SearchResult.CommitID}}/{{PathEscapeSegments $.SearchResult.Filename}}#L{{.Num}}"><span>{{.Num}}</span></a> | ||||
| 					</td> | ||||
| 					<td class="lines-code chroma"><code class="code-inner">{{.FormattedContent}}</code></td> | ||||
| 				</tr> | ||||
| 			{{end}} | ||||
| 		</tbody> | ||||
| 	</table> | ||||
| </div> | ||||
		Reference in New Issue
	
	Block a user