1
0
mirror of https://github.com/makew0rld/amfora.git synced 2024-12-04 14:46:29 -05:00
amfora/structs/structs.go
2021-05-15 23:48:47 -04:00

58 lines
2.0 KiB
Go

//nolint:lll
package structs
import "time"
type Mediatype string
const (
TextGemini Mediatype = "text/gemini"
TextPlain Mediatype = "text/plain"
TextAnsi Mediatype = "text/x-ansi"
)
type PageMode int
const (
ModeOff PageMode = iota // Regular mode
ModeLinkSelect // When the enter key is pressed, allow for tab-based link navigation
ModeSearch // When a keyword is being searched in a page - TODO: NOT USED YET
)
// Page is for storing UTF-8 text/gemini pages, as well as text/plain pages.
type Page struct {
URL string
Mediatype Mediatype // Used for rendering purposes, generalized
RawMediatype string // The actual mediatype sent by the server
Raw []byte // The raw data from the network, encoded as UTF-8. Never modify it, only set and read.
Links []string // URLs, for each region in the content.
Row int // Vertical scroll position
Column int // Horizontal scroll position - does not map exactly to a cview.TextView because it includes left margin size changes, see #197
TermWidth int // The terminal width when the Content was set, to know when reformatting should happen.
Selected string // The current text or link selected
SelectedID string // The cview region ID for the selected text/link
Mode PageMode
MadeAt time.Time // When the page was made. Zero value indicates it should stay in cache forever.
}
// Size returns an approx. size of a Page in bytes.
func (p *Page) Size() int {
n := len(p.Raw) + len(p.URL) + len(p.Selected) + len(p.SelectedID)
for i := range p.Links {
n += len(p.Links[i])
}
return n
}
// BytesWriter wraps a byte slice and implements io.Writer. Unlike bytes.Buffer,
// it will modify the underlying slice. It's use to allow functions like io.Copy
// on Page.Raw.
type BytesWriter struct {
ByteSlice *[]byte
}
func (b *BytesWriter) Write(p []byte) (n int, err error) {
*b.ByteSlice = append(*b.ByteSlice, p...)
return len(p), nil
}