mirror of
https://github.com/github/semantic.git
synced 2025-01-04 05:27:08 +03:00
Merge branch 'bounds-checked-reverse-RWS-matching' into abstract-rendering-over-the-syntax-functor
This commit is contained in:
commit
18cc8035ee
@ -46,7 +46,7 @@ patchDiff :: DiffArguments'
|
|||||||
patchDiff = DiffArguments PatchRenderer identityDecorator
|
patchDiff = DiffArguments PatchRenderer identityDecorator
|
||||||
|
|
||||||
jsonDiff :: DiffArguments'
|
jsonDiff :: DiffArguments'
|
||||||
jsonDiff = DiffArguments JSONDiffRenderer identityDecorator
|
jsonDiff = DiffArguments JSONDiffRenderer (const identifierDecorator)
|
||||||
|
|
||||||
sExpressionDiff :: DiffArguments'
|
sExpressionDiff :: DiffArguments'
|
||||||
sExpressionDiff = DiffArguments (SExpressionDiffRenderer TreeOnly) identityDecorator
|
sExpressionDiff = DiffArguments (SExpressionDiffRenderer TreeOnly) identityDecorator
|
||||||
|
@ -183,17 +183,16 @@ findNearestNeighbourTo editDistance canCompare kdTrees term@(UnmappedTerm j _ b)
|
|||||||
(previous, unmappedA, unmappedB) <- get
|
(previous, unmappedA, unmappedB) <- get
|
||||||
fromMaybe (insertion previous unmappedA unmappedB term) $ do
|
fromMaybe (insertion previous unmappedA unmappedB term) $ do
|
||||||
-- Look up the nearest unmapped term in `unmappedA`.
|
-- Look up the nearest unmapped term in `unmappedA`.
|
||||||
foundA@(UnmappedTerm i _ a) <- nearestUnmapped editDistance canCompare (IntMap.filterWithKey (\ k _ ->
|
foundA@(UnmappedTerm i _ a) <- nearestUnmapped editDistance canCompare (termsWithinMoveBoundsFrom previous unmappedA) (Both.fst kdTrees) term
|
||||||
isInMoveBounds previous k)
|
|
||||||
unmappedA) (Both.fst kdTrees) term
|
|
||||||
-- Look up the nearest `foundA` in `unmappedB`
|
-- Look up the nearest `foundA` in `unmappedB`
|
||||||
UnmappedTerm j' _ _ <- nearestUnmapped editDistance canCompare unmappedB (Both.snd kdTrees) foundA
|
UnmappedTerm j' _ _ <- nearestUnmapped editDistance canCompare (termsWithinMoveBoundsFrom (pred j) unmappedB) (Both.snd kdTrees) foundA
|
||||||
-- Return Nothing if their indices don't match
|
-- Return Nothing if their indices don't match
|
||||||
guard (j == j')
|
guard (j == j')
|
||||||
guard (canCompare a b)
|
guard (canCompare a b)
|
||||||
pure $! do
|
pure $! do
|
||||||
put (i, IntMap.delete i unmappedA, IntMap.delete j unmappedB)
|
put (i, IntMap.delete i unmappedA, IntMap.delete j unmappedB)
|
||||||
pure (These i j, These a b)
|
pure (These i j, These a b)
|
||||||
|
where termsWithinMoveBoundsFrom bound = IntMap.filterWithKey (\ k _ -> isInMoveBounds bound k)
|
||||||
|
|
||||||
isInMoveBounds :: Int -> Int -> Bool
|
isInMoveBounds :: Int -> Int -> Bool
|
||||||
isInMoveBounds previous i = previous < i && i < previous + defaultMoveBound
|
isInMoveBounds previous i = previous < i && i < previous + defaultMoveBound
|
||||||
@ -391,4 +390,3 @@ instance Listable1 Gram where
|
|||||||
|
|
||||||
instance Listable a => Listable (Gram a) where
|
instance Listable a => Listable (Gram a) where
|
||||||
tiers = tiers1
|
tiers = tiers1
|
||||||
|
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
{-# LANGUAGE DataKinds, GADTs, MultiParamTypeClasses, TypeOperators #-}
|
{-# LANGUAGE DataKinds, GADTs, GeneralizedNewtypeDeriving, MultiParamTypeClasses, TypeOperators #-}
|
||||||
module Renderer
|
module Renderer
|
||||||
( Renderer(..)
|
( Renderer(..)
|
||||||
, SExpressionFormat(..)
|
, SExpressionFormat(..)
|
||||||
, resolveRenderer
|
, resolveRenderer
|
||||||
, runRenderer
|
, runRenderer
|
||||||
, declarationDecorator
|
, declarationDecorator
|
||||||
|
, identifierDecorator
|
||||||
, Summaries(..)
|
, Summaries(..)
|
||||||
, File(..)
|
, File(..)
|
||||||
) where
|
) where
|
||||||
@ -42,7 +43,14 @@ resolveRenderer renderer input = case renderer of
|
|||||||
SExpressionDiffRenderer format -> uncurry (R.sExpression format) input
|
SExpressionDiffRenderer format -> uncurry (R.sExpression format) input
|
||||||
ToCRenderer -> uncurry R.toc input
|
ToCRenderer -> uncurry R.toc input
|
||||||
SExpressionParseTreeRenderer format -> uncurry (R.sExpressionParseTree format) input
|
SExpressionParseTreeRenderer format -> uncurry (R.sExpressionParseTree format) input
|
||||||
JSONParseTreeRenderer -> let (blob, term) = input in R.jsonFile blob (decoratorWithAlgebra identifierAlg term)
|
JSONParseTreeRenderer -> let (blob, term) = input in R.jsonFile blob (identifierDecorator term)
|
||||||
|
|
||||||
|
|
||||||
|
declarationDecorator :: Source -> Term (Syntax Text) (Record DefaultFields) -> Term (Syntax Text) (Record (Maybe Declaration ': DefaultFields))
|
||||||
|
declarationDecorator = decoratorWithAlgebra . declarationAlgebra
|
||||||
|
|
||||||
|
identifierDecorator :: Term (Syntax Text) (Record fields) -> Term (Syntax Text) (Record (Maybe Identifier ': fields))
|
||||||
|
identifierDecorator = decoratorWithAlgebra identifierAlg
|
||||||
where identifierAlg :: RAlgebra (CofreeF (Syntax Text) a) (Cofree (Syntax Text) a) (Maybe Identifier)
|
where identifierAlg :: RAlgebra (CofreeF (Syntax Text) a) (Cofree (Syntax Text) a) (Maybe Identifier)
|
||||||
identifierAlg (_ :< syntax) = case syntax of
|
identifierAlg (_ :< syntax) = case syntax of
|
||||||
S.Assignment f _ -> identifier f
|
S.Assignment f _ -> identifier f
|
||||||
@ -65,12 +73,8 @@ runRenderer :: (Monoid output, StringConv output ByteString) => Renderer input o
|
|||||||
runRenderer = foldMap . resolveRenderer
|
runRenderer = foldMap . resolveRenderer
|
||||||
|
|
||||||
|
|
||||||
declarationDecorator :: Source -> Term (Syntax Text) (Record DefaultFields) -> Term (Syntax Text) (Record (Maybe Declaration ': DefaultFields))
|
|
||||||
declarationDecorator = decoratorWithAlgebra . declarationAlgebra
|
|
||||||
|
|
||||||
|
|
||||||
newtype Identifier = Identifier Text
|
newtype Identifier = Identifier Text
|
||||||
deriving (Eq, Show)
|
deriving (Eq, NFData, Show)
|
||||||
|
|
||||||
instance ToJSONFields Identifier where
|
instance ToJSONFields Identifier where
|
||||||
toJSONFields (Identifier i) = ["identifier" .= i]
|
toJSONFields (Identifier i) = ["identifier" .= i]
|
||||||
|
@ -76,8 +76,8 @@ instance Listable DiffFixture where
|
|||||||
patchOutput = "diff --git a/test/fixtures/ruby/method-declaration.A.rb b/test/fixtures/ruby/method-declaration.B.rb\nindex 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644\n--- a/test/fixtures/ruby/method-declaration.A.rb\n+++ b/test/fixtures/ruby/method-declaration.B.rb\n@@ -1,3 +1,4 @@\n-def foo\n+def bar(a)\n+ baz\n end\n\n"
|
patchOutput = "diff --git a/test/fixtures/ruby/method-declaration.A.rb b/test/fixtures/ruby/method-declaration.B.rb\nindex 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644\n--- a/test/fixtures/ruby/method-declaration.A.rb\n+++ b/test/fixtures/ruby/method-declaration.B.rb\n@@ -1,3 +1,4 @@\n-def foo\n+def bar(a)\n+ baz\n end\n\n"
|
||||||
patchOutput' = "diff --git a/methods.rb b/methods.rb\nnew file mode 100644\nindex 0000000000000000000000000000000000000000..ff7bbbe9495f61d9e1e58c597502d152bab1761e\n--- /dev/null\n+++ b/methods.rb\n+def foo\n+end\n\n"
|
patchOutput' = "diff --git a/methods.rb b/methods.rb\nnew file mode 100644\nindex 0000000000000000000000000000000000000000..ff7bbbe9495f61d9e1e58c597502d152bab1761e\n--- /dev/null\n+++ b/methods.rb\n+def foo\n+end\n\n"
|
||||||
|
|
||||||
jsonOutput = "{\"diff\":{\"after\":{\"category\":\"Program\",\"sourceRange\":[0,21],\"sourceSpan\":{\"start\":[1,1],\"end\":[4,1]}},\"children\":[{\"after\":{\"category\":\"Method\",\"sourceRange\":[0,20],\"sourceSpan\":{\"start\":[1,1],\"end\":[3,4]}},\"children\":[{\"replace\":[{\"category\":\"Identifier\",\"children\":[],\"sourceRange\":[4,7],\"sourceSpan\":{\"start\":[1,5],\"end\":[1,8]}},{\"category\":\"Identifier\",\"children\":[],\"sourceRange\":[4,7],\"sourceSpan\":{\"start\":[1,5],\"end\":[1,8]}}]},{\"insert\":{\"category\":\"Params\",\"children\":[{\"category\":\"Identifier\",\"children\":[],\"sourceRange\":[8,9],\"sourceSpan\":{\"start\":[1,9],\"end\":[1,10]}}],\"sourceRange\":[7,13],\"sourceSpan\":{\"start\":[1,8],\"end\":[2,3]}}},{\"insert\":{\"category\":\"Identifier\",\"children\":[],\"sourceRange\":[13,16],\"sourceSpan\":{\"start\":[2,3],\"end\":[2,6]}}}],\"before\":{\"category\":\"Method\",\"sourceRange\":[0,11],\"sourceSpan\":{\"start\":[1,1],\"end\":[2,4]}}}],\"before\":{\"category\":\"Program\",\"sourceRange\":[0,12],\"sourceSpan\":{\"start\":[1,1],\"end\":[3,1]}}},\"oids\":[\"0000000000000000000000000000000000000000\",\"0000000000000000000000000000000000000000\"],\"paths\":[\"test/fixtures/ruby/method-declaration.A.rb\",\"test/fixtures/ruby/method-declaration.B.rb\"]}\n"
|
jsonOutput = "{\"diff\":{\"after\":{\"category\":\"Program\",\"sourceRange\":[0,21],\"sourceSpan\":{\"start\":[1,1],\"end\":[4,1]}},\"children\":[{\"after\":{\"category\":\"Method\",\"identifier\":\"bar\",\"sourceRange\":[0,20],\"sourceSpan\":{\"start\":[1,1],\"end\":[3,4]}},\"children\":[{\"replace\":[{\"category\":\"Identifier\",\"children\":[],\"sourceRange\":[4,7],\"sourceSpan\":{\"start\":[1,5],\"end\":[1,8]}},{\"category\":\"Identifier\",\"children\":[],\"sourceRange\":[4,7],\"sourceSpan\":{\"start\":[1,5],\"end\":[1,8]}}]},{\"insert\":{\"category\":\"Params\",\"children\":[{\"category\":\"Identifier\",\"children\":[],\"sourceRange\":[8,9],\"sourceSpan\":{\"start\":[1,9],\"end\":[1,10]}}],\"sourceRange\":[7,13],\"sourceSpan\":{\"start\":[1,8],\"end\":[2,3]}}},{\"insert\":{\"category\":\"Identifier\",\"children\":[],\"sourceRange\":[13,16],\"sourceSpan\":{\"start\":[2,3],\"end\":[2,6]}}}],\"before\":{\"category\":\"Method\",\"identifier\":\"foo\",\"sourceRange\":[0,11],\"sourceSpan\":{\"start\":[1,1],\"end\":[2,4]}}}],\"before\":{\"category\":\"Program\",\"sourceRange\":[0,12],\"sourceSpan\":{\"start\":[1,1],\"end\":[3,1]}}},\"oids\":[\"0000000000000000000000000000000000000000\",\"0000000000000000000000000000000000000000\"],\"paths\":[\"test/fixtures/ruby/method-declaration.A.rb\",\"test/fixtures/ruby/method-declaration.B.rb\"]}\n"
|
||||||
jsonOutput' = "{\"diff\":{\"insert\":{\"category\":\"Program\",\"children\":[{\"category\":\"Method\",\"children\":[{\"category\":\"Identifier\",\"children\":[],\"sourceRange\":[4,7],\"sourceSpan\":{\"start\":[1,5],\"end\":[1,8]}}],\"sourceRange\":[0,11],\"sourceSpan\":{\"start\":[1,1],\"end\":[2,4]}}],\"sourceRange\":[0,12],\"sourceSpan\":{\"start\":[1,1],\"end\":[3,1]}}},\"oids\":[\"0000000000000000000000000000000000000000\",\"ff7bbbe9495f61d9e1e58c597502d152bab1761e\"],\"paths\":[\"methods.rb\",\"methods.rb\"]}\n"
|
jsonOutput' = "{\"diff\":{\"insert\":{\"category\":\"Program\",\"children\":[{\"category\":\"Method\",\"children\":[{\"category\":\"Identifier\",\"children\":[],\"sourceRange\":[4,7],\"sourceSpan\":{\"start\":[1,5],\"end\":[1,8]}}],\"identifier\":\"foo\",\"sourceRange\":[0,11],\"sourceSpan\":{\"start\":[1,1],\"end\":[2,4]}}],\"sourceRange\":[0,12],\"sourceSpan\":{\"start\":[1,1],\"end\":[3,1]}}},\"oids\":[\"0000000000000000000000000000000000000000\",\"ff7bbbe9495f61d9e1e58c597502d152bab1761e\"],\"paths\":[\"methods.rb\",\"methods.rb\"]}\n"
|
||||||
sExpressionOutput = "(Program\n (Method\n { (Identifier)\n ->(Identifier) }\n {+(Params\n (Identifier))+}\n {+(Identifier)+}))\n"
|
sExpressionOutput = "(Program\n (Method\n { (Identifier)\n ->(Identifier) }\n {+(Params\n (Identifier))+}\n {+(Identifier)+}))\n"
|
||||||
sExpressionOutput' = "{+(Program\n (Method\n (Identifier)))+}\n"
|
sExpressionOutput' = "{+(Program\n (Method\n (Identifier)))+}\n"
|
||||||
tocOutput = "{\"changes\":{\"test/fixtures/ruby/method-declaration.A.rb -> test/fixtures/ruby/method-declaration.B.rb\":[{\"span\":{\"start\":[1,1],\"end\":[3,4]},\"category\":\"Method\",\"term\":\"bar\",\"changeType\":\"modified\"}]},\"errors\":{}}\n"
|
tocOutput = "{\"changes\":{\"test/fixtures/ruby/method-declaration.A.rb -> test/fixtures/ruby/method-declaration.B.rb\":[{\"span\":{\"start\":[1,1],\"end\":[3,4]},\"category\":\"Method\",\"term\":\"bar\",\"changeType\":\"modified\"}]},\"errors\":{}}\n"
|
||||||
|
28
test/fixtures/go/channel-types.diffB-A.txt
vendored
28
test/fixtures/go/channel-types.diffB-A.txt
vendored
@ -5,25 +5,23 @@
|
|||||||
(Identifier)
|
(Identifier)
|
||||||
(Args)
|
(Args)
|
||||||
(Other "type_declaration"
|
(Other "type_declaration"
|
||||||
{+(TypeDecl
|
|
||||||
(Identifier)
|
|
||||||
(ChannelTy
|
|
||||||
(ChannelTy
|
|
||||||
(Identifier))))+}
|
|
||||||
(TypeDecl
|
(TypeDecl
|
||||||
(Identifier)
|
{ (Identifier)
|
||||||
|
->(Identifier) }
|
||||||
(ChannelTy
|
(ChannelTy
|
||||||
(ChannelTy
|
(ChannelTy
|
||||||
{ (Identifier)
|
{ (Identifier)
|
||||||
->(StructTy) })))
|
|
||||||
(TypeDecl
|
|
||||||
(Identifier)
|
|
||||||
(ChannelTy
|
|
||||||
(ChannelTy
|
|
||||||
{ (StructTy)
|
|
||||||
->(Identifier) })))
|
->(Identifier) })))
|
||||||
{-(TypeDecl
|
(TypeDecl
|
||||||
(Identifier)
|
{ (Identifier)
|
||||||
|
->(Identifier) }
|
||||||
(ChannelTy
|
(ChannelTy
|
||||||
(ChannelTy
|
(ChannelTy
|
||||||
(Identifier))))-})))
|
(StructTy))))
|
||||||
|
(TypeDecl
|
||||||
|
{ (Identifier)
|
||||||
|
->(Identifier) }
|
||||||
|
(ChannelTy
|
||||||
|
(ChannelTy
|
||||||
|
{ (Identifier)
|
||||||
|
->(Identifier) }))))))
|
||||||
|
22
test/fixtures/go/for-statements.diffA-B.txt
vendored
22
test/fixtures/go/for-statements.diffA-B.txt
vendored
@ -4,11 +4,15 @@
|
|||||||
(Function
|
(Function
|
||||||
(Identifier)
|
(Identifier)
|
||||||
(Args)
|
(Args)
|
||||||
{+(For
|
{ (For
|
||||||
(FunctionCall
|
(ExpressionStatements
|
||||||
(Identifier))
|
(FunctionCall
|
||||||
(Other "goto_statement"
|
(Identifier)
|
||||||
(Identifier)))+}
|
)(Other"goto_statement"(Identifier))))
|
||||||
|
->(For
|
||||||
|
(FunctionCall
|
||||||
|
(Identifier))
|
||||||
|
(Other"goto_statement"(Identifier))) }
|
||||||
{+(For
|
{+(For
|
||||||
(Other "expression_list"
|
(Other "expression_list"
|
||||||
(Identifier))
|
(Identifier))
|
||||||
@ -30,14 +34,12 @@
|
|||||||
(FunctionCall
|
(FunctionCall
|
||||||
(Identifier))
|
(Identifier))
|
||||||
(Continue))+}
|
(Continue))+}
|
||||||
(For
|
{+(For
|
||||||
(ExpressionStatements
|
(ExpressionStatements
|
||||||
(FunctionCall
|
(FunctionCall
|
||||||
(Identifier)
|
(Identifier)
|
||||||
{+(Identifier)+})
|
(Identifier))
|
||||||
{+(Break)+}
|
(Break)))+}
|
||||||
{-(Other "goto_statement"
|
|
||||||
(Identifier))-}))
|
|
||||||
{-(For
|
{-(For
|
||||||
(VarDecl
|
(VarDecl
|
||||||
(Other "expression_list"
|
(Other "expression_list"
|
||||||
|
31
test/fixtures/go/for-statements.diffB-A.txt
vendored
31
test/fixtures/go/for-statements.diffB-A.txt
vendored
@ -4,12 +4,15 @@
|
|||||||
(Function
|
(Function
|
||||||
(Identifier)
|
(Identifier)
|
||||||
(Args)
|
(Args)
|
||||||
{+(For
|
{ (For
|
||||||
|
(FunctionCall
|
||||||
|
(Identifier))
|
||||||
|
(Other"goto_statement"(Identifier)))
|
||||||
|
->(For
|
||||||
(ExpressionStatements
|
(ExpressionStatements
|
||||||
(FunctionCall
|
(FunctionCall
|
||||||
(Identifier))
|
(Identifier)
|
||||||
(Other "goto_statement"
|
)(Other"goto_statement"(Identifier)))) }
|
||||||
(Identifier))))+}
|
|
||||||
{+(For
|
{+(For
|
||||||
(VarDecl
|
(VarDecl
|
||||||
(Other "expression_list"
|
(Other "expression_list"
|
||||||
@ -33,20 +36,18 @@
|
|||||||
(Identifier))
|
(Identifier))
|
||||||
(Continue
|
(Continue
|
||||||
(Identifier)))+}
|
(Identifier)))+}
|
||||||
(For
|
{+(For
|
||||||
(FunctionCall
|
(FunctionCall
|
||||||
(Identifier))
|
(Identifier))
|
||||||
{ (Other "goto_statement"
|
(Continue))+}
|
||||||
(Identifier))
|
(For
|
||||||
->(Continue) })
|
(Other "expression_list"
|
||||||
(For
|
(Identifier))
|
||||||
(Other "expression_list"
|
(Identifier)
|
||||||
(Identifier))
|
(FunctionCall
|
||||||
(Identifier)
|
(Identifier)
|
||||||
(FunctionCall
|
|
||||||
(Identifier)
|
|
||||||
{+(Identifier)+})
|
{+(Identifier)+})
|
||||||
(Break
|
(Break
|
||||||
{-(Identifier)-}))
|
{-(Identifier)-}))
|
||||||
{-(For
|
{-(For
|
||||||
(FunctionCall
|
(FunctionCall
|
||||||
@ -66,4 +67,4 @@
|
|||||||
(FunctionCall
|
(FunctionCall
|
||||||
(Identifier)
|
(Identifier)
|
||||||
(Identifier))
|
(Identifier))
|
||||||
(Break)))-}))
|
(Break)))-}))
|
||||||
|
14
test/fixtures/go/map-literals.diffA-B.txt
vendored
14
test/fixtures/go/map-literals.diffA-B.txt
vendored
@ -14,13 +14,13 @@
|
|||||||
(Identifier)
|
(Identifier)
|
||||||
{ (Identifier)
|
{ (Identifier)
|
||||||
->(Identifier) })
|
->(Identifier) })
|
||||||
{+(Pair
|
|
||||||
(StringLiteral)
|
|
||||||
(StringLiteral))+}
|
|
||||||
(Pair
|
(Pair
|
||||||
{ (StringLiteral)
|
{ (StringLiteral)
|
||||||
->(StringLiteral) }
|
->(StringLiteral) }
|
||||||
(StringLiteral))
|
{ (StringLiteral)
|
||||||
{-(Pair
|
->(StringLiteral) })
|
||||||
(StringLiteral)
|
(Pair
|
||||||
(StringLiteral))-}))))))
|
{ (StringLiteral)
|
||||||
|
->(StringLiteral) }
|
||||||
|
{ (StringLiteral)
|
||||||
|
->(StringLiteral) })))))))
|
||||||
|
@ -7,13 +7,13 @@
|
|||||||
(Function
|
(Function
|
||||||
(Identifier)
|
(Identifier)
|
||||||
(Args
|
(Args
|
||||||
{+(ParameterDecl
|
|
||||||
(Identifier)
|
|
||||||
(Identifier))+}
|
|
||||||
(ParameterDecl
|
(ParameterDecl
|
||||||
(Identifier)
|
{ (Identifier)
|
||||||
|
->(Identifier) }
|
||||||
{ (Identifier)
|
{ (Identifier)
|
||||||
->(Identifier) })
|
->(Identifier) })
|
||||||
{-(ParameterDecl
|
(ParameterDecl
|
||||||
(Identifier)
|
{ (Identifier)
|
||||||
(Identifier))-})))
|
->(Identifier) }
|
||||||
|
{ (Identifier)
|
||||||
|
->(Identifier) }))))
|
||||||
|
88
test/fixtures/javascript/export.diffA-B.txt
vendored
88
test/fixtures/javascript/export.diffA-B.txt
vendored
@ -12,68 +12,54 @@
|
|||||||
(Other "export_specifier"
|
(Other "export_specifier"
|
||||||
{ (Identifier)
|
{ (Identifier)
|
||||||
->(Identifier) }))
|
->(Identifier) }))
|
||||||
{+(Export
|
(Export
|
||||||
(Other "export_specifier"
|
(Other "export_specifier"
|
||||||
(Identifier)
|
{ (Identifier)
|
||||||
(Identifier))
|
->(Identifier)}
|
||||||
(Other "export_specifier"
|
{ (Identifier)
|
||||||
(Identifier)
|
->(Identifier)})
|
||||||
(Identifier))
|
(Other "export_specifier"
|
||||||
(Other "export_specifier"
|
{ (Identifier)
|
||||||
(Identifier)))+}
|
->(Identifier)}
|
||||||
{+(Export
|
{ (Identifier)
|
||||||
|
->(Identifier)})
|
||||||
|
(Other "export_specifier"
|
||||||
|
{ (Identifier)
|
||||||
|
->(Identifier)}))
|
||||||
|
(Export
|
||||||
(VarDecl
|
(VarDecl
|
||||||
(Identifier))
|
{ (Identifier)
|
||||||
|
->(Identifier)})
|
||||||
(VarDecl
|
(VarDecl
|
||||||
(Identifier))
|
{ (Identifier)
|
||||||
|
->(Identifier)})
|
||||||
(VarDecl
|
(VarDecl
|
||||||
(Identifier)))+}
|
{ (Identifier)
|
||||||
{+(Export
|
->(Identifier)}))
|
||||||
|
(Export
|
||||||
(VarAssignment
|
(VarAssignment
|
||||||
(Identifier)
|
{ (Identifier)
|
||||||
(Identifier))
|
->(Identifier)}
|
||||||
|
{ (Identifier)
|
||||||
|
->(Identifier)})
|
||||||
(VarAssignment
|
(VarAssignment
|
||||||
(Identifier)
|
{ (Identifier)
|
||||||
(Identifier))
|
->(Identifier)}
|
||||||
|
{ (Identifier)
|
||||||
|
->(Identifier)})
|
||||||
(VarDecl
|
(VarDecl
|
||||||
(Identifier))
|
{ (Identifier)
|
||||||
|
->(Identifier)})
|
||||||
(VarDecl
|
(VarDecl
|
||||||
(Identifier)))+}
|
{ (Identifier)
|
||||||
{+(Export
|
->(Identifier)}))
|
||||||
(Identifier))+}
|
(Export
|
||||||
|
{ (Identifier)
|
||||||
|
->(Identifier)})
|
||||||
{+(Export
|
{+(Export
|
||||||
(Function
|
(Function
|
||||||
(Identifier)
|
(Identifier)
|
||||||
(Params)))+}
|
(Params)))+}
|
||||||
{-(Export
|
|
||||||
(Other "export_specifier"
|
|
||||||
(Identifier)
|
|
||||||
(Identifier))
|
|
||||||
(Other "export_specifier"
|
|
||||||
(Identifier)
|
|
||||||
(Identifier))
|
|
||||||
(Other "export_specifier"
|
|
||||||
(Identifier)))-}
|
|
||||||
{-(Export
|
|
||||||
(VarDecl
|
|
||||||
(Identifier))
|
|
||||||
(VarDecl
|
|
||||||
(Identifier))
|
|
||||||
(VarDecl
|
|
||||||
(Identifier)))-}
|
|
||||||
{-(Export
|
|
||||||
(VarAssignment
|
|
||||||
(Identifier)
|
|
||||||
(Identifier))
|
|
||||||
(VarAssignment
|
|
||||||
(Identifier)
|
|
||||||
(Identifier))
|
|
||||||
(VarDecl
|
|
||||||
(Identifier))
|
|
||||||
(VarDecl
|
|
||||||
(Identifier)))-}
|
|
||||||
{-(Export
|
|
||||||
(Identifier))-}
|
|
||||||
(Export
|
(Export
|
||||||
(Function
|
(Function
|
||||||
(Params)))
|
(Params)))
|
||||||
|
17
test/fixtures/javascript/export.diffB-A.txt
vendored
17
test/fixtures/javascript/export.diffB-A.txt
vendored
@ -63,16 +63,17 @@
|
|||||||
(Export
|
(Export
|
||||||
(Function
|
(Function
|
||||||
(Params)))
|
(Params)))
|
||||||
{+(Export
|
|
||||||
(Function
|
|
||||||
(Identifier)
|
|
||||||
(Params)))+}
|
|
||||||
(Export
|
(Export
|
||||||
|
{+(Function
|
||||||
|
(Identifier)
|
||||||
|
(Params))+}
|
||||||
|
{-(Other "export_specifier"
|
||||||
|
(Identifier)
|
||||||
|
(Identifier))-})
|
||||||
|
{+(Export
|
||||||
(Other "export_specifier"
|
(Other "export_specifier"
|
||||||
{ (Identifier)
|
(Identifier)
|
||||||
->(Identifier) }
|
(Identifier)))+}
|
||||||
{ (Identifier)
|
|
||||||
->(Identifier) }))
|
|
||||||
(Export
|
(Export
|
||||||
{ (StringLiteral)
|
{ (StringLiteral)
|
||||||
->(StringLiteral) })
|
->(StringLiteral) })
|
||||||
|
88
test/fixtures/typescript/export.diffA-B.txt
vendored
88
test/fixtures/typescript/export.diffA-B.txt
vendored
@ -12,68 +12,54 @@
|
|||||||
(Other "export_specifier"
|
(Other "export_specifier"
|
||||||
{ (Identifier)
|
{ (Identifier)
|
||||||
->(Identifier) }))
|
->(Identifier) }))
|
||||||
{+(Export
|
(Export
|
||||||
(Other "export_specifier"
|
(Other "export_specifier"
|
||||||
(Identifier)
|
{ (Identifier)
|
||||||
(Identifier))
|
->(Identifier)}
|
||||||
(Other "export_specifier"
|
{ (Identifier)
|
||||||
(Identifier)
|
->(Identifier)})
|
||||||
(Identifier))
|
(Other "export_specifier"
|
||||||
(Other "export_specifier"
|
{ (Identifier)
|
||||||
(Identifier)))+}
|
->(Identifier)}
|
||||||
{+(Export
|
{ (Identifier)
|
||||||
|
->(Identifier)})
|
||||||
|
(Other "export_specifier"
|
||||||
|
{ (Identifier)
|
||||||
|
->(Identifier)}))
|
||||||
|
(Export
|
||||||
(VarDecl
|
(VarDecl
|
||||||
(Identifier))
|
{ (Identifier)
|
||||||
|
->(Identifier)})
|
||||||
(VarDecl
|
(VarDecl
|
||||||
(Identifier))
|
{ (Identifier)
|
||||||
|
->(Identifier)})
|
||||||
(VarDecl
|
(VarDecl
|
||||||
(Identifier)))+}
|
{ (Identifier)
|
||||||
{+(Export
|
->(Identifier)}))
|
||||||
|
(Export
|
||||||
(VarAssignment
|
(VarAssignment
|
||||||
(Identifier)
|
{ (Identifier)
|
||||||
(Identifier))
|
->(Identifier)}
|
||||||
|
{ (Identifier)
|
||||||
|
->(Identifier)})
|
||||||
(VarAssignment
|
(VarAssignment
|
||||||
(Identifier)
|
{ (Identifier)
|
||||||
(Identifier))
|
->(Identifier)}
|
||||||
|
{ (Identifier)
|
||||||
|
->(Identifier)})
|
||||||
(VarDecl
|
(VarDecl
|
||||||
(Identifier))
|
{ (Identifier)
|
||||||
|
->(Identifier)})
|
||||||
(VarDecl
|
(VarDecl
|
||||||
(Identifier)))+}
|
{ (Identifier)
|
||||||
{+(Export
|
->(Identifier)}))
|
||||||
(Identifier))+}
|
(Export
|
||||||
|
{ (Identifier)
|
||||||
|
->(Identifier)})
|
||||||
{+(Export
|
{+(Export
|
||||||
(Function
|
(Function
|
||||||
(Identifier)
|
(Identifier)
|
||||||
(Params)))+}
|
(Params)))+}
|
||||||
{-(Export
|
|
||||||
(Other "export_specifier"
|
|
||||||
(Identifier)
|
|
||||||
(Identifier))
|
|
||||||
(Other "export_specifier"
|
|
||||||
(Identifier)
|
|
||||||
(Identifier))
|
|
||||||
(Other "export_specifier"
|
|
||||||
(Identifier)))-}
|
|
||||||
{-(Export
|
|
||||||
(VarDecl
|
|
||||||
(Identifier))
|
|
||||||
(VarDecl
|
|
||||||
(Identifier))
|
|
||||||
(VarDecl
|
|
||||||
(Identifier)))-}
|
|
||||||
{-(Export
|
|
||||||
(VarAssignment
|
|
||||||
(Identifier)
|
|
||||||
(Identifier))
|
|
||||||
(VarAssignment
|
|
||||||
(Identifier)
|
|
||||||
(Identifier))
|
|
||||||
(VarDecl
|
|
||||||
(Identifier))
|
|
||||||
(VarDecl
|
|
||||||
(Identifier)))-}
|
|
||||||
{-(Export
|
|
||||||
(Identifier))-}
|
|
||||||
(Export
|
(Export
|
||||||
(Function
|
(Function
|
||||||
(Params)))
|
(Params)))
|
||||||
|
17
test/fixtures/typescript/export.diffB-A.txt
vendored
17
test/fixtures/typescript/export.diffB-A.txt
vendored
@ -63,16 +63,17 @@
|
|||||||
(Export
|
(Export
|
||||||
(Function
|
(Function
|
||||||
(Params)))
|
(Params)))
|
||||||
{+(Export
|
|
||||||
(Function
|
|
||||||
(Identifier)
|
|
||||||
(Params)))+}
|
|
||||||
(Export
|
(Export
|
||||||
|
{+(Function
|
||||||
|
(Identifier)
|
||||||
|
(Params))+}
|
||||||
|
{-(Other "export_specifier"
|
||||||
|
(Identifier)
|
||||||
|
(Identifier))-})
|
||||||
|
{+(Export
|
||||||
(Other "export_specifier"
|
(Other "export_specifier"
|
||||||
{ (Identifier)
|
(Identifier)
|
||||||
->(Identifier) }
|
(Identifier)))+}
|
||||||
{ (Identifier)
|
|
||||||
->(Identifier) }))
|
|
||||||
(Export
|
(Export
|
||||||
{ (StringLiteral)
|
{ (StringLiteral)
|
||||||
->(StringLiteral) })
|
->(StringLiteral) })
|
||||||
|
Loading…
Reference in New Issue
Block a user