Vyacheslav Zgordan ddafaca850
Spreadsheet: Remove columns feature (Issue #367) (#371)
* Issue #376 fix - RemoveColumn
* Removing of columns is forbidden when there are formula arrays in the area of removing, except 1-column wide arrays
* Modifying named ranges, column ranges when deleting a column
* Updating formulas when deleting a column
* UpdateAction
2020-02-11 19:47:08 +00:00

45 lines
1.3 KiB
Go

// Copyright 2017 FoxyUtils ehf. All rights reserved.
//
// Use of this source code is governed by the terms of the Affero GNU General
// Public License version 3.0 as published by the Free Software Foundation and
// appearing in the file LICENSE included in the packaging of this file. A
// commercial license can be purchased on https://unidoc.io.
package formula
import "github.com/unidoc/unioffice/spreadsheet/update"
// Negate is a negate expression like -A1.
type Negate struct {
e Expression
}
// NewNegate constructs a new negate expression.
func NewNegate(e Expression) Expression {
return Negate{e}
}
// Eval evaluates and returns the result of a Negate expression.
func (n Negate) Eval(ctx Context, ev Evaluator) Result {
r := n.e.Eval(ctx, ev)
if r.Type == ResultTypeNumber {
return MakeNumberResult(-r.ValueNumber)
}
return MakeErrorResult("NEGATE expected number argument")
}
// Reference returns an invalid reference for Negate.
func (n Negate) Reference(ctx Context, ev Evaluator) Reference {
return ReferenceInvalid
}
// String returns a string representation for Negate.
func (n Negate) String() string {
return "-" + n.e.String()
}
// Update updates references in the Negate after removing a row/column.
func (n Negate) Update(q *update.UpdateQuery) Expression {
return Negate{n.e.Update(q)}
}