module Language.ECMAScript3.Analysis.LabelSets
{-# DEPRECATED "Use 'Language.ECMAScript3.Analysis.LabelSet'\
\ from package 'language-ecmascript-analysis'" #-}
(annotateLabelSets
,Label(..)) where
import Language.ECMAScript3.Syntax
import Language.ECMAScript3.Syntax.Annotations
import Data.Set (Set)
import qualified Data.Set as Set
import Data.Generics.Uniplate.Data
import Data.Data (Data)
import Control.Applicative
import Data.Typeable (Typeable)
data Label = Label String
| EmptyLabel
deriving (Eq Label
Label -> Label -> Bool
Label -> Label -> Ordering
Label -> Label -> Label
forall a.
Eq a
-> (a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
min :: Label -> Label -> Label
$cmin :: Label -> Label -> Label
max :: Label -> Label -> Label
$cmax :: Label -> Label -> Label
>= :: Label -> Label -> Bool
$c>= :: Label -> Label -> Bool
> :: Label -> Label -> Bool
$c> :: Label -> Label -> Bool
<= :: Label -> Label -> Bool
$c<= :: Label -> Label -> Bool
< :: Label -> Label -> Bool
$c< :: Label -> Label -> Bool
compare :: Label -> Label -> Ordering
$ccompare :: Label -> Label -> Ordering
Ord, Label -> Label -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: Label -> Label -> Bool
$c/= :: Label -> Label -> Bool
== :: Label -> Label -> Bool
$c== :: Label -> Label -> Bool
Eq, Int -> Label -> ShowS
[Label] -> ShowS
Label -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [Label] -> ShowS
$cshowList :: [Label] -> ShowS
show :: Label -> String
$cshow :: Label -> String
showsPrec :: Int -> Label -> ShowS
$cshowsPrec :: Int -> Label -> ShowS
Show, Typeable Label
Label -> Constr
Label -> DataType
(forall b. Data b => b -> b) -> Label -> Label
forall a.
Typeable a
-> (forall (c :: * -> *).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> a -> c a)
-> (forall (c :: * -> *).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c a)
-> (a -> Constr)
-> (a -> DataType)
-> (forall (t :: * -> *) (c :: * -> *).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c a))
-> (forall (t :: * -> * -> *) (c :: * -> *).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c a))
-> ((forall b. Data b => b -> b) -> a -> a)
-> (forall r r'.
(r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> a -> r)
-> (forall r r'.
(r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> a -> r)
-> (forall u. (forall d. Data d => d -> u) -> a -> [u])
-> (forall u. Int -> (forall d. Data d => d -> u) -> a -> u)
-> (forall (m :: * -> *).
Monad m =>
(forall d. Data d => d -> m d) -> a -> m a)
-> (forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> a -> m a)
-> (forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> a -> m a)
-> Data a
forall u. Int -> (forall d. Data d => d -> u) -> Label -> u
forall u. (forall d. Data d => d -> u) -> Label -> [u]
forall r r'.
(r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Label -> r
forall r r'.
(r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Label -> r
forall (m :: * -> *).
Monad m =>
(forall d. Data d => d -> m d) -> Label -> m Label
forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Label -> m Label
forall (c :: * -> *).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c Label
forall (c :: * -> *).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> Label -> c Label
forall (t :: * -> *) (c :: * -> *).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c Label)
forall (t :: * -> * -> *) (c :: * -> *).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Label)
gmapMo :: forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Label -> m Label
$cgmapMo :: forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Label -> m Label
gmapMp :: forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Label -> m Label
$cgmapMp :: forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> Label -> m Label
gmapM :: forall (m :: * -> *).
Monad m =>
(forall d. Data d => d -> m d) -> Label -> m Label
$cgmapM :: forall (m :: * -> *).
Monad m =>
(forall d. Data d => d -> m d) -> Label -> m Label
gmapQi :: forall u. Int -> (forall d. Data d => d -> u) -> Label -> u
$cgmapQi :: forall u. Int -> (forall d. Data d => d -> u) -> Label -> u
gmapQ :: forall u. (forall d. Data d => d -> u) -> Label -> [u]
$cgmapQ :: forall u. (forall d. Data d => d -> u) -> Label -> [u]
gmapQr :: forall r r'.
(r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Label -> r
$cgmapQr :: forall r r'.
(r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Label -> r
gmapQl :: forall r r'.
(r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Label -> r
$cgmapQl :: forall r r'.
(r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Label -> r
gmapT :: (forall b. Data b => b -> b) -> Label -> Label
$cgmapT :: (forall b. Data b => b -> b) -> Label -> Label
dataCast2 :: forall (t :: * -> * -> *) (c :: * -> *).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Label)
$cdataCast2 :: forall (t :: * -> * -> *) (c :: * -> *).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Label)
dataCast1 :: forall (t :: * -> *) (c :: * -> *).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c Label)
$cdataCast1 :: forall (t :: * -> *) (c :: * -> *).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c Label)
dataTypeOf :: Label -> DataType
$cdataTypeOf :: Label -> DataType
toConstr :: Label -> Constr
$ctoConstr :: Label -> Constr
gunfold :: forall (c :: * -> *).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c Label
$cgunfold :: forall (c :: * -> *).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c Label
gfoldl :: forall (c :: * -> *).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> Label -> c Label
$cgfoldl :: forall (c :: * -> *).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> Label -> c Label
Data, Typeable)
annotateLabelSets :: Data a =>
(a -> Set Label)
-> (Set Label -> a -> a)
-> JavaScript a
-> JavaScript a
annotateLabelSets :: forall a.
Data a =>
(a -> Set Label)
-> (Set Label -> a -> a) -> JavaScript a -> JavaScript a
annotateLabelSets a -> Set Label
r Set Label -> a -> a
w = forall from to. Biplate from to => (to -> to) -> from -> from
transformBi (forall a.
Data a =>
(a -> Set Label)
-> (Set Label -> a -> a) -> Statement a -> Statement a
annotateFuncStmtBodies a -> Set Label
r Set Label -> a -> a
w)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall from to. Biplate from to => (to -> to) -> from -> from
transformBi (forall a.
Data a =>
(a -> Set Label)
-> (Set Label -> a -> a) -> Expression a -> Expression a
annotateFuncExprBodies a -> Set Label
r Set Label -> a -> a
w)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall from to. Biplate from to => (to -> to) -> from -> from
descendBi (forall a.
Data a =>
(a -> Set Label)
-> (Set Label -> a -> a) -> Statement a -> Statement a
annotateStatement a -> Set Label
r Set Label -> a -> a
w)
annotateFuncStmtBodies :: Data a =>
(a -> Set Label)
-> (Set Label -> a -> a)
-> Statement a
-> Statement a
annotateFuncStmtBodies :: forall a.
Data a =>
(a -> Set Label)
-> (Set Label -> a -> a) -> Statement a -> Statement a
annotateFuncStmtBodies a -> Set Label
r Set Label -> a -> a
w Statement a
s = case Statement a
s of
FunctionStmt a
a Id a
name [Id a]
params [Statement a]
body ->
let newbody :: [Statement a]
newbody = forall a b. (a -> b) -> [a] -> [b]
map (forall on. Uniplate on => (on -> on) -> on -> on
descend (forall a.
Data a =>
(a -> Set Label)
-> (Set Label -> a -> a) -> Statement a -> Statement a
annotateStatement a -> Set Label
r Set Label -> a -> a
w)) [Statement a]
body
in forall a. a -> Id a -> [Id a] -> [Statement a] -> Statement a
FunctionStmt a
a Id a
name [Id a]
params [Statement a]
newbody
Statement a
_ -> Statement a
s
annotateFuncExprBodies :: Data a =>
(a -> Set Label)
-> (Set Label -> a -> a)
-> Expression a
-> Expression a
annotateFuncExprBodies :: forall a.
Data a =>
(a -> Set Label)
-> (Set Label -> a -> a) -> Expression a -> Expression a
annotateFuncExprBodies a -> Set Label
r Set Label -> a -> a
w Expression a
e = case Expression a
e of
FuncExpr a
a Maybe (Id a)
mname [Id a]
params [Statement a]
body ->
let newbody :: [Statement a]
newbody = forall a b. (a -> b) -> [a] -> [b]
map (forall on. Uniplate on => (on -> on) -> on -> on
descend (forall a.
Data a =>
(a -> Set Label)
-> (Set Label -> a -> a) -> Statement a -> Statement a
annotateStatement a -> Set Label
r Set Label -> a -> a
w)) [Statement a]
body
in forall a.
a -> Maybe (Id a) -> [Id a] -> [Statement a] -> Expression a
FuncExpr a
a Maybe (Id a)
mname [Id a]
params [Statement a]
newbody
Expression a
_ -> Expression a
e
annotateStatement :: Data a =>
(a -> Set Label)
-> (Set Label -> a -> a)
-> Statement a
-> Statement a
annotateStatement :: forall a.
Data a =>
(a -> Set Label)
-> (Set Label -> a -> a) -> Statement a -> Statement a
annotateStatement a -> Set Label
r Set Label -> a -> a
w Statement a
s = case Statement a
s of
LabelledStmt a
ann Id a
lab Statement a
stmt ->
let labelset :: Set Label
labelset = forall a. Ord a => a -> Set a -> Set a
Set.insert (forall a. Id a -> Label
id2Label Id a
lab) (a -> Set Label
r a
ann)
newstmt :: Statement a
newstmt = forall a.
Data a =>
(a -> Set Label)
-> (Set Label -> a -> a) -> Statement a -> Statement a
annotateStatement a -> Set Label
r Set Label -> a -> a
w forall a b. (a -> b) -> a -> b
$ Set Label -> a -> a
w Set Label
labelset forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Statement a
stmt
in forall a. a -> Id a -> Statement a -> Statement a
LabelledStmt a
ann Id a
lab Statement a
newstmt
SwitchStmt {} ->
let labelset :: Set Label
labelset = forall a. Ord a => a -> Set a -> Set a
Set.insert Label
EmptyLabel (a -> Set Label
r forall a b. (a -> b) -> a -> b
$ forall (a :: * -> *) b. HasAnnotation a => a b -> b
getAnnotation Statement a
s)
in forall on. Uniplate on => (on -> on) -> on -> on
descend (forall a.
Data a =>
(a -> Set Label)
-> (Set Label -> a -> a) -> Statement a -> Statement a
annotateStatement a -> Set Label
r Set Label -> a -> a
w) (Set Label -> a -> a
w Set Label
labelset forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Statement a
s)
Statement a
_ | forall a. Statement a -> Bool
isIterationStmt Statement a
s ->
let labelset :: Set Label
labelset = forall a. Ord a => a -> Set a -> Set a
Set.insert Label
EmptyLabel (a -> Set Label
r forall a b. (a -> b) -> a -> b
$ forall (a :: * -> *) b. HasAnnotation a => a b -> b
getAnnotation Statement a
s)
in forall on. Uniplate on => (on -> on) -> on -> on
descend (forall a.
Data a =>
(a -> Set Label)
-> (Set Label -> a -> a) -> Statement a -> Statement a
annotateStatement a -> Set Label
r Set Label -> a -> a
w) (Set Label -> a -> a
w Set Label
labelset forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Statement a
s)
Statement a
_ -> forall on. Uniplate on => (on -> on) -> on -> on
descend (forall a.
Data a =>
(a -> Set Label)
-> (Set Label -> a -> a) -> Statement a -> Statement a
annotateStatement a -> Set Label
r Set Label -> a -> a
w) Statement a
s
id2Label :: Id a -> Label
id2Label :: forall a. Id a -> Label
id2Label = String -> Label
Label forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. Id a -> String
unId