mirror of
https://github.com/unidoc/unioffice.git
synced 2025-05-04 22:17:38 +08:00

* 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
45 lines
1.3 KiB
Go
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)}
|
|
}
|