// Copyright Vespa.ai. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root. package com.yahoo.search.grouping.request; import java.util.List; import java.util.stream.Collectors; /** * This class represents a div-function in a {@link GroupingExpression}. It evaluates to a number that equals the result * of subtracting the results of all arguments in the order they were given to the constructor (subtract second argument * from first, third from result, ...). * * @author Simon Thoresen Hult */ public class SubFunction extends FunctionNode { /** * Constructs a new instance of this class. * * @param arg1 The first compulsory argument, must evaluate to a number. * @param arg2 The second compulsory argument, must evaluate to a number. * @param argN The optional arguments, must evaluate to a number. */ public SubFunction(GroupingExpression arg1, GroupingExpression arg2, GroupingExpression... argN) { this(null, null, asList(arg1, arg2, argN)); } private SubFunction(String label, Integer level, List args) { super("sub", label, level, args); } @Override public SubFunction copy() { return new SubFunction(getLabel(), getLevelOrNull(), args().stream().map(arg -> arg.copy()).toList()); } /** * Constructs a new instance of this class from a list of arguments. * * @param args The arguments to pass to the constructor. * @return The created instance. * @throws IllegalArgumentException Thrown if the number of arguments is less than 2. */ public static SubFunction newInstance(List args) { if (args.size() < 2) { throw new IllegalArgumentException("Expected 2 or more arguments, got " + args.size() + "."); } return new SubFunction(null, null, args); } }