c-d, c-u, HTML, gj, gk & bug fixes

This commit is contained in:
斟酌 鵬兄 2017-01-30 20:13:15 +08:00
parent 06526f00a7
commit 2fda27b7be
2 changed files with 103 additions and 7 deletions

View File

@ -215,9 +215,10 @@
Controls.prototype.__composite = function( e, handler ) Controls.prototype.__composite = function( e, handler )
{ {
if( !this.__compositeReg ) this.__compositeReg = [];
if( handler ) if( handler )
{ {
if( !this.__compositeReg ) this.__compositeReg = [];
this.__compositeReg.push({ this.__compositeReg.push({
keys: Array.prototype.slice.call( arguments, 2 ) keys: Array.prototype.slice.call( arguments, 2 )
, handler: handler , handler: handler
@ -528,7 +529,7 @@
cfeeder.pan( undefined, 1 ); cfeeder.pan( undefined, 1 );
cfeeder.softReset(); cfeeder.softReset();
ccur.moveY( 0 < ccur.Y ? -1 : 0 ); ccur.moveY( 0 < ccur.Y ? -1 : 0 );
ccur.moveX(); ccur.moveX();
break; break;
case CTRL + Y: // Pan Y, Scroll Up case CTRL + Y: // Pan Y, Scroll Up
@ -544,10 +545,33 @@
ccur.moveY( ccur.Y == cfeeder.moreAt ? 0 : 1 ); ccur.moveY( ccur.Y == cfeeder.moreAt ? 0 : 1 );
ccur.moveX(); ccur.moveX();
break; break;
case CTRL + D: // Page Down, keep cursor.Y
cfeeder.pan( undefined, cfeeder.moreAt );
cfeeder.softReset();
ccur.moveY( 0 );
break;
case CTRL + U: // Page Up, keep cursor.Y
if( cfeeder.panY == 0 )
{
beep();
break;
}
cfeeder.pan( undefined, -cfeeder.moreAt );
cfeeder.softReset();
ccur.moveY( 0 );
break;
case SHIFT + H: // First line buffer case SHIFT + H: // First line buffer
ccur.moveY( -ccur.Y );
ccur.lineStart( true );
break;
case SHIFT + M: // Middle line buffer
ccur.moveY( Math.floor( 0.5 * cfeeder.moreAt ) - ccur.Y );
ccur.lineStart( true );
break; break;
case SHIFT + L: // Last line buffer case SHIFT + L: // Last line buffer
ccur.moveY( cfeeder.moreAt - ccur.Y );
ccur.lineStart( true );
break; break;
case _0: // Really line Start case _0: // Really line Start
@ -685,6 +709,45 @@
ccur.moveX( -Number.MAX_VALUE, true ); ccur.moveX( -Number.MAX_VALUE, true );
}, G ); }, G );
// Wordwrap next display line
this.__composite( e, function() {
var dispLine = ccur.getLine( true );
ccur.moveX( dispLine.content.length + 1 );
}, J );
// Wordwrap prev display line
this.__composite( e, function() {
var dispLine = ccur.getLine( true ).prev;
var thisLine = ccur.getLine().lineNum;
if( !dispLine )
{
ccur.lineStart();
beep();
return;
}
if( dispLine.content != "" && dispLine.lineNum == thisLine )
{
ccur.moveX( -( dispLine.content.length + 1 ) );
}
else
{
ccur.moveY( -1 );
var lines = ccur.getLine().visualLines;
if( 1 < lines.length )
{
var l = lines.length - 1;
var j = 0;
for( var i = 0; i < l; i ++ )
{
j += lines[i].content.length;
}
ccur.moveX( j );
}
}
}, K );
// Print Hex // Print Hex
this.__composite( e, function() { this.__composite( e, function() {
ccur.openRunAction( "PRINT_HEX", e ); ccur.openRunAction( "PRINT_HEX", e );

View File

@ -132,7 +132,14 @@
var jumpY = expLineNum - lastLineNum; var jumpY = expLineNum - lastLineNum;
var jumpX = aPos < lineStart ? lineStart - aPos : aPos - lineStart; var jumpX = aPos < lineStart ? lineStart - aPos : aPos - lineStart;
jumpX += Math.ceil( jumpX / pline.cols ) - 1; var kX = jumpX - pline.content.length;
while( 0 < kX )
{
jumpX ++;
pline = pline.next
if(!( pline && pline.lineNum == expLineNum )) break;
kX -= pline.content.length;
}
if( jumpY ) this.moveY( jumpY ); if( jumpY ) this.moveY( jumpY );
@ -256,7 +263,7 @@
if( s == 0 ) if( s == 0 )
{ {
x = 1; x = d;
if ( rline[ 0 ] == "\t" ) if ( rline[ 0 ] == "\t" )
{ {
x += tabStep; x += tabStep;
@ -266,14 +273,19 @@
e += d; e += d;
var ntabs = occurence( rline.substring( s + 1, e + 1 ), "\t" ); var ntabs = occurence( rline.substring( s + 1, e + 1 ), "\t" );
if( 1 < ntabs && rline[ e ] == "\t" ) ntabs --;
x += ntabs * tabStep + isLF; x += ntabs * tabStep + isLF;
if( 1 < d ) x += d - 1; x += Math.max( 0, Math.floor( d / line.cols ) - 1 );
// Reset the distance to 1 as x is now calculated
d = 1;
} }
else // jk, non-X navigation. i.e., pX does not change else // jk, non-X navigation. i.e., pX does not change
{ {
// s = 0, which is unused here // s = 0, which is unused here
e = x + d; e = x + d;
x += ( occurence( rline.substring( 0, e ), "\t" ) ) * tabStep; x += ( occurence( rline.substring( 0, e ), "\t" ) ) * tabStep;
x += Math.floor( x / line.cols );
if( 1 < d ) x += d - 1; if( 1 < d ) x += d - 1;
} }
} }
@ -286,6 +298,13 @@
if( boundary ) if( boundary )
{ {
x = 0 < x ? lineEnd : 0; x = 0 < x ? lineEnd : 0;
// This happens on backspacing max filled lines on INSERT mode
if( d < 0 && 0 < x )
{
boundary = false;
x += d;
}
} }
else if( c == "\n" ) else if( c == "\n" )
{ {
@ -505,7 +524,7 @@
Cursor.prototype.suppressEvent = function() { ++ this.__suppEvt; }; Cursor.prototype.suppressEvent = function() { ++ this.__suppEvt; };
Cursor.prototype.unsuppressEvent = function() { -- this.__suppEvt; }; Cursor.prototype.unsuppressEvent = function() { -- this.__suppEvt; };
Cursor.prototype.getLine = function( raw ) Cursor.prototype.getLine = function( display )
{ {
var feeder = this.feeder; var feeder = this.feeder;
var line = feeder.firstBuffer; var line = feeder.firstBuffer;
@ -513,7 +532,21 @@
for( var i = 0; line != eBuffer; line = line.next ) for( var i = 0; line != eBuffer; line = line.next )
{ {
if( line.br ) i ++; if( line.br ) i ++;
if( this.Y == i ) return line; if( this.Y == i )
{
// Return the display line
if( display )
{
var x = this.aX + 1;
while( 0 < ( x -= line.content.length ) )
{
if( !line.next ) return line;
line = line.next;
}
}
return line;
}
} }
return null; return null;