-
Notifications
You must be signed in to change notification settings - Fork 37
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Platform non-agnostic / dangerous functions #63
Comments
|
Don't know if it counys, but many popular parallel processing packages don't work on windows |
A list of functions with windows implementations (defined in /R/windows/*.R) not present in my OS X version of R (NB, the versions are different, but that probably matters in ~0 of them)
|
I did the above quickly, so obviously there are some false positives (the .onLoad jumps out) but most of them pass the eyeball test. Double edit: I'll do a better version of this later today. at the very least these are functions that have windows-specific implementations. |
Ok, this time with proper checking for the functions in the Mac versions I have installed, and some comments (and code highlighting...) pkgdirs = list.dirs(".", recursive=FALSE, full.names=TRUE)
pkgdirs = pkgdirs[-grep("Recommended", pkgdirs)]
windirs = file.path(pkgdirs,"R","windows")
winrfils = list.files(windirs, pattern = ".R", full.names=TRUE)
library(CodeDepends)
basepkgs = installed.packages(priority="base")[,"Package"]
## attach all the base packages, probably overkill give new way of checking
## for existence later on...
lapply(basepkgs, function(x) library(x, character.only=TRUE))
## returns a list of vectors of functions defined in /R/windows/*.R files
## named by the file.
winfuns = sapply(winrfils,
function(f) {
scr = readScript(f)
info = getInputs(scr)
## the outputs here are functions defined in the .R file
unlist(lapply(info, function(y) y@outputs))
})
## names of packages
pkgs = gsub(".*/([^/]*)/R/windows/.*", "\\1", names(winfuns))
## vector of functions defined in /windows/*.R files in base pkgs
## will be parallel to pkgs
winfunsvec = unlist(winfuns)
## logical indicated whether each function exists in the namespace
## of the corresponding package on my mac
foundonmac = mapply(function(f, pkg) {
ff = try(get(f, envir = asNamespace(pkg), inherits = FALSE),
silent = TRUE)
!is(ff, "try-error")
}, f = winfunsvec, pkg = rep(pkgs, times = lengths(winfuns)))
## functions implemented for windows versions of base packages but not
## for mac versions I have installed.
winonly = winfunsvec[!foundonmac]
names(winonly) = pkgsvec[!foundonmac]
winonly Gives us base base
"Sys.junction" "shell"
base grDevices
"shell.exec" ".WindowsEnv"
grDevices grDevices
".Windows.Options" ".Windows.Options.default"
grDevices grDevices
"aa.win" "windows.options"
grDevices grDevices
"windows" "win.graph"
grDevices grDevices
"win.print" "win.metafile"
grDevices grDevices
"bringToTop" "msgWindow"
grDevices grDevices
"print.SavedPlots" "[.SavedPlots"
grDevices grDevices
".Windows.Fonts" "checkWindowsFont"
grDevices grDevices
"setWindowsFonts" "windowsFonts"
grDevices tcltk
"windowsFont" ".onUnload"
utils utils
"loadRconsole" "Filters"
utils utils
"choose.files" "choose.dir"
utils utils
"unpackPkgZip" ".install.winbinary"
utils utils
"menuInstallPkgs" "menuInstallLocal"
utils utils
"zip.unpack" "DLL.version"
utils utils
"getClipboardFormats" "readClipboard"
utils utils
"writeClipboard" "getIdentification"
utils utils
"setWindowTitle" "getWindowTitle"
utils utils
"setStatusBar" "getWindowsHandle"
utils utils
"getWindowsHandles" "arrangeWindows"
utils utils
"menuShowCRAN" "shortPathName"
utils utils
"readRegistry" "setInternet2"
utils utils
"win.version" "winDialog"
utils utils
"winDialogString" "winMenuDel"
utils utils
"winMenuDelItem" "winMenuAdd"
utils utils
"winMenuAddItem" "winMenuNames"
utils utils
"winMenuItems" "winProgressBar"
utils utils
"close.winProgressBar" "setWinProgressBar"
utils utils
"getWinProgressBar" "askYesNoWinDialog" |
Thanks @gmbecker ! This is great :) |
There are some functions, or options within functions, or patterns that can not be run on all operating systems.
After some discussion around the checkers pkg, at the rOpenSci unconf17, we thought it might be useful to create a list of these functions, options, or patterns.
windows()
. In a windows OS, this opens up a graphics device, but not on another OS.download.url(mode = "w")
. On a windows OS, whenmode = "w"
, this can create a corrupt filepaste0(sep = "/")
. This is not appropriate for windows machines - a safer alternative isfile.path()
. Also, careful of specifying entire file directories.This list may eventually turn into something that
goodpractice
orlintr
uses.Tagging a few folks in here who might be interested in contributing to this: @jennybc @jeroen @richierocks @stephlock @daattali @gaborcsardi
Please feel free to add others!
The text was updated successfully, but these errors were encountered: