WarpPI/core/src/main/java/it/cavallium/warppi/math/functions/Negative.java

51 lines
1.7 KiB
Java
Raw Normal View History

package it.cavallium.warppi.math.functions;
2016-11-02 21:56:40 +01:00
import it.cavallium.warppi.Error;
import it.cavallium.warppi.gui.expression.blocks.Block;
import it.cavallium.warppi.gui.expression.blocks.BlockChar;
import it.cavallium.warppi.gui.expression.blocks.BlockParenthesis;
import it.cavallium.warppi.math.Function;
import it.cavallium.warppi.math.FunctionSingle;
import it.cavallium.warppi.math.MathContext;
import it.cavallium.warppi.math.MathematicalSymbols;
import it.unimi.dsi.fastutil.objects.ObjectArrayList;
public class Negative extends FunctionSingle {
2016-11-02 21:56:40 +01:00
public Negative(MathContext root, Function value) {
2017-01-17 22:32:40 +01:00
super(root, value);
2016-11-02 21:56:40 +01:00
}
2017-01-17 22:32:40 +01:00
@Override
public boolean equals(Object o) {
if (o instanceof Negative) {
return ((Negative) o).getParameter().equals(parameter);
}
return false;
}
@Override
public Negative clone() {
return new Negative(mathContext, parameter);
}
@Override
public ObjectArrayList<Block> toBlock(MathContext context) throws Error {
2018-05-12 21:18:29 +02:00
final ObjectArrayList<Block> blocks = new ObjectArrayList<>();
2017-07-24 23:11:29 +02:00
blocks.add(new BlockChar(MathematicalSymbols.MINUS));
if (new Expression(context, getParameter()).parenthesisNeeded()) {
2018-05-12 21:18:29 +02:00
final BlockParenthesis par = new BlockParenthesis();
final ObjectArrayList<Block> parBlocks = getParameter().toBlock(context);
for (final Block b : parBlocks) {
2017-07-24 23:11:29 +02:00
par.getNumberContainer().appendBlockUnsafe(b); // Skips recomputeDimension
}
par.recomputeDimensions(); // Recompute dimensions after appendBlockUnsafe
blocks.add(par);
} else {
blocks.addAll(getParameter().toBlock(context));
}
return blocks;
// throw new Error(Errors.NOT_IMPLEMENTED, "Unknown function " + getClass().getSimpleName());
}
2016-11-02 21:56:40 +01:00
}