* 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>
		
			
				
	
	
		
			44 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package styles
 | |
| 
 | |
| import (
 | |
| 	"github.com/alecthomas/chroma"
 | |
| )
 | |
| 
 | |
| // Autumn style.
 | |
| var Autumn = Register(chroma.MustNewStyle("autumn", chroma.StyleEntries{
 | |
| 	chroma.TextWhitespace:      "#bbbbbb",
 | |
| 	chroma.Comment:             "italic #aaaaaa",
 | |
| 	chroma.CommentPreproc:      "noitalic #4c8317",
 | |
| 	chroma.CommentSpecial:      "italic #0000aa",
 | |
| 	chroma.Keyword:             "#0000aa",
 | |
| 	chroma.KeywordType:         "#00aaaa",
 | |
| 	chroma.OperatorWord:        "#0000aa",
 | |
| 	chroma.NameBuiltin:         "#00aaaa",
 | |
| 	chroma.NameFunction:        "#00aa00",
 | |
| 	chroma.NameClass:           "underline #00aa00",
 | |
| 	chroma.NameNamespace:       "underline #00aaaa",
 | |
| 	chroma.NameVariable:        "#aa0000",
 | |
| 	chroma.NameConstant:        "#aa0000",
 | |
| 	chroma.NameEntity:          "bold #800",
 | |
| 	chroma.NameAttribute:       "#1e90ff",
 | |
| 	chroma.NameTag:             "bold #1e90ff",
 | |
| 	chroma.NameDecorator:       "#888888",
 | |
| 	chroma.LiteralString:       "#aa5500",
 | |
| 	chroma.LiteralStringSymbol: "#0000aa",
 | |
| 	chroma.LiteralStringRegex:  "#009999",
 | |
| 	chroma.LiteralNumber:       "#009999",
 | |
| 	chroma.GenericHeading:      "bold #000080",
 | |
| 	chroma.GenericSubheading:   "bold #800080",
 | |
| 	chroma.GenericDeleted:      "#aa0000",
 | |
| 	chroma.GenericInserted:     "#00aa00",
 | |
| 	chroma.GenericError:        "#aa0000",
 | |
| 	chroma.GenericEmph:         "italic",
 | |
| 	chroma.GenericStrong:       "bold",
 | |
| 	chroma.GenericPrompt:       "#555555",
 | |
| 	chroma.GenericOutput:       "#888888",
 | |
| 	chroma.GenericTraceback:    "#aa0000",
 | |
| 	chroma.GenericUnderline:    "underline",
 | |
| 	chroma.Error:               "#F00 bg:#FAA",
 | |
| 	chroma.Background:          " bg:#ffffff",
 | |
| }))
 |