Multi-TTY Emacs on Gentoo and Ubuntu

May 24, 2007 at 1:59 pm | In Emacs, Linux |

(Historical note Sep 2008: The 'ec' script below is no longer (or shortly will not be) required, as there is now a patch that enables emacs as a frameless daemon)

(Historical note May 2008: This post is now over a year old. Multi-TTY Emacs is now part of the main Emacs CVS tree. Most of this post is still applicable, but the build instructions are very much out of date and for the most part are unnecessary as the multi-tty patch has now made it into most distros. It should just be an 'apt-get install emacs-snapshot' away)

Multi-TTY Emacs is one of the most useful peices of software I've seen in a long time. Emacsclient, the underlying interface for multi-tty, has been around for a while. It allows someone to connect to a long running Emacs session and it avoids the long startup time Emacs usually has. However, it only works in a graphical environment. Multi-TTY Emacs allows us to do the same from either a graphical environment or from a simple terminal (tty).

Here's a typical use case: I'm at home and I'm using Emacs from within X-windows. I'm using the wonderful IRC client, ERC, and asking a question in #python, #emacs, #gentoo etc. but no one seems to be paying any attention and no one is answering my question right away. Oh well, it's time for me to head off to class or work. I leave Emacs running at home but since I forgot to enable chat logs, it's rather difficult for me to connect remotely and find out if anyone has responded to my question. With Multi-TTY, I can ssh into my home computer and bring up Emacs in a text console and check my ERC buffer even though I originally started Emacs graphically from X-Windows. Neat.

Emacs Multi-TTY
You can also see a video of it in action

Multi-TTY is contained in the CVS version (23) of Emacs. Version 23 is still a (tiny) bit rough around the edges, so don't blame me if while using it it deletes all your files and destroys your life in general. It won't, but caveat emptor. I am now running multi-tty on Gentoo and Ubuntu Feisty Fawn. Here's how:

Gentoo

On my laptop I run Gentoo Linux. Getting the latest version of Emacs on Gentoo was a breeze! :

  • Setup Layman
  • Add the emacs overlay: sudo layman -a emacs
  • Add the following USE flags for app-editors/emacs-cvs:
    sudo flagedit app-editors/emacs-cvs X Xaw3d alsa gif gzip-el jpeg lesstif png sound spell tiff toolkit-scroll-bars xpm -gtk -hesiod -motif -source.

  • GTK support is explicitly turned off as it causes problems with multi-TTY. This is no biggie for me as I always have (menu-bar-mode -1) and (tool-bar-mode -1) set.
  • Emerge: sudo emerge emacs-cvs -va
  • Tell the system to use the new emacs: sudo eselect emacs set emacs-23-multi-tty

Ubuntu

Ubuntu was much more difficult to setup correctly because the repositories don't have the CVS version yet (emacs-snapshot is 22). So, I've compiled it from source myself and once I clean up my instructions I will publish a HOWTO as well as my .deb package.

Update: See my new Ubuntu specific post for build instructions

Usage

Connecting to an already running emacs session is quite easy:

  • In the main emacs session run M-x server-start
  • Now just run emacsclient -c and you should see a new window pop up that has all the exact same buffers. If you are on a non-graphical terminal you'll likewise get the same emacs session albeit in text mode.

I found some excellent tips from sness.net for making this even easier. Here are my variations on his methods:

Make a new file somewhere in your path called preload_emacs:
#!/bin/bash
# Usage: preload-emacs []
#
# Preloads the Emacs instance called NAME in a detached screen
# session. Does nothing if the instance is already running. If WAITP
# is non-empty, the function waits until the server starts up and
# creates its socket; otherwise it returns immediately.
# Visit http://www.enigmacurry.com
# based on http://emacslife.blogspot.com/2007/05/multi-tty-emacs.html

name="$1"
waitp="$2"
screendir="/var/run/screen/S-$USER"
serverdir="/tmp/emacs$UID"
emacs=/usr/bin/emacs

if [ -z "$name" ]; then
echo "Usage: preload_emacs []"
exit 1
fi

if [ ! -e "$screendir"/*."$name" ]; then
if [ -e "$serverdir/$name" ]; then
# Delete leftover socket (for the wait option)
rm "$serverdir/$name"
fi
screen -dmS "emacs-$name" "$emacs" -nw –eval "(setq server-name \"$name\")" -f server-start
fi
if [ ! -z "$waitp" ]; then
while [ ! -e "$serverdir/$name" ]; do sleep 0.1; done
fi

Running preload_emacs -s ryan will now create an emacs server named 'ryan'. It loaded emacs in a screen session so that it will be able to be a long running process (Emacs apparently cannot run without an interface, hence we run it in a screen session to hide it away out of sight.)

To connect, we run emacsclient -c -s ryan. Typing plain old emacs here will load an entirely new Emacs session, which isn't really what we want. To make it a bit easier I created a shell script called "ec" that will load an emacsclient with these settings automatically:


#!/bin/bash -l
SERVERNAME=ryan
#Attempt to connect to an existing server
emacsclient -c -s $SERVERNAME $*
if [ $? -ne 0 ]
then
#Start a new emacs server and connect
preload_emacs $SERVERNAME 0
emacsclient -c -s $SERVERNAME $*
fi

Now when I type ec it will automatically attempt to connect to an already running emacs server named ryan. If it is not running, it will transparently create the server and then connect to it.

If you make "ec" your system's default editor, you'll now be able to use a lightning quick version of emacs for all your editing needs!


10 Comments »

RSS feed for comments on this post. TrackBack URI

  1. I found your scripts very useful (thanks a lot) but I think there's a mistake at line 18 of preload_emacs:

    echo "Usage: preload_emacs []" []" >&2

    Comment by Pasotaman — June 6, 2007 #

  2. Sorry about my previous message, the forum software mistook some characters form HTML commands. What I was trying to say is that, in line 18, the "less than" character must be changed to a "greater than" to specify output rathen than input.

    Comment by Pasotaman — June 6, 2007 #

  3. That is odd about the input redirect. I'm not even sure why the redirect is even there, it's just an echo statement. It was the same way in the original script I took it from. At any rate, it works as is for me.

    Thanks for dropping by!

    Comment by ryan — June 6, 2007 #

  4. Hummm… perhaps it only works because you are not causing that 'if' clause to be executed. If you try running preload_emacs without any parameters, you'll see the syntax error.

    Anyway, I don't think the 'bug' is very important since it doesn't disrupt normal operation of the script. I was only mentioning it for completitude.

    Comment by Pasotaman — June 6, 2007 #

  5. No syntax error here, I simply get the usage text. I'm removing the redirect in case any one runs into the same problem.

    Comment by ryan — June 6, 2007 #

  6. [...] Multi-TTY Emacs on Gentoo and Ubuntu — much like The Shins in Garden State, running multiTTY emacs will change your life. [...]

    Pingback by genehack.org » Blog Archive » tab dump // 20071022 — October 22, 2007 #

  7. You might want to run emacs in a dtach session instead of a screen one. Especially keys are treated a lot better then, if I recall correctly.

    Comment by Andreas Köhler — January 5, 2008 #

  8. Thanks for the tip, Andreas. That may actually be useful to me, but at a different time.

    The reason for running Emacs in a screen session is not to use Emacs inside screen, but to get the process running in a daemon mode (as opposed to running as a window or normal xterm, which I might accidentally close). As far as I know, it's not possible to run Emacs without a user interface, even if I don't need that particular interface.

    Comment by ryan — January 5, 2008 #

  9. Sure, but what does screen give you for emacs that dtach does not? Here, I use
    alias demacs='dtach -A '~'/demacs emacs -nw'
    Instead of -A (attach || create+attach) you can use -n (create+detach), but my emacs sometimes asks me questions I want to answer on startup :-)
    I suppose you also know 'emacsclient -t' which opens up emacs in your terminal, giving you a vi-like kick-start.

    Comment by Andreas Köhler — January 6, 2008 #

  10. [...] EnigmaCurry with old installation instructions, the wrapper script and the video, Mwolson's [...]

    Pingback by Multi-tty Emacs on Ubuntu « The Lumber Room — May 11, 2008 #

Leave a comment

XHTML: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>

Powered by WordPress.
Entries and comments feeds. Valid XHTML and CSS. ^Top^
XML Sitemap