Mercurial > cgi-bin > hgweb.cgi > ClipMan
changeset 37:9890445e4cc4
Didn't like eating its own dog food. Fixed.
author | David Barts <n5jrn@me.com> |
---|---|
date | Thu, 30 Jan 2020 21:03:56 -0800 (2020-01-31) |
parents | fcf82e3b7e31 |
children | 08eaae2aaf76 |
files | src/name/blackcap/clipman/Pasteboard.kt |
diffstat | 1 files changed, 11 insertions(+), 4 deletions(-) [+] |
line wrap: on
line diff
--- a/src/name/blackcap/clipman/Pasteboard.kt Thu Jan 30 20:24:02 2020 -0800 +++ b/src/name/blackcap/clipman/Pasteboard.kt Thu Jan 30 21:03:56 2020 -0800 @@ -18,6 +18,10 @@ import java.util.logging.Logger import kotlin.collections.HashMap +/* Kotlin bug: compaion class fails to see these unless they are out here. */ +private val CHARSET = Charset.forName(CHARSET_NAME) +private val HTML_FLAVOR = DataFlavor("text/html; document=all; class=\"[B\"; charset=" + CHARSET_NAME) + /** * Represents an item of data in the clipboard and how to read and * write it. @@ -60,8 +64,6 @@ private class PasteboardData(val item: PasteboardItem): Transferable, ClipboardOwner { - private val CHARSET = Charset.forName(CHARSET_NAME) - private val HTML_FLAVOR = DataFlavor("text/html; document=all; class=\"[B\"; charset=" + CHARSET_NAME) private val _data: HashMap<DataFlavor, Any> private val flavors: Array<DataFlavor> @@ -117,17 +119,22 @@ * @return a PasteboardItem? object, null if nothing could be read */ fun read() : PasteboardItem? { + /* println("-- BEGIN FLAVORS --") + CLIPBOARD.availableDataFlavors.forEach { + println(it.mimeType) + } + println("-- END FLAVORS --") */ check() val plain = getClipboardData(DataFlavor.stringFlavor) as String? if (plain == null) { return null } - val html = getClipboardData(DataFlavor.allHtmlFlavor) as String? + val html = getClipboardData(HTML_FLAVOR) as ByteArray? if (html == null) { val rtf = getClipboardData(RTF_FLAVOR) as ByteArray? return if (rtf == null) { Plain(plain) } else { RTF(plain, rtf) } } else { - return HTML(plain, html) + return HTML(plain, html.toString(CHARSET)) } }