Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

new parser #1399

Merged
merged 52 commits into from
May 21, 2018
Merged
Show file tree
Hide file tree
Changes from 48 commits
Commits
Show all changes
52 commits
Select commit Hold shift + click to select a range
fb7e5d5
new parser
jerch Apr 21, 2018
9b085d2
new parser
jerch Apr 21, 2018
73f40ef
merge with master
jerch Apr 21, 2018
20760d0
utilize more typescript features
jerch Apr 22, 2018
f976707
new parser
jerch Apr 21, 2018
c8910cc
utilize more typescript features
jerch Apr 22, 2018
55993ad
merge with remote
jerch Apr 23, 2018
a058395
move addChar to ParserTerminal
jerch Apr 24, 2018
c0ab2b9
rename enums
jerch Apr 24, 2018
9eb107a
first handler API changes
jerch Apr 24, 2018
b72cdad
move switches to jump tables
jerch Apr 29, 2018
9d2bbd1
remove term from EscapeSequenceParser
jerch Apr 29, 2018
2d77fcf
merge ParserTerminal with InputHandler
jerch Apr 29, 2018
27a3347
Merge branch 'master' into new_parser
jerch Apr 29, 2018
dc14f52
fix InputHandler
jerch Apr 29, 2018
0f3d82a
faster print action
jerch Apr 29, 2018
826cca7
fix import issue
jerch Apr 29, 2018
a55a7f3
some cleanup
jerch Apr 29, 2018
f5375c3
fix error in esc handler call
jerch Apr 30, 2018
a103526
add array fallback for TransitionTable
jerch Apr 30, 2018
b158176
local .buffer in parse
jerch Apr 30, 2018
645cd2e
fix test cases
jerch Apr 30, 2018
dbc6b12
missing whitespace
jerch Apr 30, 2018
ba6fcdd
real merge of InputHandler and ParserTerminal
jerch Apr 30, 2018
af392a6
cleanup, some docs, temp fix for InputHandler tests
jerch Apr 30, 2018
aeae688
multiple changes in InputHandler:
jerch May 1, 2018
0535f5d
unified method signature in InputHandler, moved some CSI condition in…
jerch May 1, 2018
2eeb7b8
ESC and OSC method entries for InputHandler
jerch May 1, 2018
c7fdff2
several changes:
jerch May 1, 2018
728eeeb
set member through ctor argument
jerch May 1, 2018
0c200f2
remove collect from args where not needed
jerch May 1, 2018
89cf45c
save func pointer in local var
jerch May 1, 2018
9a32852
single arg for DCS and ESC handler registration
jerch May 1, 2018
d090cbe
some docs
jerch May 1, 2018
536b3a8
fix member scope and tests
jerch May 1, 2018
25ff77a
fix transition definitions
jerch May 1, 2018
a1a4cac
dcs handler implementations
jerch May 1, 2018
c069e94
Merge branch 'master' into new_parser
jerch May 1, 2018
0f8d225
fix identation
jerch May 1, 2018
6cefb4c
more test cases
jerch May 5, 2018
edb06c6
Add copyright header
Tyriar May 5, 2018
362d769
Some polish
Tyriar May 5, 2018
108aa5a
test Uint8Array and Array; fix Uint8Array type
jerch May 6, 2018
551ccc0
explicit arguments for fallback handlers
jerch May 6, 2018
a37449a
some docs cleanup
jerch May 6, 2018
02893dc
fix some docs
jerch May 7, 2018
d8afdb1
Merge branch 'master' into new_parser
Tyriar May 15, 2018
c1f8225
Merge branch 'master' into new_parser
Tyriar May 21, 2018
ceb1432
remove deprecated FIXME
jerch May 21, 2018
8386ec1
Merge branch 'new_parser' of https://github.com/jerch/xterm.js into n…
jerch May 21, 2018
e97882e
use string templates in DCS responses
jerch May 21, 2018
6bc6ea5
Merge branch 'master' into new_parser
Tyriar May 21, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1,243 changes: 1,243 additions & 0 deletions src/EscapeSequenceParser.test.ts

Large diffs are not rendered by default.

544 changes: 544 additions & 0 deletions src/EscapeSequenceParser.ts

Large diffs are not rendered by default.

71 changes: 71 additions & 0 deletions src/EscapeSequences.ts
Original file line number Diff line number Diff line change
Expand Up @@ -77,3 +77,74 @@ export namespace C0 {
/** Delete (Caret = ^?) */
export const DEL = '\x7f';
}

