Added f, t movements

This commit is contained in:
斟酌 鵬兄 2016-04-03 19:46:35 +08:00
parent 2b3eb9db31
commit 4529f4b4a1
3 changed files with 116 additions and 2 deletions

View File

@ -0,0 +1,82 @@
(function(){
var ns = __namespace( "Components.Vim.Actions" );
/** @type {System.Debug} */
var debug = __import( "System.Debug" );
var beep = __import( "Components.Vim.Beep" );
/** @type {Components.Vim.IAction} */
var TO = function( Cursor )
{
/** @type {Components.Vim.Cursor} */
this.__cursor = Cursor;
this.__msg = "<TO COMMAND>";
Cursor.suppressEvent();
};
TO.prototype.dispose = function()
{
this.__cursor.unsuppressEvent();
};
TO.prototype.handler = function( em, et )
{
et.preventDefault();
var cur = this.__cursor;
var f = cur.feeder;
var n = cur.getLine().lineNum;
var p = f.content.indexOf( "\n" );
for( i = 1; p != -1 && i < n; i ++ )
{
p = f.content.indexOf( "\n", p + 1 );
}
var upperLimit = f.content.indexOf( "\n", p + 1 );
if( 0 < n ) p ++;
var lowerLimmit = p;
var cX = cur.X;
var tX = cX;
var Char = et.key;
if( et.kMap( "Tab" ) )
{
Char = "\t";
}
if( 1 < Char.length )
{
beep();
return;
}
// Forward
if( em.kMap( "t" ) || em.kMap( "f" ) )
{
tX = f.content.indexOf( Char, p + cX + 1 );
}
// backward
else
{
tX = f.content.lastIndexOf( Char, p + cX - 1 );
}
if( lowerLimmit <= tX && tX < upperLimit )
{
cur.moveX( tX - lowerLimmit - cX );
}
else beep();
};
TO.prototype.getMessage = function()
{
return this.__msg;
};
ns[ NS_EXPORT ]( EX_CLASS, "TO", TO );
})();

View File

@ -47,6 +47,8 @@
var COMMA = 188; var FULLSTOP = 190;
var SLASH = 191; var BACK_SLASH = 220;
var ANY_KEY = -1;
var __maps = {};
var Map = function( str )
{
@ -169,8 +171,9 @@
{
var compReg = this.__compositeReg[i];
var keys = compReg.keys;
var key = keys[ compReg.i ++ ];
if( keys[ compReg.i ++ ] == kCode )
if( key == ANY_KEY || key == kCode )
{
if( compReg.i == keys.length )
{
@ -405,8 +408,38 @@
);
break;
case SHIFT + T: // To
case T: // To
this.__cMovement = true;
this.__composite( e, function( e2 ) {
var oX = ccur.X;
ccur.openRunAction( "TO", e, e2 );
if( ccur.X < oX )
{
ccur.moveX( 1 );
}
else if( oX < ccur.X )
{
ccur.moveX( -1 );
}
}, ANY_KEY );
break;
case SHIFT + F: // To
case F: // To
this.__cMovement = true;
this.__composite( e, function( e2 ) {
ccur.openRunAction( "TO", e, e2 );
}, ANY_KEY );
break;
case I: // In between boundary
if( !ccur.action )
{

View File

@ -137,7 +137,6 @@
this.moveX( - Number.MAX_VALUE );
this.moveX( jumpX, false, phantomSpace );
};
// 0 will be treated as default ( 1 )