* No reall progress on multi line... dur.
This commit is contained in:
parent
f9358d04cd
commit
a24b1045ff
|
@ -8,6 +8,7 @@ var ansi = require('./ansi_term.js');
|
||||||
|
|
||||||
var assert = require('assert');
|
var assert = require('assert');
|
||||||
var _ = require('lodash');
|
var _ = require('lodash');
|
||||||
|
var GapBuffer = require('gapbuffer').GapBuffer;
|
||||||
|
|
||||||
|
|
||||||
//
|
//
|
||||||
|
@ -47,14 +48,21 @@ function MultiLineEditTextView(options) {
|
||||||
|
|
||||||
View.call(this, options);
|
View.call(this, options);
|
||||||
|
|
||||||
if(0 !== this.position.col) {
|
//
|
||||||
// :TODO: experimental - log this as warning if kept
|
// defualt tabWidth is 4
|
||||||
this.position.col = 0;
|
// See the following:
|
||||||
}
|
// * http://www.ansi-bbs.org/ansi-bbs2/control_chars/
|
||||||
|
// * http://www.bbsdocumentary.com/library/PROGRAMS/GRAPHICS/ANSI/bansi.txt
|
||||||
|
//
|
||||||
|
this.tabWidth = _.isNumber(options.tabWidth) ? options.tabWidth : 8;
|
||||||
|
this.tabString = new Array(self.tabWidth).join(' ');
|
||||||
|
|
||||||
|
|
||||||
var self = this;
|
var self = this;
|
||||||
|
|
||||||
|
this.renderBuffer = [];
|
||||||
|
this.textBuffer = new GapBuffer(1024);
|
||||||
|
|
||||||
this.lines = []; // a given line is text...until EOL
|
this.lines = []; // a given line is text...until EOL
|
||||||
this.topLineIndex = 0;
|
this.topLineIndex = 0;
|
||||||
this.cursorPos = { x : 0, y : 0 }; // relative to view window
|
this.cursorPos = { x : 0, y : 0 }; // relative to view window
|
||||||
|
@ -97,23 +105,24 @@ function MultiLineEditTextView(options) {
|
||||||
};
|
};
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
this.createScrollRegion = function() {
|
this.createScrollRegion = function() {
|
||||||
self.client.term.write(ansi.setScrollRegion(self.position.row, self.position.row + 5));//self.dimens.height));
|
self.client.term.write(ansi.setScrollRegion(self.position.row, self.position.row + 5));//self.dimens.height));
|
||||||
};
|
};
|
||||||
|
*/
|
||||||
|
|
||||||
this.redrawViewableText = function() {
|
this.redrawViewableText = function() {
|
||||||
var x = self.position.row;
|
var row = self.position.row;
|
||||||
var bottom = x + self.dimens.height;
|
var bottom = row + self.dimens.height;
|
||||||
var index = self.topLineIndex;
|
var i = self.topLineIndex;
|
||||||
|
|
||||||
self.client.term.write(self.getSGR());
|
self.client.term.write(self.getSGR());
|
||||||
|
|
||||||
while(index < self.lines.length && x < bottom) {
|
while(i < self.renderBuffer.length && row < bottom) {
|
||||||
self.client.term.write(ansi.goto(x, this.position.col));
|
self.client.term.write(ansi.goto(row, this.position.col));
|
||||||
self.writeLine(self.lines[index]);
|
self.client.term.write(self.renderBuffer[i]);
|
||||||
console.log(self.lines[index])
|
++row;
|
||||||
++x;
|
++i;
|
||||||
++index;
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -130,18 +139,32 @@ function MultiLineEditTextView(options) {
|
||||||
return line.match(re) || [];
|
return line.match(re) || [];
|
||||||
};
|
};
|
||||||
|
|
||||||
this.writeLine = function(s) {
|
this.regenerateRenderBuffer = function() {
|
||||||
//
|
self.renderBuffer = [];
|
||||||
// Hello, World\n
|
|
||||||
// \tThis is a test, it is only a test!
|
|
||||||
//
|
|
||||||
// Loop through |s| finding control characters & processing them
|
|
||||||
// with our own internal handling.
|
|
||||||
|
|
||||||
var clean = s.replace(/[\x00-\x1F\x7F-\x9F]/g, '');
|
// :TODO: optimize this by only rending what is visible -- or at least near there, e.g. topindex -> maxchars that can fit at most
|
||||||
self.client.term.write(clean);
|
|
||||||
|
// :TODO: asArray() should take a optional scope, e.g. asArray(beg, end)
|
||||||
|
var lines = self.textBuffer.asArray()
|
||||||
|
.join('')
|
||||||
|
.replace(/\t/g, self.tabString)
|
||||||
|
.split(/\r\n|\n|\r/g);
|
||||||
|
|
||||||
|
var maxLines = self.dimens.height - self.position.row;
|
||||||
|
|
||||||
|
for(var i = 0; i < lines.length && self.renderBuffer.length < maxLines; ++i) {
|
||||||
|
if(0 === lines[i].length) {
|
||||||
|
self.renderBuffer.push('');
|
||||||
|
} else {
|
||||||
|
Array.prototype.push.apply(self.renderBuffer, self.wordWrap(lines[i]));
|
||||||
|
}
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
this.getTextBufferPosition = function(row, col) {
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
this.scrollUp = function(count) {
|
this.scrollUp = function(count) {
|
||||||
|
|
||||||
};
|
};
|
||||||
|
@ -150,7 +173,7 @@ function MultiLineEditTextView(options) {
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
this.keyUp = function() {
|
this.cursorUp = function() {
|
||||||
if(self.cursorPos.row > 0) {
|
if(self.cursorPos.row > 0) {
|
||||||
self.cursorPos.row--;
|
self.cursorPos.row--;
|
||||||
console.log(self.lines[self.getLineIndex()])
|
console.log(self.lines[self.getLineIndex()])
|
||||||
|
@ -181,8 +204,8 @@ MultiLineEditTextView.prototype.setPosition = function(pos) {
|
||||||
MultiLineEditTextView.prototype.redraw = function() {
|
MultiLineEditTextView.prototype.redraw = function() {
|
||||||
MultiLineEditTextView.super_.prototype.redraw.call(this);
|
MultiLineEditTextView.super_.prototype.redraw.call(this);
|
||||||
|
|
||||||
//this.redrawViewableText();
|
this.redrawViewableText();
|
||||||
this.client.term.write(this.text);
|
//this.client.term.write(this.text);
|
||||||
};
|
};
|
||||||
|
|
||||||
/*MultiLineEditTextView.prototype.setFocus = function(focused) {
|
/*MultiLineEditTextView.prototype.setFocus = function(focused) {
|
||||||
|
@ -192,19 +215,36 @@ MultiLineEditTextView.prototype.redraw = function() {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
MultiLineEditTextView.prototype.setText = function(text) {
|
MultiLineEditTextView.prototype.setText = function(text) {
|
||||||
// :TODO: text.split(/\r\n|\n|\r/))
|
|
||||||
//this.lines = text.split(/\r?\n/);
|
|
||||||
|
|
||||||
//this.cursorPos.row = this.position.row + this.dimens.height;
|
//this.cursorPos.row = this.position.row + this.dimens.height;
|
||||||
this.lines = this.wordWrap(text);
|
//this.lines = this.wordWrap(text);
|
||||||
this.createScrollRegion();
|
|
||||||
|
|
||||||
this.text = text;
|
if(this.textBuffer.length > 0) { // :TODO: work around GapBuffer bug: if it's already empty this will cause gapEnd to be undefined
|
||||||
|
this.textBuffer.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
//this.textBuffer.insertAll(0, text);
|
||||||
|
text = text.replace(/\b/g, '');
|
||||||
|
|
||||||
|
var c;
|
||||||
|
for(var i = 0; i < text.length; ++i) {
|
||||||
|
c = text[i];
|
||||||
|
|
||||||
|
// :TODO: what should really be removed here??? Any non-printable besides \t and \r\n?
|
||||||
|
if('\b' === c) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.textBuffer.insert(i, c);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.regenerateRenderBuffer();
|
||||||
|
|
||||||
|
console.log(this.renderBuffer)
|
||||||
}
|
}
|
||||||
|
|
||||||
MultiLineEditTextView.prototype.onSpecialKeyPress = function(keyName) {
|
MultiLineEditTextView.prototype.onSpecialKeyPress = function(keyName) {
|
||||||
if(this.isSpecialKeyMapped('up', keyName)) {
|
if(this.isSpecialKeyMapped('up', keyName)) {
|
||||||
this.keyUp();
|
this.cursorUp();
|
||||||
} else if(this.isSpecialKeyMapped('down', keyName)) {
|
} else if(this.isSpecialKeyMapped('down', keyName)) {
|
||||||
|
|
||||||
} else if(this.isSpecialKeyMapped('left', keyName)) {
|
} else if(this.isSpecialKeyMapped('left', keyName)) {
|
||||||
|
|
|
@ -371,7 +371,7 @@
|
||||||
"MT1" : {
|
"MT1" : {
|
||||||
"width" : 67,
|
"width" : 67,
|
||||||
"height" : 17,
|
"height" : 17,
|
||||||
"text" : "Hints:\n * Press CTRL-Y to clear a line\n * Arrow keys to move around\n\nTry editing the text below:\nLet me be sick... I want to get up. Get me something to be sick in... Stop the film... Please stop it... I can't stand it any more. Stop it please... please.\n\nWell, that was a very promising start. By my calculations, you should be starting to feel alright again. Yes? Dr. Brodsky's pleased with you. Now tomorrow there'll be two sessions, of course, morning and afternoon.\n\nYou mean, I have to viddy two sessions in one day?\n\nI imagine you'll be feeling a little bit limp by the end of the day. But we have to be hard on you. You have to be cured.\n",
|
"text" : "Hints:\n * Press CTRL-Y to clear a line\n * Arrow keys to move around\n\nTry editing the text below:\nThis\tis\ttabbbed!\nLet me be sick... I want to get up. Get me something to be sick in... Stop the film... Please stop it... I can't stand it any more. Stop it please... please.\n\nWell, that was a very promising start. By my calculations, you should be starting to feel alright again. Yes? Dr. Brodsky's pleased with you. Now tomorrow there'll be two sessions, of course, morning and afternoon.\n\nYou mean, I have to viddy two sessions in one day?\n\nI imagine you'll be feeling a little bit limp by the end of the day. But we have to be hard on you. You have to be cured.\n",
|
||||||
"focus" : true
|
"focus" : true
|
||||||
},
|
},
|
||||||
"BT5" : {
|
"BT5" : {
|
||||||
|
|
Loading…
Reference in New Issue