WarpPI/src/main/java/org/warp/picalculator/math/functions/Negative.java

52 lines
1.7 KiB
Java
Raw Normal View History

2016-11-02 21:56:40 +01:00
package org.warp.picalculator.math.functions;
import org.warp.picalculator.Error;
import org.warp.picalculator.gui.expression.blocks.Block;
2017-07-24 23:11:29 +02:00
import org.warp.picalculator.gui.expression.blocks.BlockChar;
import org.warp.picalculator.gui.expression.blocks.BlockParenthesis;
import org.warp.picalculator.math.Function;
import org.warp.picalculator.math.FunctionSingle;
import org.warp.picalculator.math.MathContext;
2017-07-24 23:11:29 +02:00
import org.warp.picalculator.math.MathematicalSymbols;
2016-11-02 21:56:40 +01:00
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
}