mirror of
https://github.com/unidoc/unioffice.git
synced 2025-04-29 13:49:10 +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
54 lines
1.3 KiB
Go
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
|
|
}
|