Browse Source

Fix pattern matching for ComposedType.BaseType.

newNRvisualizers
Daniel Grunwald 14 years ago
parent
commit
dac867d9ed
  1. 4
      ICSharpCode.NRefactory.CSharp/Ast/ComposedType.cs
  2. 15
      ICSharpCode.NRefactory.CSharp/Ast/GeneralScope/AttributeSection.cs
  3. 66
      ICSharpCode.NRefactory.ConsistencyCheck/PatternMatchingTest.cs
  4. 2
      ICSharpCode.NRefactory.Tests/CSharp/Parser/Expression/TypeOfExpressionTests.cs

4
ICSharpCode.NRefactory.CSharp/Ast/ComposedType.cs

@ -92,7 +92,9 @@ namespace ICSharpCode.NRefactory.CSharp @@ -92,7 +92,9 @@ namespace ICSharpCode.NRefactory.CSharp
protected internal override bool DoMatch(AstNode other, PatternMatching.Match match)
{
ComposedType o = other as ComposedType;
return o != null && this.HasNullableSpecifier == o.HasNullableSpecifier && this.PointerRank == o.PointerRank && this.ArraySpecifiers.DoMatch(o.ArraySpecifiers, match);
return o != null && this.HasNullableSpecifier == o.HasNullableSpecifier && this.PointerRank == o.PointerRank
&& this.BaseType.DoMatch(o.BaseType, match)
&& this.ArraySpecifiers.DoMatch(o.ArraySpecifiers, match);
}
public override string ToString()

15
ICSharpCode.NRefactory.CSharp/Ast/GeneralScope/AttributeSection.cs

@ -135,7 +135,7 @@ namespace ICSharpCode.NRefactory.CSharp @@ -135,7 +135,7 @@ namespace ICSharpCode.NRefactory.CSharp
protected internal override bool DoMatch(AstNode other, PatternMatching.Match match)
{
AttributeSection o = other as AttributeSection;
return o != null && this.AttributeTarget == o.AttributeTarget && this.Attributes.DoMatch(o.Attributes, match);
return o != null && MatchString(this.AttributeTarget, o.AttributeTarget) && this.Attributes.DoMatch(o.Attributes, match);
}
public AttributeSection()
@ -171,17 +171,4 @@ namespace ICSharpCode.NRefactory.CSharp @@ -171,17 +171,4 @@ namespace ICSharpCode.NRefactory.CSharp
// }
// }
}
public enum AttributeTarget {
None,
Assembly,
Module,
Type,
Param,
Field,
Return,
Method,
Unknown
}
}

66
ICSharpCode.NRefactory.ConsistencyCheck/PatternMatchingTest.cs

@ -0,0 +1,66 @@ @@ -0,0 +1,66 @@
// Copyright (c) AlphaSierraPapa for the SharpDevelop Team
//
// Permission is hereby granted, free of charge, to any person obtaining a copy of this
// software and associated documentation files (the "Software"), to deal in the Software
// without restriction, including without limitation the rights to use, copy, modify, merge,
// publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons
// to whom the Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in all copies or
// substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
// INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE
// FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
using System;
using System.Linq;
using ICSharpCode.NRefactory.CSharp;
using ICSharpCode.NRefactory.PatternMatching;
namespace ICSharpCode.NRefactory.ConsistencyCheck
{
/// <summary>
/// Validates pattern matching:
/// Every compilation must match its clone;
/// and mutations to the cloned compilation must prevent the match.
/// </summary>
/// <remarks>
/// This test is SLOW! (due to O(n^2) algorithm).
/// Expect it to take a whole hour!
/// </remarks>
public class PatternMatchingTest
{
public static void RunTest(CSharpFile file)
{
AstNode copy = file.SyntaxTree.Clone();
if (!copy.IsMatch(file.SyntaxTree))
throw new InvalidOperationException("Clone must match the compilation itself; in " + file.FileName);
// Mutate identifiers:
foreach (var id in copy.Descendants.OfType<Identifier>()) {
if (id.Parent is ConstructorDeclaration || id.Parent is DestructorDeclaration)
continue; // identifier in ctor/dtor isn't relevant for matches
string oldName = id.Name;
id.Name = "mutatedName";
if (copy.IsMatch(file.SyntaxTree))
throw new InvalidOperationException("Mutation in " + id.StartLocation + " did not prevent the match; in " + file.FileName);
id.Name = oldName;
//if (!copy.IsMatch(file.SyntaxTree))
// throw new InvalidOperationException("Clone must match the compilation itself after resetting the mutation");
}
// Mutate primitive values:
foreach (var pe in copy.Descendants.OfType<PrimitiveExpression>()) {
object oldVal = pe.Value;
pe.Value = "Mutated " + "Value";
if (copy.IsMatch(file.SyntaxTree))
throw new InvalidOperationException("Mutation in " + pe.StartLocation + " did not prevent the match; in " + file.FileName);
pe.Value = oldVal;
}
Console.Write('.');
}
}
}

2
ICSharpCode.NRefactory.Tests/CSharp/Parser/Expression/TypeOfExpressionTests.cs

@ -118,7 +118,7 @@ namespace ICSharpCode.NRefactory.CSharp.Parser.Expression @@ -118,7 +118,7 @@ namespace ICSharpCode.NRefactory.CSharp.Parser.Expression
"typeof(MyStruct?)",
new TypeOfExpression {
Type = new ComposedType {
BaseType = new SimpleType("MyType"),
BaseType = new SimpleType("MyStruct"),
HasNullableSpecifier = true
}});
}

Loading…
Cancel
Save