[TxMt] Re: Difficulty using TextMate as external editor

Steve King sking at arbor.net
Tue Jan 4 16:49:10 UTC 2011


On 2011-01-03 16:39, Ian Greig wrote:
> The "mate" command question
> Another way devised by Tinderbox users involves using a macro to call the
> "mate" command. That brings me full circle. I do not seem to be able to make
> this work, even by invoking the command line directly in Terminal. I would
> like some help with this please.

I know nothing about Tinderbox, but that's not going to keep me from 
jumping in here...

The very first thing you have to do is to install the 'mate' command.  
You say that you "do not seem to be able to make this work, even by 
invoking the command line directly in Terminal." That suggests to me 
that this first step has not been taken.  Refer to the blog posting at 
http://blog.macromates.com/2005/textmate-shell-utility-tmmate/ for 
details, but you'll need to execute these commands:

    mkdir ~/bin
    ln -s /Applications/TextMate.app/Contents/Resources/mate ~/bin/mate


There are other niceties too, but that's the basics.  Now type 
'~/bin/mate /tmp/test' at the Terminal command line.  Does it open a new 
Textmate window editing the file /tmp/test? If so, congratulations! 
You're halfway there.

In general, there are two ways to invoke 'mate' as an external editor.  
The first is as described above, by having Tinderbox (or whatever other 
app) write a temporary file and calling 'mate' to edit it.  You'll 
probably want to give 'mate' the '--wait' option. Without that option, 
the Textmate window is opened and control immediately returns to the 
caller.  Unfortunately, that's the end of the transaction. There's no 
way for the calling program to know when you're done editing.  The 
'--wait' option tells 'mate' not to return control to the caller until 
you've closed the window.  This will signal the calling program that 
it's time to read the temp file back in to get your changes.

To do it this way you'll need to write a macro in Tinderbox that does this:

    save to /tmp/filename
    mate --wait /tmp/filename
    load /tmp/filename


Since I don't know anything about Tinderbox I'm afraid I can't be any 
more specific.

The second way to use 'mate' as an external editor is similar, but 
instead of writing to a temporary file you feed the file to mate on its 
standard input and read the changes back from its standard output. 
"Standard input" (stdin) and "standard output" (stdout) are generic Unix 
terms meaning "what the program reads in from the Terminal" and "what it 
writes back to the Terminal". Only, "Terminal" doesn't have to literally 
be Terminal.app, it can be any other program. If you run the command 'ls 
| less' at the Terminal prompt you're using the pipe ("|") character to 
send the standard output of the 'ls' command to the standard input of 
the 'less' command, instead of sending the output of 'ls' directly back 
to the Terminal window. Piping stdout from one program to the stdin of 
another is the fundamental basis of almost all Unix command-line 
programing. You can chain any number of commands together this way. Try 
typing: 'echo "hello, world" | mate --wait | less' to see what I mean.

To apply this to Tinderbox you'll need to tell it to write to mate's 
standard input and read from mate's standard output. Again, I don't know 
what the syntax would be as a Tinderbox macro, but conceptually 
something like:

    mate --wait
    write file to mate's stdin
    read file from mate's stdout


I can't give you cookie-cutter directions, but hopefully this gives you 
enough understanding of what's going on to figure the rest out yourself.

-- 
Steve King
Sr. Software Engineer
Arbor Networks
+1 734 821 1461
www.arbornetworks.com <http://www.arbornetworks.com/>



More information about the textmate mailing list