TextMate 2 adds a nice feature, where it is possible to edit files on a remote server using a helper script. The original helper script provided with TM2 is implemented in ruby. Here is my attempt to replace this ruby script with a shell script, because in some cases a ruby installation might just be to much overhead for just editing remote files.
The shell script needs to be copied to the server, you want to remote edit files, on. After that, open your TM2 preferences and enable "Allow rmate connections" setting in the "Terminal" settings and adjust the setting "Access for" according to your needs:
It's a good idea to allow access only for local clients. In this case you need to open a SSH connection to the system you want to edit a file on and specify a remote tunnel in addition:
ssh -R 52698:localhost:52698 email@example.com
If you are logged in on the remote system, you can now just execute
On some machines, where port forwarding is not possible, for example due to a missing ssh daemon, you can allow access for "remote clients". Just ssh or telnet to the remote machine and execute:
rmate -H textmate-host test.txt
Example session: Editing html file located on an SGI o2: https://github.com/aurora/rmate/wiki/Screens
A bash with compiled support for "/dev/tcp" is required. This is not the case on some older linux distributions, like Ubuntu 9.x.
$ ./rmate [-H host-name] [-p port-number] [-w] [-l line-number] [-m display-name] [-t file-type] [-f] [-v] file-path
rmate takes a file as last argument. This argument is always required.
-H connect to host (default: localhost) -p port number to use for connection (default: 52698) -w wait for file to be closed by TextMate -l place caret on line number after loading file -m the display name shown in TextMate -t treat file as having specified type -f open even if file is not writable -v verbose logging messages -h display this usage information
Some default parameters (host and port) can be configured by defining them
as the environment variables
RMATE_PORT or by putting them
in a configuration file. The configuration files loaded are
host: auto # prefer host from SSH_CONNECTION over localhost port: 52698
Alternative notation for configuration file is:
The precedence for setting the configuration is (higher precedence counts):
- default (localhost, 52698)
- environment variables (RMATE_HOST, RMATE_PORT)
Use with caution. This software may contain serious bugs. I can not be made responsible for any damage the software may cause to your system or files.
Copyright (C) 2011-2014 by Harald Lapp firstname.lastname@example.org
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.