mirror of
https://github.com/AppleCommander/bastools.git
synced 2025-01-20 06:30:00 +00:00
Rewrote the zero vector handling logic. #16.
This commit is contained in:
parent
965d6be891
commit
580af51716
@ -183,39 +183,26 @@ public class VectorShape implements Shape {
|
|||||||
VectorCommand vector2 = work.poll();
|
VectorCommand vector2 = work.poll();
|
||||||
int section2 = Optional.ofNullable(vector2).map(VectorCommand::ordinal).orElse(0);
|
int section2 = Optional.ofNullable(vector2).map(VectorCommand::ordinal).orElse(0);
|
||||||
VectorCommand vector3 = work.poll();
|
VectorCommand vector3 = work.poll();
|
||||||
if (vector3 != null && vector3.plot) {
|
// Remove all invalid encodings 100, 101, 110, 111, and 000.
|
||||||
|
if (vector3 != null && (vector3.plot || vector3 == VectorCommand.MOVE_UP)) {
|
||||||
work.addFirst(vector3);
|
work.addFirst(vector3);
|
||||||
vector3 = null;
|
vector3 = null;
|
||||||
}
|
}
|
||||||
int section3 = Optional.ofNullable(vector3).map(VectorCommand::ordinal).orElse(0);
|
int section3 = Optional.ofNullable(vector3).map(VectorCommand::ordinal).orElse(0);
|
||||||
if ((section1 + section2 + section3) == 0) {
|
if (section3 == 0 && section2 == 0 && !work.isEmpty()) {
|
||||||
// Can only write a 0 byte to terminate shape
|
|
||||||
if (vector2 == null) {
|
|
||||||
vector2 = VectorCommand.MOVE_LEFT;
|
|
||||||
section2 = vector2.ordinal();
|
|
||||||
} else if (vector3 == null) {
|
|
||||||
vector3 = VectorCommand.MOVE_LEFT;
|
vector3 = VectorCommand.MOVE_LEFT;
|
||||||
section3 = vector3.ordinal();
|
section3 = vector3.ordinal();
|
||||||
if (!work.isEmpty()) {
|
// If we have a series of MOVE_UP, we'll end up with a "uul", "rul", "rul", etc.
|
||||||
work.addFirst(VectorCommand.MOVE_RIGHT);
|
// It can be compressed a bit by stretching that right out a bit to get "uul", "uur", "uul, "uur", etc.
|
||||||
}
|
int moveUpCount = 0;
|
||||||
|
for (VectorCommand test : work) {
|
||||||
|
if (test == VectorCommand.MOVE_UP) {
|
||||||
|
moveUpCount += 1;
|
||||||
} else {
|
} else {
|
||||||
work.addFirst(vector3);
|
break;
|
||||||
vector3 = VectorCommand.MOVE_LEFT;
|
|
||||||
section3 = vector3.ordinal();
|
|
||||||
if (!work.isEmpty()) {
|
|
||||||
work.addFirst(VectorCommand.MOVE_RIGHT);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (vector3 == VectorCommand.MOVE_UP) {
|
work.add(Math.min(moveUpCount,2), VectorCommand.MOVE_RIGHT);
|
||||||
// section 3 cannot be 0
|
|
||||||
work.addFirst(vector3);
|
|
||||||
vector3 = null;
|
|
||||||
if (vector2 == VectorCommand.MOVE_UP) {
|
|
||||||
// section 2 and 3 cannot be 0
|
|
||||||
work.addFirst(vector2);
|
|
||||||
vector2 = null;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
outputStream.write(section3 << 6 | section2 << 3 | section1);
|
outputStream.write(section3 << 6 | section2 << 3 | section1);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user