By L. Collado-Torres.
Version Requirements; TextMate 2.0.6: OS X 10.12 (i386) TextMate 2.0 rc.10. TextMate 1.x is not suitable as it relies on system components no longer. Download TextMate for Mac - A user friendly macOS text editor designed to provide support for programmers and designers that need an efficient tool for writing code and markup. Free Download specifications changelog 100% CLEAN report malware. TextMate is an unsophisticated text editor that allows you to use syntax highlight themes for various scripting languages. User-friendly workflow and intuitive design. The TextMate main window is focused on text processing and eliminated all possible distractions. However, the bottom toolbar provides access to frequently used tools: you can.
For the past 6-7 years I have been using TextMate 2 as my text editor which I’ve found useful for R code, bash, Markdown, etc. You could also look into Sublime Text or use RStudio (post about this setup coming soon).
Sometimes students are interested in this setup, which is what I’ll document here. Though I want to highlight that you can get a very similar setup using other tools. Note that this setup only works for Mac computers.
Setup
First, install TextMate 2 for free. TextMate allows users to contribute bundles which are a set of tools that enhance the editor. For example, if you want to quickly insert an R code chunk in a .Rmd
file you can add a command for it inside a bundle. You can also use a bundle to get the editor to recognize R code inside an R markdown code chunk. Probably the easiest way to get jump-started is to copy my exact setup.
Change some preferences
So next, go to the preferences menu
and under bundle, choose the R bundle as shown below.
As you can see, it hasn’t been updated in a while. I have made a few edits myself here and there which I’ll describe in the next section.
You should also enable running TextMate from the terminal.
Finally, here are my main file preferences: I want my files to be .R
files by default and to use linux line endings to avoid issues later on.
Adding bundles from git
TextMate allows you to install bundles by adding the bundle files in a specific folder. The bundle files are most likely in a GitHub repository, so you just need to clone (download) them to where TextMate expect them to be.
- https://github.com/lcolladotor/r.tmbundle for R and sending code to be evaluated in an iTerm2 terminal (setup explained later)
- https://github.com/noniq/Merge-Markers.tmbundle for git merging
- https://github.com/elia/base16-themes.tmbundle for theme colors
- https://github.com/lcolladotor/criticmarkup.tmbundle for CriticMarkup in Markdown files
- https://github.com/lcolladotor/knitr.tmbundle for
knitr::knit()
- https://github.com/lcolladotor/markdown-redcarpet.tmbundle for basically running
rmarkdown::render()
on the document at hand and previewing it live (if it’s an html doc). It also makes it so that R code inside code chunks will be recognized as such, enabling all the R code shortcuts.
As you can see, these bundles help adapt TextMate2 for working with R files of different flavors. But it’s not beginner friendly, hence the upcoming blog post about using RStudio.
Some feature highlights
One of the features that I really like from TextMate is searching/replacing (you can use regex) across all the files and sub-directories of a given directory. It’s very useful when trying to fix a common typo across different files or finding all the places where a function/argument was used. The latter one is handy when you are looking at someone else’s code. It’s basically like searching inside a GitHub repository: example, search baseurl
in all of blogdown for finding the code that reads it from a config file, which I did for this PR.
You can also comment all the lines of code you have selected fairly easily using the Source
bundle.
I’ve also used the Text
, LaTeX
and Gist
bundles, though not as frequently. Also, TextMate automatically spell checks for you and knows to ignore R markdown code chunks.
Evaluating code in R console or iTerm2
If you download and install the iTerm2 terminal, you can configure TextMate to evaluate the code in that terminal. The particular code I have for doing this is in the leo
branch of the following repo https://github.com/lcolladotor/r.tmbundle/commits/leo. In total I use 3 different keyboard shortcuts depending on whether I want to evaluate the code:
- in an R console window;
- in an R console window after automatically running
setwd()
to the directory that contains the files I’m looking at; - to the iTerm2 terminal, which is useful when working with a computing cluster.
Running rmarkdown::render()
If I’m working with an R Markdown file (.Rmd
extension), I frequently use the alt (option) + t
shortcut for running rmarkdown::render()
and viewing the output file.
Textmate Mac Download Free Download
For example, if I’m working with the recount-brain/index.Rmd
file (you can get it here), my setup allows me to run all the R shortcuts. That’s because it recognizes the R code chunk syntax and uses the source.r
scope.
Anyway, after using alt (option) + t
TextMate shows me the final html.
A lot of the bundles in TextMate are from the days when we run Sweave()
. So they work well with .Rnw
files and all the like. I did modify one of them to use knitr::knit()
instead of Sweave()
.
mate
and rmate
If you enable the terminal preferences you can now use the mate
command in any directory in your laptop. TextMate will open and show you all the tabs of files you had last opened in that same directory. This behavior is also a part of the .Rproj
files with RStudio.
The command I really like is rmate
because it enables me to remotely open a file from the cluster in TextMate, which combined with the evaluate in iTerm2 command makes it easy to work. Basically, I power up an iTerm2 terminal, log into the cluster, navigate to the directory that contains the files I’m working with, and then open them remotely with rmate
.
Setting up rmate
takes a bit of work but it’s definitely worth it.
- In the cluster, install
rmate
following the instructions at https://github.com/textmate/rmate - Find a port that works for doing the forwarding. The default one will likely be taken already by another user. Find more about this here. There they use
ssh -R 8080:localhost:80 public.example.com
for testing. Sadly, I don’t know of a quick and easy way to find a port for you to use :/ - Edit your cluster’s
~/.bashrc
file with the port information. Mine includes these lines wheresomeSecretPortNumber
is replaced by my port number.
- Edit your laptop’s
~/.ssh/config
file so you don’t have to specify the port every time youssh
into theJHPCE
cluster:
- Edit your cluster’s
~/.ssh/config
file so the port gets forwarded also when you access a compute node withqrsh
. All of JHPCE’s compute nodes are namedcompute
something, so we can take advantage of that in the config file.
Once you do these steps, rmate
should work on a new terminal window.
TextMate variables
Textmate Mac Download Free Windows 10
I don’t remember right now if I manually edited the TextMate variables, but just in case, here’s the info.
Acknowledgments
This blog post was made possible thanks to:
- BiocStyle(Oleś, Morgan, and Huber, 2017)
- blogdown(Xie, Hill, and Thomas, 2017)
- devtools(Wickham, Hester, and Chang, 2018)
- knitcitations(Boettiger, 2017)
References
[1] C. Boettiger. knitcitations: Citations for ‘Knitr’ Markdown Files. R package version 1.0.8. 2017. URL: https://CRAN.R-project.org/package=knitcitations.
[2] A. Oleś, M. Morgan and W. Huber. BiocStyle: Standard styles for vignettes and other Bioconductor documents. R package version 2.6.1. 2017. URL: https://github.com/Bioconductor/BiocStyle.
[3] H. Wickham, J. Hester and W. Chang. devtools: Tools to Make Developing R Packages Easier. R package version 1.13.5. 2018. URL: https://CRAN.R-project.org/package=devtools.
[4] Y. Xie, A. P. Hill and A. Thomas. blogdown: Creating Websites with R Markdown. ISBN 978-0815363729. Boca Raton, Florida: Chapman and Hall/CRC, 2017. URL: https://github.com/rstudio/blogdown.