mirror of
https://github.com/github/semantic.git
synced 2025-01-04 21:47:07 +03:00
Split up BooleanOperator
This commit is contained in:
parent
cf709a7edb
commit
493399c74e
@ -77,40 +77,68 @@ instance Evaluatable Arithmetic where
|
|||||||
go (FloorDivision a b) = liftNumeric2 liftedFloorDiv a b
|
go (FloorDivision a b) = liftNumeric2 liftedFloorDiv a b
|
||||||
|
|
||||||
-- | Regex matching operators (Ruby's =~ and ~!)
|
-- | Regex matching operators (Ruby's =~ and ~!)
|
||||||
data RegexMatch a
|
data Matches a = Matches { lhs :: a, rhs :: a }
|
||||||
= Matches !a !a
|
|
||||||
| NotMatches !a !a
|
|
||||||
deriving (Declarations1, Diffable, Eq, Foldable, FreeVariables1, Functor, Generic1, Hashable1, Mergeable, Ord, Show, ToJSONFields1, Traversable, Named1, Message1)
|
deriving (Declarations1, Diffable, Eq, Foldable, FreeVariables1, Functor, Generic1, Hashable1, Mergeable, Ord, Show, ToJSONFields1, Traversable, Named1, Message1)
|
||||||
|
|
||||||
instance Eq1 RegexMatch where liftEq = genericLiftEq
|
instance Eq1 Matches where liftEq = genericLiftEq
|
||||||
instance Ord1 RegexMatch where liftCompare = genericLiftCompare
|
instance Ord1 Matches where liftCompare = genericLiftCompare
|
||||||
instance Show1 RegexMatch where liftShowsPrec = genericLiftShowsPrec
|
instance Show1 Matches where liftShowsPrec = genericLiftShowsPrec
|
||||||
|
instance Evaluatable Matches
|
||||||
|
|
||||||
-- TODO: Implement Eval instance for Match
|
data NotMatches a = NotMatches { lhs :: a, rhs :: a }
|
||||||
instance Evaluatable RegexMatch
|
|
||||||
|
|
||||||
-- | Boolean operators.
|
|
||||||
data BooleanOperator a
|
|
||||||
= Or !a !a
|
|
||||||
| And !a !a
|
|
||||||
| Not !a
|
|
||||||
| XOr !a !a
|
|
||||||
deriving (Declarations1, Diffable, Eq, Foldable, FreeVariables1, Functor, Generic1, Hashable1, Mergeable, Ord, Show, ToJSONFields1, Traversable, Named1, Message1)
|
deriving (Declarations1, Diffable, Eq, Foldable, FreeVariables1, Functor, Generic1, Hashable1, Mergeable, Ord, Show, ToJSONFields1, Traversable, Named1, Message1)
|
||||||
|
|
||||||
instance Eq1 BooleanOperator where liftEq = genericLiftEq
|
instance Eq1 NotMatches where liftEq = genericLiftEq
|
||||||
instance Ord1 BooleanOperator where liftCompare = genericLiftCompare
|
instance Ord1 NotMatches where liftCompare = genericLiftCompare
|
||||||
instance Show1 BooleanOperator where liftShowsPrec = genericLiftShowsPrec
|
instance Show1 NotMatches where liftShowsPrec = genericLiftShowsPrec
|
||||||
|
instance Evaluatable NotMatches
|
||||||
|
|
||||||
instance Evaluatable BooleanOperator where
|
data Or a = Or { lhs :: a, rhs :: a }
|
||||||
-- N.B. we have to use Monad rather than Applicative/Traversable on 'And' and 'Or' so that we don't evaluate both operands
|
deriving (Declarations1, Diffable, Eq, Foldable, FreeVariables1, Functor, Generic1, Hashable1, Mergeable, Ord, Show, ToJSONFields1, Traversable, Named1, Message1)
|
||||||
|
|
||||||
|
instance Eq1 Or where liftEq = genericLiftEq
|
||||||
|
instance Ord1 Or where liftCompare = genericLiftCompare
|
||||||
|
instance Show1 Or where liftShowsPrec = genericLiftShowsPrec
|
||||||
|
|
||||||
|
instance Evaluatable Or where
|
||||||
|
eval t = rvalBox =<< go (fmap subtermValue t) where
|
||||||
|
go (Or a b) = do
|
||||||
|
cond <- a
|
||||||
|
ifthenelse cond (pure cond) b
|
||||||
|
|
||||||
|
data And a = And { lhs :: a, rhs :: a }
|
||||||
|
deriving (Declarations1, Diffable, Eq, Foldable, FreeVariables1, Functor, Generic1, Hashable1, Mergeable, Ord, Show, ToJSONFields1, Traversable, Named1, Message1)
|
||||||
|
|
||||||
|
instance Eq1 And where liftEq = genericLiftEq
|
||||||
|
instance Ord1 And where liftCompare = genericLiftCompare
|
||||||
|
instance Show1 And where liftShowsPrec = genericLiftShowsPrec
|
||||||
|
instance Evaluatable And where
|
||||||
eval t = rvalBox =<< go (fmap subtermValue t) where
|
eval t = rvalBox =<< go (fmap subtermValue t) where
|
||||||
go (And a b) = do
|
go (And a b) = do
|
||||||
cond <- a
|
cond <- a
|
||||||
ifthenelse cond b (pure cond)
|
ifthenelse cond b (pure cond)
|
||||||
go (Or a b) = do
|
|
||||||
cond <- a
|
data Not a = Not { term :: a }
|
||||||
ifthenelse cond (pure cond) b
|
deriving (Declarations1, Diffable, Eq, Foldable, FreeVariables1, Functor, Generic1, Hashable1, Mergeable, Ord, Show, ToJSONFields1, Traversable, Named1, Message1)
|
||||||
|
|
||||||
|
instance Eq1 Not where liftEq = genericLiftEq
|
||||||
|
instance Ord1 Not where liftCompare = genericLiftCompare
|
||||||
|
instance Show1 Not where liftShowsPrec = genericLiftShowsPrec
|
||||||
|
|
||||||
|
instance Evaluatable Not where
|
||||||
|
eval t = rvalBox =<< go (fmap subtermValue t) where
|
||||||
go (Not a) = a >>= fmap (boolean . not) . asBool
|
go (Not a) = a >>= fmap (boolean . not) . asBool
|
||||||
|
|
||||||
|
data XOr a = XOr { lhs :: a, rhs :: a }
|
||||||
|
deriving (Declarations1, Diffable, Eq, Foldable, FreeVariables1, Functor, Generic1, Hashable1, Mergeable, Ord, Show, ToJSONFields1, Traversable, Named1, Message1)
|
||||||
|
|
||||||
|
instance Eq1 XOr where liftEq = genericLiftEq
|
||||||
|
instance Ord1 XOr where liftCompare = genericLiftCompare
|
||||||
|
instance Show1 XOr where liftShowsPrec = genericLiftShowsPrec
|
||||||
|
|
||||||
|
instance Evaluatable XOr where
|
||||||
|
-- N.B. we have to use Monad rather than Applicative/Traversable on 'And' and 'Or' so that we don't evaluate both operands
|
||||||
|
eval t = rvalBox =<< go (fmap subtermValue t) where
|
||||||
go (XOr a b) = boolean <$> liftA2 (/=) (a >>= asBool) (b >>= asBool)
|
go (XOr a b) = boolean <$> liftA2 (/=) (a >>= asBool) (b >>= asBool)
|
||||||
|
|
||||||
-- | Javascript delete operator
|
-- | Javascript delete operator
|
||||||
|
@ -17,6 +17,7 @@ import Data.JSON.Fields
|
|||||||
import Data.Record
|
import Data.Record
|
||||||
import Text.Show
|
import Text.Show
|
||||||
import Proto3.Suite.Class
|
import Proto3.Suite.Class
|
||||||
|
import Proto3.Suite.DotProto
|
||||||
import qualified Proto3.Wire.Encode as Encode
|
import qualified Proto3.Wire.Encode as Encode
|
||||||
import qualified Proto3.Wire.Decode as Decode
|
import qualified Proto3.Wire.Decode as Decode
|
||||||
|
|
||||||
|
@ -41,14 +41,16 @@ type Syntax =
|
|||||||
, Expression.RShift
|
, Expression.RShift
|
||||||
, Expression.UnsignedRShift
|
, Expression.UnsignedRShift
|
||||||
, Expression.Complement
|
, Expression.Complement
|
||||||
, Expression.BooleanOperator
|
|
||||||
, Expression.Call
|
, Expression.Call
|
||||||
, Expression.Comparison
|
, Expression.Comparison
|
||||||
, Expression.Subscript
|
, Expression.Subscript
|
||||||
, Statement.PostDecrement
|
, Statement.PostDecrement
|
||||||
, Statement.PostIncrement
|
, Statement.PostIncrement
|
||||||
, Expression.MemberAccess
|
, Expression.MemberAccess
|
||||||
, Expression.BooleanOperator
|
, Expression.And
|
||||||
|
, Expression.Not
|
||||||
|
, Expression.Or
|
||||||
|
, Expression.XOr
|
||||||
, Expression.Call
|
, Expression.Call
|
||||||
, Expression.Comparison
|
, Expression.Comparison
|
||||||
, Expression.Subscript
|
, Expression.Subscript
|
||||||
|
@ -44,7 +44,10 @@ type Syntax =
|
|||||||
, Expression.RShift
|
, Expression.RShift
|
||||||
, Expression.UnsignedRShift
|
, Expression.UnsignedRShift
|
||||||
, Expression.Complement
|
, Expression.Complement
|
||||||
, Expression.BooleanOperator
|
, Expression.And
|
||||||
|
, Expression.Not
|
||||||
|
, Expression.Or
|
||||||
|
, Expression.XOr
|
||||||
, Expression.InstanceOf
|
, Expression.InstanceOf
|
||||||
, Expression.MemberAccess
|
, Expression.MemberAccess
|
||||||
, Expression.Subscript
|
, Expression.Subscript
|
||||||
|
@ -47,7 +47,10 @@ type Syntax = '[
|
|||||||
, Expression.BXOr
|
, Expression.BXOr
|
||||||
, Expression.LShift
|
, Expression.LShift
|
||||||
, Expression.RShift
|
, Expression.RShift
|
||||||
, Expression.BooleanOperator
|
, Expression.And
|
||||||
|
, Expression.Not
|
||||||
|
, Expression.Or
|
||||||
|
, Expression.XOr
|
||||||
, Expression.Call
|
, Expression.Call
|
||||||
, Expression.Cast
|
, Expression.Cast
|
||||||
, Expression.Comparison
|
, Expression.Comparison
|
||||||
|
@ -49,7 +49,10 @@ type Syntax =
|
|||||||
, Declaration.Function
|
, Declaration.Function
|
||||||
, Declaration.Variable
|
, Declaration.Variable
|
||||||
, Expression.Arithmetic
|
, Expression.Arithmetic
|
||||||
, Expression.BooleanOperator
|
, Expression.And
|
||||||
|
, Expression.Not
|
||||||
|
, Expression.Or
|
||||||
|
, Expression.XOr
|
||||||
, Expression.BAnd
|
, Expression.BAnd
|
||||||
, Expression.BOr
|
, Expression.BOr
|
||||||
, Expression.BXOr
|
, Expression.BXOr
|
||||||
|
@ -51,11 +51,15 @@ type Syntax = '[
|
|||||||
, Expression.LShift
|
, Expression.LShift
|
||||||
, Expression.RShift
|
, Expression.RShift
|
||||||
, Expression.Complement
|
, Expression.Complement
|
||||||
, Expression.BooleanOperator
|
, Expression.And
|
||||||
|
, Expression.Not
|
||||||
|
, Expression.Or
|
||||||
|
, Expression.XOr
|
||||||
, Expression.Call
|
, Expression.Call
|
||||||
, Expression.Comparison
|
, Expression.Comparison
|
||||||
, Expression.Enumeration
|
, Expression.Enumeration
|
||||||
, Expression.RegexMatch
|
, Expression.Matches
|
||||||
|
, Expression.NotMatches
|
||||||
, Expression.MemberAccess
|
, Expression.MemberAccess
|
||||||
, Expression.ScopeResolution
|
, Expression.ScopeResolution
|
||||||
, Expression.Subscript
|
, Expression.Subscript
|
||||||
|
@ -55,7 +55,10 @@ type Syntax = '[
|
|||||||
, Expression.RShift
|
, Expression.RShift
|
||||||
, Expression.UnsignedRShift
|
, Expression.UnsignedRShift
|
||||||
, Expression.Complement
|
, Expression.Complement
|
||||||
, Expression.BooleanOperator
|
, Expression.And
|
||||||
|
, Expression.Not
|
||||||
|
, Expression.Or
|
||||||
|
, Expression.XOr
|
||||||
, Expression.Call
|
, Expression.Call
|
||||||
, Expression.Cast
|
, Expression.Cast
|
||||||
, Expression.Comparison
|
, Expression.Comparison
|
||||||
|
Loading…
Reference in New Issue
Block a user