Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Add sixel sequence object #269

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

CannibalVox
Copy link

In charmbracelet/lipgloss#436 @aymanbagabas requested that I move ANSI escape code logic to this repository. The logic for building the palette and pixels seem complex enough that they should remain in lipgloss(?) but the basic writing of ANSI envelope is now here in x/ansi.

Copy link
Member

@aymanbagabas aymanbagabas left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It would be great to have our own Sixel implementation under ansi/sixel, however. That seems like a longer initiative. For now, we could get by using https://github.com/mattn/go-sixel

"strconv"
)

type SixelSequence struct {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sixel is just a DCS command. This should be a type SixelImage struct that conforms to image.Image.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sixels don't really lend themselves to random access by pixel- Image.At() would basically have to be O(N) where N is the number of bytes in the encoded sixel image.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants