radian: A 21 century R console
radian is an alternative console for the R program with multiline editing and rich syntax highlight.
One would consider radian as a ipython clone for R, though its design is more aligned to julia.
Features
- cross platform, runs on Windows, macOS and Linux
- shell mode: hit
;
to enter and <backspace>
to leave - reticulate python repl mode: hit
~
to enter - improved R prompt and reticulate python prompt
- multiline editing
- syntax highlight
- auto completion (reticulate autocompletion depends on
jedi
)
- unicode support
- latex completion
- auto matching parens/quotes.
- bracketed paste mode
- emacs/vi editing mode
- automatically adjust to terminal width
- read more than 4096 bytes per line
Installation
Requirements:
pip3 install -U radian
radian
pip3 install -U git+https://github.com/randy3k/radian
Alternatively, if you use conda or miniconda,
conda install -c conda-forge radian
In this case, it is recommended to install R via conda to ensure consistency in C runtime libraries.
Alias on unix system
You could alias r
to radian by putting
alias r="radian"
in ~/.bash_profile
such that r
would open radian and R
would still open the traditional R console.
(R
is still useful, e.g, running R CMD BUILD
.)
Settings
radian can be customized by specifying the below options in various locations
$XDG_CONFIG_HOME/radian/profile
or $HOME/.config/radian/profile
(Unix)%USERPROFILE%/radian/profile
(Windows)$HOME/.radian_profile
(Unix)%USERPROFILE%/.radian_profile
(Windows).radian_profile
in the working directory
The options could be also specified in the .Rprofile
files, however,
it is not recommended because
- the settings are not persistent when vanilla mode is used;
- it doesn't work well with
packrat
or renv
.
options(radian.color_scheme = "native")
options(radian.editing_mode = "emacs")
options(radian.emacs_bindings_in_vi_insert_mode = FALSE)
options(radian.show_vi_mode_prompt = TRUE)
options(radian.vi_mode_prompt = "\033[0;34m[{}]\033[0m ")
options(radian.indent_lines = TRUE)
options(radian.auto_match = TRUE)
options(radian.auto_suggest = FALSE)
options(radian.highlight_matching_bracket = FALSE)
options(radian.auto_indentation = TRUE)
options(radian.tab_size = 4)
options(radian.complete_while_typing = TRUE)
options(radian.completion_prefix_length = 2)
options(radian.completion_timeout = 0.05)
options(radian.completion_adding_spaces_around_equals = TRUE)
options(radian.auto_width = TRUE)
options(radian.insert_new_line = TRUE)
options(radian.history_size = 20000)
options(radian.global_history_file = "~/.radian_history")
options(radian.local_history_file = ".radian_history")
options(radian.history_search_no_duplicates = FALSE)
options(radian.history_search_ignore_case = FALSE)
options(radian.history_ignore_browser_commands = TRUE)
options(radian.prompt = "\033[0;34mr$>\033[0m ")
options(radian.shell_prompt = "\033[0;31m#!>\033[0m ")
options(radian.browse_prompt = "\033[0;33mBrowse[{}]>\033[0m ")
options(radian.stderr_format = "\033[0;31m{}\033[0m")
options(radian.enable_reticulate_prompt = TRUE)
Custom key bindings
options(
radian.escape_key_map = list(
list(key = "-", value = " <- "),
),
radian.ctrl_key_map = list(
list(key = "right", value = " %>% ")
)
)
FAQ
Unicode doesn't work in Windows and R 4.2+.
The latest version of R supports Unicode codepage directly. However, radian relies on Python and Python doesn't support Unicode in the way that R supports it. A workaround could be found here: https://github.com/randy3k/radian/issues/269#issuecomment-1169663251. Though it may break the ploting device (running plot()
will kill radian).
I can't specify python runtime in reticulate.
It is expected. radian
runs on python and the python runtime used by radian is forced in
reticulate. reticulate::py_config()
gives the note:
NOTE: Python version was forced by the current process
In order to use radian with another python runtime, you will need to install radian
on
that python environment.
How to switch to a different R or specify the version of R.
There are serveral options.
- The easiest option is to pass the path to the R binary with
--r-binary
, i.e., radian --r-binary=/path/to/R
- Also, one could expose the path to the R binary in the
PATH
variable - The environment variable
R_BINARY
could also be used to specify the path to R. - The environment variable
R_HOME
could also be used to specify R home directory. Note that it is should be set as the result of R.home()
, not the directory where R
is located. For example, in Unix
$ env R_HOME=/usr/local/lib/R radian
Cannot find shared library
Please also make sure that R was installed with the R shared library libR.so
or libR.dylib
or libR.dll
. On Linux, the configure flag ./configure --enable-R-shlib
may be needed to install R from the source. Do not forget to make clean
to force the recompilation of the files with the correct compiler options.
Outdated setuptools
If you encounter
The package setup script has attempted to modify files on your system that are not within the EasyInstall build area.
Please update your setuptools by
pip install -U setuptools
How to use local history file
radian maintains its own history file .radian_history
and doesn't use the .Rhistory
file. A local .radian_history
is used if it is found in the launch directory. Otherwise, the global history file ~/.radian_history
would be used. To override the default behavior, you could launch radian with the options: radian --local-history
, radian --global-history
or radian --no-history
.
Does it slow down my R program?
radian only provides a frontend to the R program, the actual running eventloop is the same as that of the traditional R console. There is no performance sacrifice (or gain) while using this modern command line interface.
However, it was reported that radian may be slower when using parallel computation, specifially when using forking. User should take extra care in those cases.
Nvim-R support
Put
let R_app = "radian"
let R_cmd = "R"
let R_hl_term = 0
let R_args = [] " if you had set any
let R_bracketed_paste = 1
in your vim config.
reticulate
Auto Completions
To enable reticulate prompt completions, make sure that jedi
is installed.
pip install jedi
Alternatively, if you use conda,
conda install -c conda-forge jedi
Prompt not shown inside a docker container
It maybe caused by the invalid terminal size, try running stty size
in your terminal
to see if it returns a correct size. You could change the values of it from the environmental variables
$COLUMNS
and $LINES
when you log-in the docker container.
docker exec -it <container> bash -c "stty cols $COLUMNS rows $LINES && bash"
Why called radian?
radian is powered by (π)thon.
Credits
radian wouldn't be possible without the creative work prompt_toolkit by Jonathan Slenders.