A small menubar app that allows you to switch between R versions quickly (if you have multiple versions of R framework installed). https://rud.is/rswitch
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
boB Rudis 41e68c4b3f
Release
4 years ago
Index/DataStore/v5 slight refactor 5 years ago
Pods downloads working 4 years ago
RSwitch Release 4 years ago
RSwitch.xcodeproj downloads working 4 years ago
RSwitch.xcworkspace Release 4 years ago
build 1.4.0 5 years ago
guide Release 4 years ago
releases Release 4 years ago
rswitch-cmd Release 4 years ago
.gitignore notarization 5 years ago
LICENSE initial commit 5 years ago
NEWS.md Release 4 years ago
Podfile removed soup 5 years ago
Podfile.lock removed soup 5 years ago
README.md 1.3.0 5 years ago
rswitch-menu-example.png RSwitch 1.5.0 5 years ago
rswitch.png logo 5 years ago

README.md

Project Status: Active – The project has reached a stable, usable state and is being actively developed. Signed by Minimum macOS Target License

RSwitch

Change 'Current' R version on macOS

Description

At the bottom of the R for macOS Developer's Page there's mention of an "other binary" called "RSwitch" that is "a small GUI that allows you to switch between R versions quickly (if you have multiple versions of R framework installed)." Said switching requires you to use the "tar.gz" versions of R from the R for macOS Developer's Page since the official CRAN binary installers clean up after themselves quite nicely to prevent potentially wacky behavior.

All this GUI does is change the Current alias target in /Library/Frameworks/R.framework/Versions to the appropriate version. You can do that from the command line but the switcher GUI was created so that means some folks prefer click-switching.

After launching the app, there will be a new menu item in the main macOS menubar with a popup that will look something like this:

The checkmarked version is the default (i.e. the one Current points to) and if you select any other version the alias will be changed. You can also launch a new Finder window that opens to the R frameworks directory or quit the app.

There are also links to various useful R macOS resources plus two menu items that will download the latest RStudio macOS daily or the latest macOS r-devel tarball. Neither shows a progress dialog but will download the respective files to ~/Downloads and both open the Finder to that directory as well as display an alert with any succes or failure. NOTE: that you will need to delete old versions of r-devel from ~/Downloads before re-downloading (this behavior might be changed in future releases).

Why?

  • I needed to brush up on Swift 5 coding
  • I wanted RSwitch as a menubar app vs one with a dialog that I could easily lose across 15 desktops
  • I wanted to see if it was possible to make it work sandboxed (TLDR: it isn't)
  • The existing RSwitch source code is not available (likely got lost in the move from AT&T's domain to the new mac.r-project.org domain)
  • The existing RSwitch binaries no longer work starting with macOS Catalina since they are 32-bit
  • I'm not exactly enamored with the old-school R icons, including the RSwitch one. That's a personal preference, not a judgement or dig on the existing icons or the creators of said icons.

What's Inside the Tin?

The releases directory contains ZIP files of various versions (see TODO for why there'll be future versions). Just download and extract and enjoy.

Other than that (and the example png & LICENSE file) the rest is a super small Xcode project. It's commented as well to let you know what's going on.

CAUTION

You should really build this yourself since installing random binaries from the internet (or, even official ones from things like app stores) is fraught with peril. You have no guarantee that the releases are, indeed, built from this source tree. I could be stealing all your stuff! (NOTE: I'm not). Reading and understanding the source code and building the app on your own is the only way to ensure you're not going to be compromised.

Contributing

  • Follow the Contributor Code of Conduct
  • See the TODO (below)
  • File an issue claiming an item (on any social coding site you like)
  • Ensure you have signed commits
  • File a PR or submit a patch via email (bob at rud dot is)

This codebase has been uploaded to the following authoritative social coding sites:

TODO

  • Allow hiding of the app icon? (not sure this is a good idea, tho…pls discuss in an issue!)
  • (add your own TODO suggestions via PR)
  • Clean up the icon (which is "dial" by IconMark from the Noun Project). This means having it look better in the menu bar in dark/light mode including the highlight mode for it. Possibly means getting a visible "R" on it somewhere.
  • Better/prettier alerting (which also means more sanity checks)
  • Add Cmd-1, -2, -3, (etc) key equivalents in the menu bar for fast selection (one reason why ^^ might not be a good idea)
  • Add an "about" box (mostly to ensure IconMark gets more credit than a comment and README)

License

Copyright (c) 2019 Bob Rudis, MIT License