Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/randy3k/SendCode
Send code and text to macOS and Linux Terminals, iTerm, ConEmu, Cmder, Tmux, Terminus; R (RStudio), Julia, IPython.
https://github.com/randy3k/SendCode
cmder conemu gnome-terminal ipython iterm2 julia pantheon-terminal python r rstudio sendcode sublime-text terminal tmux
Last synced: 3 months ago
JSON representation
Send code and text to macOS and Linux Terminals, iTerm, ConEmu, Cmder, Tmux, Terminus; R (RStudio), Julia, IPython.
- Host: GitHub
- URL: https://github.com/randy3k/SendCode
- Owner: randy3k
- License: mit
- Created: 2016-07-10T22:54:06.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2022-11-04T23:13:05.000Z (about 2 years ago)
- Last Synced: 2024-10-30T16:12:48.468Z (3 months ago)
- Topics: cmder, conemu, gnome-terminal, ipython, iterm2, julia, pantheon-terminal, python, r, rstudio, sendcode, sublime-text, terminal, tmux
- Language: Python
- Homepage:
- Size: 1.12 MB
- Stars: 203
- Watchers: 9
- Forks: 28
- Open Issues: 58
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- jimsghstars - randy3k/SendCode - Send code and text to macOS and Linux Terminals, iTerm, ConEmu, Cmder, Tmux, Terminus; R (RStudio), Julia, IPython. (Python)
README
# SendCode for Sublime Text
Send code and text to macOS and Linux Terminals, iTerm, ConEmu, Cmder, Tmux, Terminus; R (RStudio), Julia, IPython.
![](https://user-images.githubusercontent.com/1690993/28198891-4ebe5eaa-682f-11e7-8173-10b64faef9b4.png)
Following Programs are supported
- Mac: Terminal, iTerm (>=2.9), R GUI, RStudio Desktop, RStudio and Jupyter running on Chrome and Safari
- Windows: Cmder, ConEmu, R GUI, RStudio Desktop
- Linux: Tmux, Screen, Gnome-Terminal, Pantheon-Terminal, Mate-Terminal, Konsole, RStudio Desktop
- Sublime Plugin: [Terminus](https://github.com/randy3k/Terminus)### Installation
You could install SendCode via Package Control.
- If you don't have Package Control installed, follow the [installation instructions on the Package Control website](https://packagecontrol.io/installation).
- In Sublime Text, type cmd+shift+p (Mac) or ctrl+shift+p (Windows/Linux) to bring up the command palette.
- Into the command palette start typing `Package Control: Install Package` and select the option when in pops up.
- In the Install Package window start typing `SendCode` and select the option when it pops up.
- SendCode should then be installed.If you are using Linux, we might need to install
[xdotool](http://www.semicomplete.com/projects/xdotool/) to use some features. Ubuntu users can use
```
sudo apt-get install xdotool
```
If it cannot be found, you will be prompted
to download a [binary distribution](https://github.com/randy3k/sublime-xdotool).### Usage
Select a program using the command `SendCode: Choose Program` in command palette. The default program on macOS, windows and linux are Terminal, Cmder and tmux respectively. Each syntax binds to its own program. For instance, you could bind `R` to r files and `tmux` to python files.
There are two main keybindings:
- cmd+enter (Mac) or ctrl+enter (Windows/Linux)
If text is selected, it sends the text to the program selected. If no text is selected, then it sends the current block (if found). Finally, it moves the cursor to the next line.
- cmd+b (Mac) or ctrl+b (Windows/Linux): source current file (R, Julia and Python (IPython) only)
SendCode uses Sublime build system to source files, you might have to choose the `Source File` option in a pop up window.
### Troubleshooting
1. Python console
[IPython](https://ipython.org) (5.0 or above, or any repls which support bracketed paste mode) are assumed to be used.
1. [radian](https://github.com/randy3k/radian) console
You might want to turn on `bracketed_paste_mode` if [radian](https://github.com/randy3k/radian) is used.
1. RStudio on Windows
Make sure [RStudio v1.1.383](https://www.rstudio.com/products/rstudio/download/) or above is used.1. R Gui on Windows
Make sure the corresponding R program is opened when you are sending the text.
1. Cmder/ Conemu on Windows
You might need to set the path to `ConEmuC.exe` in SendCode settings. For Cmder, the file is located at
`\\vendor\\conemu-maximus5\\ConEmu\\ConEmuC.exe`.1. Safari-Jupyter on macOS
Most likely you haven't enabled JavaScript for AppleScript. Check the option "Allow JavaScript from Apple Events" in the `Develop` menu (the `Develope` menu needs to be enabled in the preferences).
### Custom Keybindings
It is fairly easy to create your own keybinds for commands which you frequently use. For example, the following keybinds execute changing working directory commands for R, Python and Julia.
```json
[
{
"keys": ["ctrl+shift+h"], "command": "send_code",
"args": {"cmd": "setwd(\"$file_path\")"},
"context": [
{ "key": "selector", "operator": "equal", "operand": "source.r" }
]
},
{
"keys": ["ctrl+shift+h"], "command": "send_code",
"args": {"cmd": "%cd \"$file_path\""},
"context": [
{ "key": "selector", "operator": "equal", "operand": "source.python" }
]
},
{
"keys": ["ctrl+shift+h"], "command": "send_code",
"args": {"cmd": "cd(\"$file_path\")"},
"context": [
{ "key": "selector", "operator": "equal", "operand": "source.julia" }
]
}
]
```SendCode expands following variables in the `cmd` field:
- `$file`, the full path to the file
- `$file_path`, the directory contains the file
- `$file_name`, the file name
- `$file_base_name`, the file name without extension
- `$file_extension`, the file extension
- `$folder`, the first folder of current window
- `$project_path`, the directory where sublime-project is stored
- `$current_folder`, the folder of the window which contains the current view
- `$selection`, the text selected, or the word under cursor
- `$line`, the current line numberIt also supports placeholders for variables, details can be found in the [unofficial documentation](http://docs.sublimetext.info/en/latest/reference/build_systems/configuration.html#placeholders-for-variables).
```
${file_path:$folder}
```
This will emit the directory of current file if there is one, otherwise the first folder of the current window.You also don't have to worry about escaping quotes and backslashes between quotes, SendCode will
handle them for you.The `prog` argument determines which program to use
```json
[
{
"keys": ["ctrl+shift+enter"], "command": "send_code",
"args": {"cmd": "\n", "prog": "tmux"}
}
]
```### User settings
A couple of settings can be found `Preferences: SendCode Settings`.
Project-wise settings could also be specified in `sublime-project` as```js
{
"settings": {
"SendCode": {
"prog": "terminus",
"r" : {
"bracketed_paste_mode": true
}
}
}
}
```### Block expansion
SendCode uses the following logics to expand cursor when sending code.
- Expand current line to match `()`, `[]` and `{}`.
- R:
- backward expand if the previous line ends with a pipe opeartor `%>%`
- `# %%` decorators
- `#+` spin decorators
- `#'` roxygen decorators
- Julia
- `begin`, `end` indented pairs.
- `# %%` decorators
- Python:
- indentations
- `# %%` decorators.
- (See the settings `block_start_pattern` and `block_end_pattern`)
- Markdown fenced code blocks
- put the cursor at the line of \`\`\` to send the whole block.