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

54 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 (
"strconv"
"github.com/unidoc/unioffice"
"github.com/unidoc/unioffice/spreadsheet/update"
)
// Bool is a boolean expression.
type Bool struct {
b bool
}
// NewBool constructs a new boolean expression.
func NewBool(v string) Expression {
b, err := strconv.ParseBool(v)
if err != nil {
unioffice.Log("error parsing formula bool %s: %s", v, err)
}
return Bool{b}
}
// Eval evaluates and returns a boolean.
func (b Bool) Eval(ctx Context, ev Evaluator) Result {
return MakeBoolResult(b.b)
}
// Reference returns an invalid reference for Bool.
func (b Bool) Reference(ctx Context, ev Evaluator) Reference {
return ReferenceInvalid
}
// String returns a string representation for Bool.
func (b Bool) String() string {
if b.b {
return "TRUE"
} else {
return "FALSE"
}
}
// Update returns the same object as updating sheet references does not affect Bool.
func (b Bool) Update(q *update.UpdateQuery) Expression {
return b
}