R/tk2swaplist.R

Defines functions tk2swaplist

Documented in tk2swaplist

tk2swaplist <- function(items, selection, title = "Select items", ...)
{
    win <- tktoplevel()
    res <- try(tclRequire("swaplist"), silent = TRUE)
    if (inherits(res, "try-error"))
        stop("swaplist Tcl package not available")
    sel <- tclVar()
    res <- tcl("swaplist::swaplist", win, sel, items, selection,
        title = title, ...)
    if (tclvalue(res) == 0) { # User cancelled
        res <- character(0)
    } else res <- tclObj(sel)
    if (is.ordered(items))
        return(ordered(as.character(res), levels = levels(items)))
    if (is.factor(items))
        return(factor(as.character(res), levels = levels(items)))
    switch(typeof(items),
        integer = as.integer(res),
        double = as.numeric(res),
        logical = as.logical(res),
        complex = as.complex(res),
        as.character(res))
}

Try the tcltk2 package in your browser

Any scripts or data that you put into this service are public.

tcltk2 documentation built on May 2, 2019, 9:37 a.m.