refactor: move image to module

This commit is contained in:
Jan De Dobbeleer 2024-07-02 10:58:24 +02:00 committed by Jan De Dobbeleer
parent ee9bdf4761
commit ad10da8cc9
3 changed files with 17 additions and 16 deletions

View file

@ -4,6 +4,7 @@ import (
"fmt" "fmt"
"github.com/jandedobbeleer/oh-my-posh/src/config" "github.com/jandedobbeleer/oh-my-posh/src/config"
"github.com/jandedobbeleer/oh-my-posh/src/image"
"github.com/jandedobbeleer/oh-my-posh/src/platform" "github.com/jandedobbeleer/oh-my-posh/src/platform"
"github.com/jandedobbeleer/oh-my-posh/src/prompt" "github.com/jandedobbeleer/oh-my-posh/src/prompt"
"github.com/jandedobbeleer/oh-my-posh/src/shell" "github.com/jandedobbeleer/oh-my-posh/src/shell"
@ -79,7 +80,7 @@ Exports the config to an image file using customized output options.`,
primaryPrompt := eng.Primary() primaryPrompt := eng.Primary()
imageCreator := &prompt.ImageRenderer{ imageCreator := &image.Renderer{
AnsiString: primaryPrompt, AnsiString: primaryPrompt,
Author: author, Author: author,
BgColor: bgColor, BgColor: bgColor,

View file

@ -20,7 +20,7 @@
// https://github.com/homeport/termshot // https://github.com/homeport/termshot
package prompt package image
import ( import (
"archive/zip" "archive/zip"
@ -108,7 +108,7 @@ func NewRGBColor(ansiColor string) *RGB {
} }
} }
type ImageRenderer struct { type Renderer struct {
AnsiString string AnsiString string
Author string Author string
CursorPadding int CursorPadding int
@ -147,7 +147,7 @@ type ImageRenderer struct {
ansiSequenceRegexMap map[string]string ansiSequenceRegexMap map[string]string
} }
func (ir *ImageRenderer) Init(env platform.Environment) error { func (ir *Renderer) Init(env platform.Environment) error {
ir.env = env ir.env = env
if ir.Path == "" { if ir.Path == "" {
@ -206,7 +206,7 @@ func (ir *ImageRenderer) Init(env platform.Environment) error {
return nil return nil
} }
func (ir *ImageRenderer) loadFonts() error { func (ir *Renderer) loadFonts() error {
var data []byte var data []byte
fontCachePath := filepath.Join(ir.env.CachePath(), "Hack.zip") fontCachePath := filepath.Join(ir.env.CachePath(), "Hack.zip")
@ -283,7 +283,7 @@ func (ir *ImageRenderer) loadFonts() error {
return nil return nil
} }
func (ir *ImageRenderer) fontHeight() float64 { func (ir *Renderer) fontHeight() float64 {
return float64(ir.regular.Metrics().Height >> 6) return float64(ir.regular.Metrics().Height >> 6)
} }
@ -329,7 +329,7 @@ var doubleWidthRunes = []RuneRange{
// This is getting how many additional characters of width to allocate when drawing // This is getting how many additional characters of width to allocate when drawing
// e.g. for characters that are 2 or more wide. A standard character will return 0 // e.g. for characters that are 2 or more wide. A standard character will return 0
// Nerd Font glyphs will return 1, since most are double width // Nerd Font glyphs will return 1, since most are double width
func (ir *ImageRenderer) runeAdditionalWidth(r rune) int { func (ir *Renderer) runeAdditionalWidth(r rune) int {
// exclude the round leading diamond // exclude the round leading diamond
singles := []rune{'\ue0b6', '\ue0ba', '\ue0bc'} singles := []rune{'\ue0b6', '\ue0ba', '\ue0bc'}
if slices.Contains(singles, r) { if slices.Contains(singles, r) {
@ -344,7 +344,7 @@ func (ir *ImageRenderer) runeAdditionalWidth(r rune) int {
return 0 return 0
} }
func (ir *ImageRenderer) cleanContent() { func (ir *Renderer) cleanContent() {
// clean abundance of empty lines // clean abundance of empty lines
ir.AnsiString = strings.Trim(ir.AnsiString, "\n") ir.AnsiString = strings.Trim(ir.AnsiString, "\n")
ir.AnsiString = "\n" + ir.AnsiString ir.AnsiString = "\n" + ir.AnsiString
@ -375,7 +375,7 @@ func (ir *ImageRenderer) cleanContent() {
} }
} }
func (ir *ImageRenderer) measureContent() (width, height float64) { func (ir *Renderer) measureContent() (width, height float64) {
linewidth := 145 linewidth := 145
linewidth += ir.additionalWidth() linewidth += ir.additionalWidth()
@ -392,7 +392,7 @@ additionalWidth returns the number of additional characters of width to allocate
for characters that are 2 wide. A standard character will return 0 for characters that are 2 wide. A standard character will return 0
Nerd Font glyphs will return 1, since most are double width Nerd Font glyphs will return 1, since most are double width
*/ */
func (ir *ImageRenderer) additionalWidth() int { func (ir *Renderer) additionalWidth() int {
longest := 0 longest := 0
var longestLine string var longestLine string
for _, line := range strings.Split(ir.AnsiString, "\n") { for _, line := range strings.Split(ir.AnsiString, "\n") {
@ -411,7 +411,7 @@ func (ir *ImageRenderer) additionalWidth() int {
return additionalWidth return additionalWidth
} }
func (ir *ImageRenderer) lenWithoutANSI(text string) int { func (ir *Renderer) lenWithoutANSI(text string) int {
if len(text) == 0 { if len(text) == 0 {
return 0 return 0
} }
@ -435,7 +435,7 @@ func (ir *ImageRenderer) lenWithoutANSI(text string) int {
return length return length
} }
func (ir *ImageRenderer) SavePNG() error { func (ir *Renderer) SavePNG() error {
var f = func(value float64) float64 { return ir.factor * value } var f = func(value float64) float64 { return ir.factor * value }
var ( var (
@ -569,7 +569,7 @@ func (ir *ImageRenderer) SavePNG() error {
return dc.SavePNG(ir.Path) return dc.SavePNG(ir.Path)
} }
func (ir *ImageRenderer) shouldPrint() bool { func (ir *Renderer) shouldPrint() bool {
for sequence, re := range ir.ansiSequenceRegexMap { for sequence, re := range ir.ansiSequenceRegexMap {
match := regex.FindNamedRegexMatch(re, ir.AnsiString) match := regex.FindNamedRegexMatch(re, ir.AnsiString)
if len(match) == 0 { if len(match) == 0 {
@ -622,7 +622,7 @@ func (ir *ImageRenderer) shouldPrint() bool {
return true return true
} }
func (ir *ImageRenderer) setBase16Color(colorStr string) { func (ir *Renderer) setBase16Color(colorStr string) {
tempColor := ir.defaultForegroundColor tempColor := ir.defaultForegroundColor
colorInt, err := strconv.Atoi(colorStr) colorInt, err := strconv.Atoi(colorStr)
if err != nil { if err != nil {

View file

@ -1,4 +1,4 @@
package prompt package image
import ( import (
"os" "os"
@ -36,7 +36,7 @@ func runImageTest(config, content string) (string, error) {
terminal.Init(shell.GENERIC) terminal.Init(shell.GENERIC)
image := &ImageRenderer{ image := &Renderer{
AnsiString: content, AnsiString: content,
} }