php-parser/node/expr/binary_op/not_equal.go

66 lines
1.0 KiB
Go
Raw Normal View History

2017-12-12 21:26:00 +00:00
package binary_op
import (
"github.com/z7zmey/php-parser/node"
)
type NotEqual struct {
BinaryOp
}
func NewNotEqual(variable node.Node, expression node.Node) node.Node {
return NotEqual{
BinaryOp{
2017-12-27 17:55:58 +00:00
"BinaryNotEqual",
2017-12-29 15:53:13 +00:00
map[string]interface{}{},
2017-12-31 10:59:22 +00:00
nil,
2017-12-12 21:26:00 +00:00
variable,
expression,
},
}
}
2017-12-27 23:23:32 +00:00
2017-12-29 15:20:24 +00:00
func (n NotEqual) Name() string {
return "NotEqual"
}
func (n NotEqual) Attributes() map[string]interface{} {
2017-12-29 15:53:13 +00:00
return n.attributes
2017-12-29 15:20:24 +00:00
}
2017-12-31 09:57:55 +00:00
func (n NotEqual) Attribute(key string) interface{} {
return n.attributes[key]
}
2018-01-02 12:11:08 +00:00
func (n NotEqual) SetAttribute(key string, value interface{}) node.Node {
2017-12-31 09:57:55 +00:00
n.attributes[key] = value
2018-01-02 12:11:08 +00:00
return n
2017-12-31 09:57:55 +00:00
}
2017-12-31 10:59:22 +00:00
func (n NotEqual) Position() *node.Position {
return n.position
}
func (n NotEqual) SetPosition(p *node.Position) node.Node {
n.position = p
return n
}
2017-12-27 23:23:32 +00:00
func (n NotEqual) Walk(v node.Visitor) {
2017-12-28 11:36:27 +00:00
if v.EnterNode(n) == false {
2017-12-27 23:23:32 +00:00
return
}
if n.left != nil {
2017-12-28 11:36:27 +00:00
vv := v.GetChildrenVisitor("left")
2017-12-27 23:23:32 +00:00
n.left.Walk(vv)
}
if n.right != nil {
2017-12-28 11:36:27 +00:00
vv := v.GetChildrenVisitor("right")
2017-12-27 23:23:32 +00:00
n.right.Walk(vv)
}
2017-12-28 11:36:27 +00:00
v.LeaveNode(n)
2017-12-27 23:23:32 +00:00
}