mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-04 07:27:33 -05:00 
			
		
		
		
	Server-side syntax highlighting for all code (#12047)
* Server-side syntax hilighting for all code This PR does a few things: * Remove all traces of highlight.js * Use chroma library to provide fast syntax hilighting directly on the server * Provide syntax hilighting for diffs * Re-style both unified and split diffs views * Add custom syntax hilighting styling for both regular and arc-green Fixes #7729 Fixes #10157 Fixes #11825 Fixes #7728 Fixes #3872 Fixes #3682 And perhaps gets closer to #9553 * fix line marker * fix repo search * Fix single line select * properly load settings * npm uninstall highlight.js * review suggestion * code review * forgot to call function * fix test * Apply suggestions from code review suggestions from @silverwind thanks Co-authored-by: silverwind <me@silverwind.io> * code review * copy/paste error * Use const for highlight size limit * Update web_src/less/_repository.less Co-authored-by: Lauris BH <lauris@nix.lv> * update size limit to 1MB and other styling tweaks * fix highlighting for certain diff sections * fix test * add worker back as suggested Co-authored-by: silverwind <me@silverwind.io> Co-authored-by: Lauris BH <lauris@nix.lv>
This commit is contained in:
		@@ -15,6 +15,8 @@ import (
 | 
			
		||||
	"code.gitea.io/gitea/modules/git"
 | 
			
		||||
	"code.gitea.io/gitea/modules/setting"
 | 
			
		||||
 | 
			
		||||
	"gopkg.in/ini.v1"
 | 
			
		||||
 | 
			
		||||
	dmp "github.com/sergi/go-diff/diffmatchpatch"
 | 
			
		||||
	"github.com/stretchr/testify/assert"
 | 
			
		||||
)
 | 
			
		||||
@@ -26,14 +28,15 @@ func assertEqual(t *testing.T, s1 string, s2 template.HTML) {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func TestDiffToHTML(t *testing.T) {
 | 
			
		||||
	assertEqual(t, "foo <span class=\"added-code\">bar</span> biz", diffToHTML([]dmp.Diff{
 | 
			
		||||
	setting.Cfg = ini.Empty()
 | 
			
		||||
	assertEqual(t, "foo <span class=\"added-code\">bar</span> biz", diffToHTML("", []dmp.Diff{
 | 
			
		||||
		{Type: dmp.DiffEqual, Text: "foo "},
 | 
			
		||||
		{Type: dmp.DiffInsert, Text: "bar"},
 | 
			
		||||
		{Type: dmp.DiffDelete, Text: " baz"},
 | 
			
		||||
		{Type: dmp.DiffEqual, Text: " biz"},
 | 
			
		||||
	}, DiffLineAdd))
 | 
			
		||||
 | 
			
		||||
	assertEqual(t, "foo <span class=\"removed-code\">bar</span> biz", diffToHTML([]dmp.Diff{
 | 
			
		||||
	assertEqual(t, "foo <span class=\"removed-code\">bar</span> biz", diffToHTML("", []dmp.Diff{
 | 
			
		||||
		{Type: dmp.DiffEqual, Text: "foo "},
 | 
			
		||||
		{Type: dmp.DiffDelete, Text: "bar"},
 | 
			
		||||
		{Type: dmp.DiffInsert, Text: " baz"},
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user