view src/main/kotlin/name/blackcap/passman/Clipboard.kt @ 1:8aacca5c2d53

Should have not committed this one.
author David Barts <n5jrn@me.com>
date Sun, 11 Sep 2022 16:12:47 -0700
parents a6cfdffcaa94
children 3c792ad36b3d
line wrap: on
line source

package name.blackcap.passman

import java.awt.Toolkit
import java.awt.datatransfer.Clipboard
import java.awt.datatransfer.DataFlavor
import java.awt.datatransfer.Transferable
import java.awt.datatransfer.UnsupportedFlavorException

private val CLIPBOARD = Toolkit.getDefaultToolkit().systemClipboard

private class ClipboardData(val item: String): Transferable {
    private val FLAVORS = arrayOf<DataFlavor>(DataFlavor.stringFlavor)

    override fun getTransferDataFlavors(): Array<DataFlavor> = FLAVORS

    override fun isDataFlavorSupported(flavor: DataFlavor?): Boolean =
        FLAVORS.contains(flavor)

    override fun getTransferData(flavor: DataFlavor?): Any {
        if (!isDataFlavorSupported(flavor)) {
            throw UnsupportedFlavorException(flavor)
        }
        return item
    }

}

private class ClipboardOwner(): java.awt.datatransfer.ClipboardOwner {
    override fun lostOwnership(clipboard: Clipboard?, contents: Transferable?) {
        /* we don't care */
    }
}

/* xxx: this often makes a string out of a password */
fun writeToClipboard(charArray: CharArray) {
    CLIPBOARD.setContents(ClipboardData(String(charArray)), ClipboardOwner())
}

fun writeToClipboard(string: String) {
    CLIPBOARD.setContents(ClipboardData(string), ClipboardOwner())
}