<div>Elia,</div><div><br></div><div>I started using TM1 when it was about a year old, but I had to give up on mouse based editors because of the shoulder pain of always reaching for the mouse. I tried using the meta key combinations as a substitute, but after a year of that my hands really hurt.
                </div><div><br></div><div>Several programmers, told me that they had switched to Vim because of similar reasons and that they had much less pain. With Vim, or ST2/Vintage, I can code all day without problems.</div><div><br></div><div>Even though I like Vim, I still feel like it has a lot of flaws and there are times when a mouse is just plain superior no matter how well  you know the magic Vim key combinations. When I tried ST2 with the Vintage plugin, it became clear how much better a hybrid editor could be.</div><div><br></div><div>Some people feel strongly that modes are very un-mac, which I have to agree with. However, even Apple releases modal software that breaks their UI guidelines, because sometimes modes lead to greater productivity. For instance, Final Cut Pro X is filled with no-meta-key key commands (http://www.premiumbeat.com/blog/the-big-cheat-sheet-of-final-cut-pro-x-shortcuts/). </div><div><br></div><div>I certainly wouldn't want to turn TM2 into Vim, but I believe that there are good reasons to optionally offer some key Vim functionality within TM2.</div><div><br></div><div>I am very productive with ST2/Vintage now days, however I believe in choice and I would like to see 2 very good editors both providing a Vim like option. Also, I have an affection for TextMate since it provided me with years of enjoyable use. Finally, with TM2 being open sourced, I feel that it will be around  in 20 years, so that any work I put into it will still benefit me later.</div>
                <div><div><br></div><div>-- </div><div>Hans Stimer</div><div>Sent with <a href="http://www.sparrowmailapp.com/?sig">Sparrow</a></div><div><br></div></div>
                 
                <p style="color: #A0A0A8;">On Saturday, August 11, 2012 at 10:27 AM, Elia Schito wrote:</p>
                <blockquote type="cite" style="border-left-style:solid;border-width:1px;margin-left:0px;padding-left:10px;">
                    <span><div><div><div>I think TextMate is wonderful also because it's so integrated with its platform (OSX).</div><div>OSX relies on "meta" keys to perform tasks and on "letter" keys to input text, which in my opinion is a better paradigm. If you reconsider vim style from this point of view they're very similar: you hold some non-text key instead of hitting ESC+:.</div>

<div><br></div><div>Also most of TM shortcuts work across the whole system (I always hated when after using vim you start typing random letters in the textfields of all you're other programs).</div><div><br></div><div>

So I think integrating vim paradigm is a bad idea, though as a plugin seems more harmless.</div><div>Remember that, besides vim and macvim you have <a href="http://www.sublimetext.com/docs/2/vintage.html" target="_blank">sublime text vintage mode</a> which probably does everything you're asking for. That said I strongly recommend you to stay on TM and maybe go deeper in bundles stuff (after years using it they still make me smile).</div>

<div><br></div><div>Elia</div><div><br></div><div><div>PS. I know to be a bit biased against vim, please forgive me if I've been rough  :)</div><div><br></div></div><div>—<br><span style="background-color:rgb(255,255,255)">☁ <a href="http://twitter.com/elia" target="_blank"><font color="#6666CC">@elia</font></a> </span><font color="#CCCCCC"><span style="background-color:rgb(255,255,255)">(twitter)</span></font><span style="background-color:rgb(255,255,255)"> </span><span style="font-family:arial,sans-serif;font-size:13px;border-collapse:collapse;line-height:15px"><span style="background-color:rgb(255,255,255)">✎ <a href="mailto:elia@schito.me" target="_blank"><font color="#6666CC">elia@schito.me</font></a> </span><font color="#CCCCCC"><span style="background-color:rgb(255,255,255)">(</span></font></span><font color="#CCCCCC"><span style="background-color:rgb(255,255,255)">gtalk)</span></font></div>

<div><span style="background-color:rgb(255,255,255)">☎ <font color="#CCCCCC">(+39)</font><font color="#CC0000"> 348/9051393</font> </span><span style="font-family:arial,sans-serif;font-size:13px;border-collapse:collapse;line-height:15px"><span style="background-color:rgb(255,255,255)"> </span></span><span style="background-color:rgb(255,255,255)"><a href="mailto:perlelia@gmail.com" target="_blank"><font color="#6666CC">perlelia@gmail.com</font></a> </span><font color="#CCCCCC"><span style="background-color:rgb(255,255,255)">(FaceTime)</span></font></div>

<br>
<br><br><div>On Sat, Aug 11, 2012 at 7:16 PM, Hans Stimer <span dir="ltr"><<a href="mailto:hans.stimer@gmail.com" target="_blank">hans.stimer@gmail.com</a>></span> wrote:<br><blockquote type="cite"><div>


                <div><div>I'm looking for advice on the best way to hack minimal Vim support into TM2. I'm not looking to support all of Vim, but just a subset of what might be referred to as Vim normal mode. </div>

<div><br></div><div>Desired behavior</div><div>===</div><div>Until Vim mode is activated, TM2 should behave as normal. Once activated, all the <meta>*-<key> combinations will continue to work as normal TM2 commands, but non-meta key combinations will be interpreted as Vim commands. </div>

<div><br></div><div>Entering Vim normal mode</div><div>---</div><div>Traditionally, Vim normal mode is entered via hitting the escape key.  Since most people won't want Vim behavior, there needs to be a toggle that enables Vim so that the escape key will work. This prevents existing TM2 escape behavior changing for those who don't want the optional Vim behavior.</div>

<div><br></div><div>Additionally, it is not uncommon for Vim users to remap the Vim normal mode entry trigger to something like "jj". This should be supported so that users can have the escape key retain it's traditional TM2 use.</div>

<div><br></div><div>Vim normal mode</div><div>---</div><div>I would like to support the full range of Vim commands for motion, deleting, and changing of text short of entering command mode i.e. ":<command>"</div>

</div><div><br></div><div>Vim command mode</div><div>---</div><div>No support, but maybe a subset later.</div><div><br></div><div>Vim search mode</div><div>---</div><div>I don't think this needs support, however it would be handy for '/' to map to opening the find dialog.</div>

<div><br></div><div><br></div><div>Approaches</div><div>===</div><div>I've spent a little time trying to figure out how to modify TM2 for Vim support and I'm not sure which direction I should go.</div><div><br></div>

<div>1) Hard code it right into TM2. It looks like I could start with OakTextView:keydown and branch off to a Vim interpreter if Vim is enabled. I think this is probably the easiest and most flexible approach. </div><div>

<br></div><div>2) Create a TM2 plugin/bundle that does most of the work, and modify TM2 just enough to provide the support that such a plugin/bundle would need. This approach worries, me because I'm not sure how much modification TM2 would need to expose all the required interface to the plugin system. Do TM2 plugins work the same as TM1 plugins? Is the TM2 plugin API in flux?</div>

<div><br></div><div>Thoughts?</div>
            <br><br>
_______________________________________________<br>
textmate mailing list<br>
<a href="mailto:textmate@lists.macromates.com">textmate@lists.macromates.com</a><br>
<a href="http://lists.macromates.com/listinfo/textmate" target="_blank">http://lists.macromates.com/listinfo/textmate</a><br></div></blockquote></div><br>
</div><div><div><br></div><div>_______________________________________________</div><div>textmate mailing list</div><div><a href="mailto:textmate@lists.macromates.com">textmate@lists.macromates.com</a></div><div><a href="http://lists.macromates.com/listinfo/textmate">http://lists.macromates.com/listinfo/textmate</a></div></div></div></span>
                 
                 
                 
                 
                </blockquote>
                 
                <div>
                    <br>
                </div>