join plain text and rich text to one struct.

This commit is contained in:
Miroslav Šedivý
2021-01-29 20:05:13 +01:00
parent 5c9a57ee91
commit 546cd608c3
6 changed files with 63 additions and 62 deletions

View File

@ -5,8 +5,37 @@ import (
"bytes"
"os/exec"
"strings"
"demodesk/neko/internal/types"
)
func (manager *DesktopManagerCtx) ClipboardGetText() (*types.ClipboardText, error) {
text, err := manager.ClipboardGetBinary("STRING")
if err != nil {
return nil, err
}
// Rich text must not always be available, can fail silently.
html, _ := manager.ClipboardGetBinary("text/html")
return &types.ClipboardText{
Text: string(text),
HTML: string(html),
}, nil
}
func (manager *DesktopManagerCtx) ClipboardSetText(data types.ClipboardText) error {
// TODO: Refactor.
// Current implementation is unable to set multiple targets. HTML
// is set, if available. Otherwise plain text.
if data.HTML != "" {
return manager.ClipboardSetBinary("text/html", []byte(data.HTML))
}
return manager.ClipboardSetBinary("STRING", []byte(data.Text))
}
func (manager *DesktopManagerCtx) ClipboardGetBinary(mime string) ([]byte, error) {
cmd := exec.Command("xclip", "-selection", "clipboard", "-out", "-target", mime)
@ -77,21 +106,3 @@ func (manager *DesktopManagerCtx) ClipboardGetTargets() ([]string, error) {
return response, nil
}
func (manager *DesktopManagerCtx) ClipboardGetPlainText() (string, error) {
bytes, err := manager.ClipboardGetBinary("STRING")
return string(bytes), err
}
func (manager *DesktopManagerCtx) ClipboardSetPlainText(data string) error {
return manager.ClipboardSetBinary("STRING", []byte(data))
}
func (manager *DesktopManagerCtx) ClipboardGetRichText() (string, error) {
bytes, err := manager.ClipboardGetBinary("text/html")
return string(bytes), err
}
func (manager *DesktopManagerCtx) ClipboardSetRichText(data string) error {
return manager.ClipboardSetBinary("text/html", []byte(data))
}