unioffice/spreadsheet/formula/constarrayexpr.go
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

49 lines
1.5 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"
// ConstArrayExpr is a constant array expression.
type ConstArrayExpr struct {
data [][]Expression
}
// NewConstArrayExpr constructs a new constant array expression with a given data.
func NewConstArrayExpr(data [][]Expression) Expression {
return &ConstArrayExpr{data}
}
// Eval evaluates and returns the result of a constant array expression.
func (c ConstArrayExpr) Eval(ctx Context, ev Evaluator) Result {
res := [][]Result{}
for _, row := range c.data {
r := []Result{}
for _, col := range row {
r = append(r, col.Eval(ctx, ev))
}
res = append(res, r)
}
return MakeArrayResult(res)
}
// Reference returns an invalid reference for ConstArrayExpr.
func (c ConstArrayExpr) Reference(ctx Context, ev Evaluator) Reference {
return ReferenceInvalid
}
// String returns a string representation of ConstArrayExpr.
func (c ConstArrayExpr) String() string {
return "" // to do
}
// Update returns the same object as updating sheet references does not affect ConstArrayExpr.
func (c ConstArrayExpr) Update(q *update.UpdateQuery) Expression {
return c
}