forked from Botanical/BotanJS
Added f, t movements
This commit is contained in:
parent
2b3eb9db31
commit
4529f4b4a1
82
botanjs/src/Components/Vim/Actions/TO.js
Normal file
82
botanjs/src/Components/Vim/Actions/TO.js
Normal 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 );
|
||||
})();
|
@ -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 )
|
||||
{
|
||||
|
@ -137,7 +137,6 @@
|
||||
|
||||
this.moveX( - Number.MAX_VALUE );
|
||||
this.moveX( jumpX, false, phantomSpace );
|
||||
|
||||
};
|
||||
|
||||
// 0 will be treated as default ( 1 )
|
||||
|
Loading…
Reference in New Issue
Block a user