mirror of
https://github.com/JanDeDobbeleer/oh-my-posh.git
synced 2025-01-13 12:17:26 -08:00
refactor: move image to module
This commit is contained in:
parent
ee9bdf4761
commit
ad10da8cc9
|
@ -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,
|
||||||
|
|
|
@ -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 {
|
|
@ -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,
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue