Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
swim.recon.InfixOperatorWriter Maven / Gradle / Ivy
Go to download
Uploads all artifacts belonging to configuration ':swim-recon:archives'
// Copyright 2015-2019 SWIM.AI inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package swim.recon;
import swim.codec.Output;
import swim.codec.Unicode;
import swim.codec.Utf8;
import swim.codec.Writer;
import swim.codec.WriterException;
final class InfixOperatorWriter extends Writer {
final ReconWriter recon;
final I lhs;
final String operator;
final I rhs;
final int precedence;
final Writer, ?> part;
final int step;
InfixOperatorWriter(ReconWriter recon, I lhs, String operator, I rhs,
int precedence, Writer, ?> part, int step) {
this.recon = recon;
this.lhs = lhs;
this.operator = operator;
this.rhs = rhs;
this.precedence = precedence;
this.part = part;
this.step = step;
}
@Override
public Writer pull(Output> output) {
return write(output, this.recon, this.lhs, this.operator, this.rhs,
this.precedence, this.part, this.step);
}
static int sizeOf(ReconWriter recon, I lhs, String operator, I rhs, int precedence) {
int size = 0;
if (recon.precedence(lhs) < precedence) {
size += 1; // '('
size += recon.sizeOfItem(lhs);
size += 1; // ')'
} else {
size += recon.sizeOfItem(lhs);
}
size += 1; // ' '
size += Utf8.sizeOf(operator);
size += 1; // ' '
if (recon.precedence(rhs) < precedence) {
size += 1; // '('
size += recon.sizeOfItem(rhs);
size += 1; // ')'
} else {
size += recon.sizeOfItem(rhs);
}
return size;
}
static Writer write(Output> output, ReconWriter recon,
I lhs, String operator, I rhs, int precedence,
Writer, ?> part, int step) {
if (step == 1) {
if (recon.precedence(lhs) < precedence) {
if (output.isCont()) {
output = output.write('(');
step = 2;
}
} else {
step = 2;
}
}
if (step == 2) {
if (part == null) {
part = recon.writeItem(lhs, output);
} else {
part = part.pull(output);
}
if (part.isDone()) {
part = null;
step = 3;
} else if (part.isError()) {
return part.asError();
}
}
if (step == 3) {
if (recon.precedence(lhs) < precedence) {
if (output.isCont()) {
output = output.write(')');
step = 4;
}
} else {
step = 4;
}
}
if (step == 4 && output.isCont()) {
output = output.write(' ');
step = 5;
}
if (step == 5) {
if (part == null) {
part = Unicode.writeString(operator, output);
} else {
part = part.pull(output);
}
if (part.isDone()) {
part = null;
step = 6;
} else if (part.isError()) {
return part.asError();
}
}
if (step == 6 && output.isCont()) {
output = output.write(' ');
step = 7;
}
if (step == 7) {
if (recon.precedence(rhs) < precedence) {
if (output.isCont()) {
output = output.write('(');
step = 8;
}
} else {
step = 8;
}
}
if (step == 8) {
if (part == null) {
part = recon.writeItem(rhs, output);
} else {
part = part.pull(output);
}
if (part.isDone()) {
part = null;
step = 9;
} else if (part.isError()) {
return part.asError();
}
}
if (step == 9) {
if (recon.precedence(rhs) < precedence) {
if (output.isCont()) {
output = output.write(')');
return done();
}
} else {
return done();
}
}
if (output.isDone()) {
return error(new WriterException("truncated"));
} else if (output.isError()) {
return error(output.trap());
}
return new InfixOperatorWriter(recon, lhs, operator, rhs, precedence, part, step);
}
static Writer write(Output> output, ReconWriter recon,
I lhs, String operator, I rhs, int precedence) {
return write(output, recon, lhs, operator, rhs, precedence, null, 1);
}
}