forked from Botanical/BotanJS
Merge remote-tracking branch 'vim/master' into Astro
This commit is contained in:
commit
4ce1473d1c
@ -37,6 +37,7 @@
|
|||||||
this.__stator = new Stator( Cursor );
|
this.__stator = new Stator( Cursor );
|
||||||
this.__minReach = 0;
|
this.__minReach = 0;
|
||||||
this.__insertLen = 0;
|
this.__insertLen = 0;
|
||||||
|
this.__chopIndent = false;
|
||||||
|
|
||||||
// Initialize this stack
|
// Initialize this stack
|
||||||
this.__rec( "", true );
|
this.__rec( "", true );
|
||||||
@ -52,6 +53,7 @@
|
|||||||
|
|
||||||
INSERT.prototype.dispose = function()
|
INSERT.prototype.dispose = function()
|
||||||
{
|
{
|
||||||
|
if( this.__chopIndent ) this.__realizeIndent();
|
||||||
if( this.__cancelIndent() )
|
if( this.__cancelIndent() )
|
||||||
{
|
{
|
||||||
this.__cursor.feeder.pan();
|
this.__cursor.feeder.pan();
|
||||||
@ -175,6 +177,8 @@
|
|||||||
|
|
||||||
var f = cur.aPos;
|
var f = cur.aPos;
|
||||||
|
|
||||||
|
var chopIndent = feeder.content[ f ] != "\n";
|
||||||
|
|
||||||
feeder.content =
|
feeder.content =
|
||||||
feeder.content.substring( 0, f )
|
feeder.content.substring( 0, f )
|
||||||
+ inputChar
|
+ inputChar
|
||||||
@ -187,6 +191,7 @@
|
|||||||
cur.moveY( 1 );
|
cur.moveY( 1 );
|
||||||
cur.lineStart();
|
cur.lineStart();
|
||||||
this.__autoIndent( e );
|
this.__autoIndent( e );
|
||||||
|
this.__chopIndent = chopIndent;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -218,6 +223,7 @@
|
|||||||
|
|
||||||
INSERT.prototype.__autoIndent = function( e )
|
INSERT.prototype.__autoIndent = function( e )
|
||||||
{
|
{
|
||||||
|
var oInd = this.__phantomIndent;
|
||||||
var carried = this.__cancelIndent();
|
var carried = this.__cancelIndent();
|
||||||
|
|
||||||
var cur = this.__cursor;
|
var cur = this.__cursor;
|
||||||
@ -237,7 +243,7 @@
|
|||||||
line = feeder.content.substring( i + 1, j - 1 );
|
line = feeder.content.substring( i + 1, j - 1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
var inDel = "";
|
var inDel = carried ? oInd[ IN_DEL ] : "";
|
||||||
// Indent removed
|
// Indent removed
|
||||||
for( var ir = f; "\t ".indexOf( feeder.content[ ir ] ) != -1; ir ++ )
|
for( var ir = f; "\t ".indexOf( feeder.content[ ir ] ) != -1; ir ++ )
|
||||||
{
|
{
|
||||||
|
@ -15,10 +15,6 @@
|
|||||||
|
|
||||||
var occurence = __import( "System.utils.Perf.CountSubstr" );
|
var occurence = __import( "System.utils.Perf.CountSubstr" );
|
||||||
|
|
||||||
var REPL_BEFORE = 0;
|
|
||||||
var REPL_OFFSET = 1;
|
|
||||||
var REPL_LENGTH = 2;
|
|
||||||
|
|
||||||
/** @type {Components.Vim.IAction}
|
/** @type {Components.Vim.IAction}
|
||||||
* Cursor @param {Components.Vim.Cursor}
|
* Cursor @param {Components.Vim.Cursor}
|
||||||
* e @param {Components.Vim.ActionEvent}
|
* e @param {Components.Vim.ActionEvent}
|
||||||
@ -32,8 +28,8 @@
|
|||||||
|
|
||||||
this.__slineNum = Cursor.getLine().lineNum;
|
this.__slineNum = Cursor.getLine().lineNum;
|
||||||
|
|
||||||
this.__lines = e.count;
|
this.__lines = e.count - 1;
|
||||||
debug.Info( "Open shift: " + this.__lines + " line(s) below the cursor" );
|
debug.Info( "Open shift: " + this.__lines + " line(s) from the cursor" );
|
||||||
|
|
||||||
this.__direction = e.kMap( ">" ) ? 1 : -1;
|
this.__direction = e.kMap( ">" ) ? 1 : -1;
|
||||||
debug.Info( "Direction is: " + ( this.__direction == 1 ? ">" : "<" ) );
|
debug.Info( "Direction is: " + ( this.__direction == 1 ? ">" : "<" ) );
|
||||||
@ -66,7 +62,7 @@
|
|||||||
|
|
||||||
if( 1 < e.count )
|
if( 1 < e.count )
|
||||||
{
|
{
|
||||||
nline += e.count;
|
nline += ( e.count - 1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
// default: >>, <<, >l, <h
|
// default: >>, <<, >l, <h
|
||||||
@ -83,6 +79,21 @@
|
|||||||
|
|
||||||
if( this.__startX != currAp )
|
if( this.__startX != currAp )
|
||||||
{
|
{
|
||||||
|
start = 0; end = 0;
|
||||||
|
|
||||||
|
if( nline )
|
||||||
|
{
|
||||||
|
if( currAp < sp )
|
||||||
|
{
|
||||||
|
start -= ( nline - 1 );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
end += ( nline - 1 );
|
||||||
|
}
|
||||||
|
console.log( start, end );
|
||||||
|
}
|
||||||
|
|
||||||
if( currAp < sp )
|
if( currAp < sp )
|
||||||
{
|
{
|
||||||
sp = sp + currAp;
|
sp = sp + currAp;
|
||||||
@ -90,7 +101,6 @@
|
|||||||
sp = sp - currAp;
|
sp = sp - currAp;
|
||||||
}
|
}
|
||||||
|
|
||||||
start = end = 0;
|
|
||||||
for( var i = 0; i < currAp; i ++ )
|
for( var i = 0; i < currAp; i ++ )
|
||||||
{
|
{
|
||||||
if( feeder.content[ i ] == "\n" )
|
if( feeder.content[ i ] == "\n" )
|
||||||
@ -261,7 +271,15 @@
|
|||||||
|
|
||||||
if( end < j ) break;
|
if( end < j ) break;
|
||||||
|
|
||||||
var line = c.substring( 1 < i ? i : i - 1, c.indexOf( "\n", i ) );
|
var line = c.indexOf( "\n", i );
|
||||||
|
if( ~line )
|
||||||
|
{
|
||||||
|
line = c.substring( 1 < i ? i : i - 1, line );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
line = c.substring( 1 < i ? i : i - 1 );
|
||||||
|
}
|
||||||
|
|
||||||
if( 1 < i )
|
if( 1 < i )
|
||||||
{
|
{
|
||||||
@ -291,7 +309,11 @@
|
|||||||
if( !~"\t ".indexOf( line[ sj ] ) ) break;
|
if( !~"\t ".indexOf( line[ sj ] ) ) break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if( startC != "\t" ) break;
|
else if( startC == "\t" )
|
||||||
|
{
|
||||||
|
sj ++;
|
||||||
|
}
|
||||||
|
else break;
|
||||||
}
|
}
|
||||||
|
|
||||||
indentedLine = line.substring( sj );
|
indentedLine = line.substring( sj );
|
||||||
@ -305,7 +327,9 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
var nPos = feeder.content.length;
|
var nPos = feeder.content.length;
|
||||||
feeder.content += "\n" + c.substring( i ) + "\n";
|
feeder.content += "\n";
|
||||||
|
|
||||||
|
if( ~i ) feeder.content += c.substring( i ) + "\n";
|
||||||
feeder.pan();
|
feeder.pan();
|
||||||
|
|
||||||
cur.moveTo( nPos );
|
cur.moveTo( nPos );
|
||||||
|
@ -21,13 +21,16 @@
|
|||||||
var TAB = 9;
|
var TAB = 9;
|
||||||
var ENTER = 13;
|
var ENTER = 13;
|
||||||
var DELETE = 46;
|
var DELETE = 46;
|
||||||
|
var SPACE = 32;
|
||||||
|
|
||||||
var UP = 38; var DOWN = 40; var LEFT = 37; var RIGHT = 39;
|
var UP = 38; var DOWN = 40; var LEFT = 37; var RIGHT = 39;
|
||||||
|
|
||||||
var _0 = 48; var _1 = 49; var _2 = 50; var _3 = 51; var _4 = 52;
|
var _0 = 48; var _1 = 49; var _2 = 50; var _3 = 51; var _4 = 52;
|
||||||
var _5 = 53; var _6 = 54; var _7 = 55; var _8 = 56; var _9 = 57;
|
var _5 = 53; var _6 = 54; var _7 = 55; var _8 = 56; var _9 = 57;
|
||||||
|
|
||||||
var SEMI_COLON = 59;
|
var SEMI_COLON = 59; var GECKO_SEMI_COLON = 186;
|
||||||
|
|
||||||
|
var EQUAL = 61; var GECKO_EQUAL = 187;
|
||||||
|
|
||||||
var A = 65; var B = 66; var C = 67; var D = 68; var E = 69;
|
var A = 65; var B = 66; var C = 67; var D = 68; var E = 69;
|
||||||
var F = 70; var G = 71; var H = 72; var I = 73; var J = 74;
|
var F = 70; var G = 71; var H = 72; var I = 73; var J = 74;
|
||||||
@ -44,6 +47,7 @@
|
|||||||
var F6 = 117; var F7 = 118; var F8 = 119; var F9 = 120; var F10 = 121;
|
var F6 = 117; var F7 = 118; var F8 = 119; var F9 = 120; var F10 = 121;
|
||||||
var F11 = 122; var F12 = 123;
|
var F11 = 122; var F12 = 123;
|
||||||
|
|
||||||
|
var DASH = 173; var GECKO_DASH = 189;
|
||||||
var COMMA = 188; var FULLSTOP = 190;
|
var COMMA = 188; var FULLSTOP = 190;
|
||||||
var SLASH = 191; var BACK_SLASH = 220;
|
var SLASH = 191; var BACK_SLASH = 220;
|
||||||
|
|
||||||
@ -139,6 +143,59 @@
|
|||||||
return __maps[ str ] = kCode;
|
return __maps[ str ] = kCode;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Polyfill for Chrome < 51
|
||||||
|
var RMap = function( kCode )
|
||||||
|
{
|
||||||
|
switch( kCode )
|
||||||
|
{
|
||||||
|
case SPACE: return " ";
|
||||||
|
case A: return "a"; case B: return "b"; case C: return "c"; case D: return "d";
|
||||||
|
case E: return "e"; case F: return "f"; case G: return "g"; case H: return "h";
|
||||||
|
case I: return "i"; case J: return "j"; case K: return "k"; case L: return "l";
|
||||||
|
case M: return "m"; case N: return "n"; case O: return "o"; case P: return "p";
|
||||||
|
case Q: return "q"; case R: return "r"; case S: return "s"; case T: return "t";
|
||||||
|
case U: return "u"; case V: return "v"; case W: return "w"; case X: return "x";
|
||||||
|
case Y: return "y"; case Z: return "z";
|
||||||
|
case _1: return "1"; case _2: return "2"; case _3: return "3";
|
||||||
|
case _4: return "4"; case _5: return "5"; case _6: return "6"; case _7: return "7";
|
||||||
|
case _8: return "8"; case _9: return "9"; case _0: return "0";
|
||||||
|
|
||||||
|
case S_BRACKET_L: return "["; case S_BRACKET_R: return "]";
|
||||||
|
case SEMI_COLON: case GECKO_SEMI_COLON: return ";";
|
||||||
|
case QUOTE: return "'"; case COMMA: return ",";
|
||||||
|
case FULLSTOP: return "."; case SLASH: return "/"; case BACK_SLASH: return "\\";
|
||||||
|
case DASH: case GECKO_DASH: return "-"; case EQUAL: case GECKO_EQUAL: return "=";
|
||||||
|
|
||||||
|
case SHIFT + _1: return "!"; case SHIFT + _2: return "@"; case SHIFT + _3: return "#";
|
||||||
|
case SHIFT + _4: return "$"; case SHIFT + _5: return "%"; case SHIFT + _6: return "^";
|
||||||
|
case SHIFT + _7: return "&"; case SHIFT + _8: return "*"; case SHIFT + _9: return "(";
|
||||||
|
case SHIFT + _0: return ")";
|
||||||
|
|
||||||
|
case SHIFT + S_BRACKET_L: return "{"; case SHIFT + S_BRACKET_R: return "}";
|
||||||
|
case SHIFT + SEMI_COLON: case SHIFT + GECKO_SEMI_COLON: return ":";
|
||||||
|
case SHIFT + QUOTE: return "\"";
|
||||||
|
case SHIFT + COMMA: return "<"; case SHIFT + FULLSTOP: return ">";
|
||||||
|
case SHIFT + SLASH: return "?"; case SHIFT + BACK_SLASH: return "|";
|
||||||
|
case SHIFT + DASH: case SHIFT + GECKO_DASH: return "_";
|
||||||
|
case SHIFT + EQUAL: case SHIFT + GECKO_EQUAL: return "+";
|
||||||
|
|
||||||
|
case SHIFT + A: return "A"; case SHIFT + B: return "B"; case SHIFT + C: return "C";
|
||||||
|
case SHIFT + D: return "D"; case SHIFT + E: return "E"; case SHIFT + F: return "F";
|
||||||
|
case SHIFT + G: return "G"; case SHIFT + H: return "H"; case SHIFT + I: return "I";
|
||||||
|
case SHIFT + J: return "J"; case SHIFT + K: return "K"; case SHIFT + L: return "L";
|
||||||
|
case SHIFT + M: return "M"; case SHIFT + N: return "N"; case SHIFT + O: return "O";
|
||||||
|
case SHIFT + P: return "P"; case SHIFT + Q: return "Q"; case SHIFT + R: return "R";
|
||||||
|
case SHIFT + S: return "S"; case SHIFT + T: return "T"; case SHIFT + U: return "U";
|
||||||
|
case SHIFT + V: return "V"; case SHIFT + W: return "W"; case SHIFT + X: return "X";
|
||||||
|
case SHIFT + Y: return "Y"; case SHIFT + Z: return "Z";
|
||||||
|
case ESC: return "Escape"; case BACKSPACE: return "Backspace"; case DELETE: return "Delete";
|
||||||
|
case SHIFT: return "Shift"; case ALT: return "Alt"; case CTRL: return "Control";
|
||||||
|
case ENTER: return "Enter"; case TAB: return "Tab";
|
||||||
|
}
|
||||||
|
|
||||||
|
return "?";
|
||||||
|
};
|
||||||
|
|
||||||
var Controls = function( vimArea )
|
var Controls = function( vimArea )
|
||||||
{
|
{
|
||||||
/** @type {Components.Vim.VimArea} */
|
/** @type {Components.Vim.VimArea} */
|
||||||
@ -277,6 +334,7 @@
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case SHIFT + SEMI_COLON: // ":" Command line
|
case SHIFT + SEMI_COLON: // ":" Command line
|
||||||
|
case SHIFT + GECKO_SEMI_COLON:
|
||||||
this.__divedCCmd = new ExCommand( ccur, ":" );
|
this.__divedCCmd = new ExCommand( ccur, ":" );
|
||||||
this.__divedCCmd.handler( e );
|
this.__divedCCmd.handler( e );
|
||||||
break;
|
break;
|
||||||
@ -349,7 +407,13 @@
|
|||||||
_self.__mod = false;
|
_self.__mod = false;
|
||||||
}, ANY_KEY );
|
}, ANY_KEY );
|
||||||
break;
|
break;
|
||||||
case _0: case _1: case _2: case _3: case _4:
|
case _0: // No 0 for first count
|
||||||
|
if( !this.__compositeReg )
|
||||||
|
{
|
||||||
|
mod = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case _1: case _2: case _3: case _4:
|
||||||
case _5: case _6: case _7: case _8: case _9:
|
case _5: case _6: case _7: case _8: case _9:
|
||||||
|
|
||||||
var Count = e.key;
|
var Count = e.key;
|
||||||
@ -412,10 +476,12 @@
|
|||||||
switch( kCode )
|
switch( kCode )
|
||||||
{
|
{
|
||||||
case BACKSPACE: this.__cMoveX( -1, true ); break; // Backspace, go back 1 char
|
case BACKSPACE: this.__cMoveX( -1, true ); break; // Backspace, go back 1 char
|
||||||
case H: this.__cMoveX( -1 ); break; // Left
|
case H: this.__cMoveX( - e.count ); break; // Left
|
||||||
case L: this.__cMoveX( 1 ); break; // Right
|
case L: this.__cMoveX( e.count ); break; // Right
|
||||||
case K: this.__cMoveY( -1 ); break; // Up
|
case DASH: case GECKO_DASH:
|
||||||
case J: this.__cMoveY( 1 ); break; // Down
|
case K: this.__cMoveY( - e.count ); break; // Up
|
||||||
|
case ENTER:
|
||||||
|
case J: this.__cMoveY( e.count ); break; // Down
|
||||||
|
|
||||||
case CTRL + F: // Page Down
|
case CTRL + F: // Page Down
|
||||||
if( cfeeder.firstBuffer.nextLine.placeholder )
|
if( cfeeder.firstBuffer.nextLine.placeholder )
|
||||||
@ -650,17 +716,21 @@
|
|||||||
this.__divedCCmd.dispose();
|
this.__divedCCmd.dispose();
|
||||||
this.__cMovement = false;
|
this.__cMovement = false;
|
||||||
this.__divedCCmd = null;
|
this.__divedCCmd = null;
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( e.canceled ) return;
|
if( e.canceled ) return;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.__modCommand( e );
|
|
||||||
if( e.canceled ) return;
|
|
||||||
|
|
||||||
var cfeeder = this.__cfeeder;
|
var cfeeder = this.__cfeeder;
|
||||||
var ccur = this.__ccur;
|
var ccur = this.__ccur;
|
||||||
|
|
||||||
|
if( !ccur.action || ccur.action.allowMovement )
|
||||||
|
{
|
||||||
|
this.__modCommand( e );
|
||||||
|
if( e.canceled ) return;
|
||||||
|
}
|
||||||
|
|
||||||
var kCode = e.keyCode;
|
var kCode = e.keyCode;
|
||||||
|
|
||||||
// Action commands are handled by the actions themselves
|
// Action commands are handled by the actions themselves
|
||||||
@ -729,7 +799,7 @@
|
|||||||
+ ( e.altKey ? ALT : 0 );
|
+ ( e.altKey ? ALT : 0 );
|
||||||
|
|
||||||
this.__modKeys = c == KEY_SHIFT || c == KEY_CTRL || c == KEY_ALT;
|
this.__modKeys = c == KEY_SHIFT || c == KEY_CTRL || c == KEY_ALT;
|
||||||
this.__key = e.key;
|
this.__key = e.key || RMap( this.__kCode );
|
||||||
}
|
}
|
||||||
|
|
||||||
this.__count = 1;
|
this.__count = 1;
|
||||||
|
Loading…
Reference in New Issue
Block a user