ddd1d92ff1
The idea here is to preserve the history of `dev` branch development and its code when merging with the `master`. Later this code could be moved into the masters code where appropriate.
56 lines
1.3 KiB
Go
56 lines
1.3 KiB
Go
package stack
|
|
|
|
import (
|
|
"fmt"
|
|
)
|
|
|
|
// Boolean represents a boolean value on the stack
|
|
type Boolean struct {
|
|
*abstractItem
|
|
val bool
|
|
}
|
|
|
|
//NewBoolean returns a new boolean stack item
|
|
func NewBoolean(val bool) *Boolean {
|
|
return &Boolean{
|
|
&abstractItem{},
|
|
val,
|
|
}
|
|
}
|
|
|
|
// Boolean overrides the default implementation
|
|
// by the abstractItem, returning a Boolean struct
|
|
func (b *Boolean) Boolean() (*Boolean, error) {
|
|
return b, nil
|
|
}
|
|
|
|
// Value returns the underlying boolean value
|
|
func (b *Boolean) Value() bool {
|
|
return b.val
|
|
}
|
|
|
|
// Not returns a Boolean whose underlying value is flipped.
|
|
// If the value is True, it is flipped to False and viceversa
|
|
func (b *Boolean) Not() *Boolean {
|
|
return NewBoolean(!b.Value())
|
|
}
|
|
|
|
// And returns a Boolean whose underlying value is obtained
|
|
// by applying the && operator to two Booleans' values.
|
|
func (b *Boolean) And(a *Boolean) *Boolean {
|
|
c := b.Value() && a.Value()
|
|
return NewBoolean(c)
|
|
}
|
|
|
|
// Or returns a Boolean whose underlying value is obtained
|
|
// by applying the || operator to two Booleans' values.
|
|
func (b *Boolean) Or(a *Boolean) *Boolean {
|
|
c := b.Value() || a.Value()
|
|
return NewBoolean(c)
|
|
}
|
|
|
|
// Hash overrides the default abstract hash method.
|
|
func (b *Boolean) Hash() (string, error) {
|
|
data := fmt.Sprintf("%T %v", b, b.Value())
|
|
return KeyGenerator([]byte(data))
|
|
}
|