/**
* C1 control codes
* See = https://en.wikipedia.org/wiki/C0_and_C1_control_codes
*/
export namespace C1 {
/** padding character */
export const PAD = '\x80';
/** High Octet Preset */
export const HOP = '\x81';
/** Break Permitted Here */
export const BPH = '\x82';
/** No Break Here */
export const NBH = '\x83';
/** Index */
export const IND = '\x84';
/** Next Line */
export const NEL = '\x85';
/** Start of Selected Area */
export const SSA = '\x86';
/** End of Selected Area */
export const ESA = '\x87';
/** Horizontal Tabulation Set */
export const HTS = '\x88';
/** Horizontal Tabulation With Justification */
export const HTJ = '\x89';
/** Vertical Tabulation Set */
export const VTS = '\x8a';
/** Partial Line Down */
export const PLD = '\x8b';
/** Partial Line Up */
export const PLU = '\x8c';
/** Reverse Index */
export const RI = '\x8d';
/** Single-Shift 2 */
export const SS2 = '\x8e';
/** Single-Shift 3 */
export const SS3 = '\x8f';
/** Device Control String */
export const DCS = '\x90';
/** Private Use 1 */
export const PU1 = '\x91';
/** Private Use 2 */
export const PU2 = '\x92';
/** Set Transmit State */
export const STS = '\x93';
/** Destructive backspace, intended to eliminate ambiguity about meaning of BS. */
export const CCH = '\x94';
/** Message Waiting */
export const MW = '\x95';
/** Start of Protected Area */
export const SPA = '\x96';
/** End of Protected Area */
export const EPA = '\x97';
/** Start of String */
export const SOS = '\x98';
/** Single Graphic Character Introducer */
export const SGCI = '\x99';
/** Single Character Introducer */
export const SCI = '\x9a';
/** Control Sequence Introducer */
export const CSI = '\x9b';
/** String Terminator */
export const ST = '\x9c';
/** Operating System Command */
export const OSC = '\x9d';
/** Privacy Message */
export const PM = '\x9e';
/** Application Program Command */
export const APC = '\x9f';
}
21 changes: 11 additions & 10 deletions src/InputHandler.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -29,53 +29,54 @@ describe('InputHandler', () => {
it('should call Terminal.setOption with correct params', () => {
let terminal = new MockInputHandlingTerminal();
let inputHandler = new InputHandler(terminal);
const collect = ' ';

inputHandler.setCursorStyle([0]);
inputHandler.setCursorStyle([0], collect);
assert.equal(terminal.options['cursorStyle'], 'block');
assert.equal(terminal.options['cursorBlink'], true);

terminal.options = {};
inputHandler.setCursorStyle([1]);
inputHandler.setCursorStyle([1], collect);
assert.equal(terminal.options['cursorStyle'], 'block');
assert.equal(terminal.options['cursorBlink'], true);

terminal.options = {};
inputHandler.setCursorStyle([2]);
inputHandler.setCursorStyle([2], collect);
assert.equal(terminal.options['cursorStyle'], 'block');
assert.equal(terminal.options['cursorBlink'], false);

terminal.options = {};
inputHandler.setCursorStyle([3]);
inputHandler.setCursorStyle([3], collect);
assert.equal(terminal.options['cursorStyle'], 'underline');
assert.equal(terminal.options['cursorBlink'], true);

terminal.options = {};
inputHandler.setCursorStyle([4]);
inputHandler.setCursorStyle([4], collect);
assert.equal(terminal.options['cursorStyle'], 'underline');
assert.equal(terminal.options['cursorBlink'], false);

terminal.options = {};
inputHandler.setCursorStyle([5]);
inputHandler.setCursorStyle([5], collect);
assert.equal(terminal.options['cursorStyle'], 'bar');
assert.equal(terminal.options['cursorBlink'], true);

terminal.options = {};
inputHandler.setCursorStyle([6]);
inputHandler.setCursorStyle([6], collect);
assert.equal(terminal.options['cursorStyle'], 'bar');
assert.equal(terminal.options['cursorBlink'], false);
});
});
describe('setMode', () => {
it('should toggle Terminal.bracketedPasteMode', () => {
let terminal = new MockInputHandlingTerminal();
terminal.prefix = '?';
const collect = '?';
terminal.bracketedPasteMode = false;
let inputHandler = new InputHandler(terminal);
// Set bracketed paste mode
inputHandler.setMode([2004]);
inputHandler.setMode([2004], collect);
assert.equal(terminal.bracketedPasteMode, true);
// Reset bracketed paste mode
inputHandler.resetMode([2004]);
inputHandler.resetMode([2004], collect);
assert.equal(terminal.bracketedPasteMode, false);
});
});
Expand Down
Loading