Moved escaked point handling out of the lexer
This commit is contained in:
parent
547ad93953
commit
0d54b152dc
|
@ -243,7 +243,13 @@ public class FourCornerUnicodeDisplay {
|
|||
public void strobeUnicode(List<Integer> codePoints) {
|
||||
codePoints.forEach(v -> output.appendCodePoint(v));
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public void strobeRecursiveCake(List<Integer> cakePoints) {
|
||||
FourCornerZionStenoLexer thisDisplayEscaked = new FourCornerZionStenoLexer(this, true);
|
||||
thisDisplayEscaked.read(cakePoints);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void strobeNether(List<Integer> key, List<Integer> octals) {
|
||||
// TODO Auto-generated method stub
|
||||
|
@ -260,10 +266,5 @@ public class FourCornerUnicodeDisplay {
|
|||
output.append(";");
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void burnRecursive(int line, int col) {
|
||||
throw new IllegalStateException("loop");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -41,6 +41,8 @@ public interface FourCornerZion7Candlelier {
|
|||
|
||||
void strobeUnicode(List<Integer> codePoints);
|
||||
|
||||
void strobeRecursiveCake(List<Integer> cakePoints);
|
||||
|
||||
void strobeNether(List<Integer> key, List<Integer> octals);
|
||||
|
||||
interface Adapter extends FourCornerZion7Candlelier {
|
||||
|
@ -57,6 +59,10 @@ public interface FourCornerZion7Candlelier {
|
|||
default void strobeUnicode(List<Integer> codePoints) {
|
||||
}
|
||||
|
||||
@Override
|
||||
default void strobeRecursiveCake(List<Integer> cakePoints) {
|
||||
}
|
||||
|
||||
@Override
|
||||
default void strobeNether(List<Integer> key, List<Integer> octals) {
|
||||
}
|
||||
|
|
|
@ -51,7 +51,6 @@ public class FourCornerZionStenoLexer {
|
|||
private final int numeratorBank[] = new int[denominatorBank.length];
|
||||
private List<Integer> input;
|
||||
private int inputIndex = 0;
|
||||
private int readLevel = 0;
|
||||
private int currLine = 0;
|
||||
private int currCol = 0;
|
||||
private FourCornerZionStenoLexerSmoke smokeSignals = CLEAN_SMOKE;
|
||||
|
@ -137,17 +136,10 @@ public class FourCornerZionStenoLexer {
|
|||
|
||||
public void read(List<Integer> points) {
|
||||
input = Objects.requireNonNull(points);
|
||||
readLevel++; // first puts on one, we allow level deep
|
||||
if (readLevel > 2) {
|
||||
smokeSignals.burnRecursive(currLine, currCol);
|
||||
return;
|
||||
}
|
||||
if (readLevel == 1) {
|
||||
inputIndex = 0;
|
||||
currLine = 0;
|
||||
currCol = 0; // allow reuse of lexer
|
||||
handlerDocument.strobeDocumentAlpha();
|
||||
}
|
||||
inputIndex = 0;
|
||||
currLine = 0;
|
||||
currCol = 0; // allow reuse of lexer
|
||||
handlerDocument.strobeDocumentAlpha();
|
||||
while (true) {
|
||||
ScanResult run = ScanResult.DONE;
|
||||
while (run.isDone()) {
|
||||
|
@ -164,10 +156,7 @@ public class FourCornerZionStenoLexer {
|
|||
smokeSignals.burnUnsupported(currLine, currCol, input.get(inputIndex));
|
||||
}
|
||||
}
|
||||
if (readLevel == 1) {
|
||||
handlerDocument.strobeDocumentOmega();
|
||||
}
|
||||
readLevel--;
|
||||
handlerDocument.strobeDocumentOmega();
|
||||
}
|
||||
|
||||
private ScanResult readTokens() {
|
||||
|
@ -247,7 +236,6 @@ public class FourCornerZionStenoLexer {
|
|||
ScanResult result = ScanResult.DONE;
|
||||
int idxFirst = lexer.inputIndex;
|
||||
int idxLast = lexer.inputIndex;
|
||||
|
||||
while (true) {
|
||||
int cakePoint = lexer.input.get(lexer.inputIndex);
|
||||
if (cakePoint < blockStart || cakePoint > blockStop) {
|
||||
|
@ -590,32 +578,32 @@ public class FourCornerZionStenoLexer {
|
|||
if (FCDotDEC0127DashPX0.ESC68_FC18.equals(decMode)) {
|
||||
List<List<Integer>> result = new ArrayList<>();
|
||||
scanSalahRakaAt(lexer, result);
|
||||
if (!result.isEmpty()) {
|
||||
List<Integer> renderCakePoints = new ArrayList<>();
|
||||
for (List<Integer> argu : result) {
|
||||
int cakePointArgu = 0;
|
||||
int cakePointIdx = 6;
|
||||
for (Integer octal : argu) {
|
||||
if (octal < FCDotCDC1604DashP6.NX01_A.ordinal()) {
|
||||
continue;
|
||||
}
|
||||
if (octal > FCDotCDC1604DashP6.NX08_H.ordinal()) {
|
||||
continue;
|
||||
}
|
||||
int offset = octal - FCDotCDC1604DashP6.NX01_A.ordinal();
|
||||
cakePointArgu = cakePointArgu + (offset << (cakePointIdx*3));
|
||||
cakePointIdx--;
|
||||
if (cakePointIdx < 0) {
|
||||
renderCakePoints.add(cakePointArgu);
|
||||
cakePointIdx = 6;
|
||||
cakePointArgu = 0;
|
||||
}
|
||||
if (result.isEmpty()) {
|
||||
return false;
|
||||
}
|
||||
List<Integer> renderCakePoints = new ArrayList<>();
|
||||
for (List<Integer> argu : result) {
|
||||
int cakePointArgu = 0;
|
||||
int cakePointIdx = 6;
|
||||
for (Integer octal : argu) {
|
||||
if (octal < FCDotCDC1604DashP6.NX01_A.ordinal()) {
|
||||
continue;
|
||||
}
|
||||
if (octal > FCDotCDC1604DashP6.NX08_H.ordinal()) {
|
||||
continue;
|
||||
}
|
||||
int offset = octal - FCDotCDC1604DashP6.NX01_A.ordinal();
|
||||
cakePointArgu = cakePointArgu + (offset << (cakePointIdx*3));
|
||||
cakePointIdx--;
|
||||
if (cakePointIdx < 0) {
|
||||
renderCakePoints.add(cakePointArgu);
|
||||
cakePointIdx = 6;
|
||||
cakePointArgu = 0;
|
||||
}
|
||||
}
|
||||
FourCornerZionStenoLexer lexer2 = new FourCornerZionStenoLexer(lexer.handler);
|
||||
lexer2.read(renderCakePoints);
|
||||
return true;
|
||||
}
|
||||
lexer.handler.strobeRecursiveCake(renderCakePoints);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
|
|
@ -32,8 +32,6 @@ public interface FourCornerZionStenoLexerSmoke {
|
|||
|
||||
void burnUnsupported(int line, int col, int cakePoint);
|
||||
|
||||
void burnRecursive(int line, int col);
|
||||
|
||||
void burnInvalidEscape(int line, int col, int cakePoint);
|
||||
|
||||
|
||||
|
@ -55,10 +53,6 @@ public interface FourCornerZionStenoLexerSmoke {
|
|||
default void burnUnsupported(int line, int col, int cakePoint) {
|
||||
}
|
||||
|
||||
@Override
|
||||
default void burnRecursive(int line, int col) {
|
||||
}
|
||||
|
||||
@Override
|
||||
default void burnSalahInvalidCakePoint(int line, int col, int cakePoint) {
|
||||
}
|
||||
|
|
|
@ -32,7 +32,6 @@ public class TestSmokeReader implements FourCornerZionStenoLexerSmoke.Adapter {
|
|||
|
||||
int errorUNI21UnusedBigIndian;
|
||||
int errorUnsupport;
|
||||
int errorRecursive;
|
||||
|
||||
public TestSmokeReader() {
|
||||
reset();
|
||||
|
@ -41,7 +40,6 @@ public class TestSmokeReader implements FourCornerZionStenoLexerSmoke.Adapter {
|
|||
public void reset() {
|
||||
errorUNI21UnusedBigIndian = -1;
|
||||
errorUnsupport = -1;
|
||||
errorRecursive = -1;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -53,9 +51,4 @@ public class TestSmokeReader implements FourCornerZionStenoLexerSmoke.Adapter {
|
|||
public void burnUnsupported(int line, int col, int cakePoint) {
|
||||
errorUnsupport = line;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void burnRecursive(int line, int col) {
|
||||
errorRecursive = line;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue