Browse Source

Fixed definite assignment analysis bug.

pull/100/head
Daniel Grunwald 15 years ago
parent
commit
1331869851
  1. 3
      NRefactory/ICSharpCode.NRefactory/CSharp/Analysis/DefiniteAssignmentAnalysis.cs

3
NRefactory/ICSharpCode.NRefactory/CSharp/Analysis/DefiniteAssignmentAnalysis.cs

@ -559,10 +559,13 @@ namespace ICSharpCode.NRefactory.CSharp.Analysis @@ -559,10 +559,13 @@ namespace ICSharpCode.NRefactory.CSharp.Analysis
{
IdentifierExpression ident = left as IdentifierExpression;
if (ident != null && ident.Identifier == analysis.variableName) {
// right==null is special case when handling 'out' expressions
if (right != null)
right.AcceptVisitor(this, initialStatus);
return DefiniteAssignmentStatus.DefinitelyAssigned;
} else {
DefiniteAssignmentStatus status = left.AcceptVisitor(this, initialStatus);
if (right != null)
status = right.AcceptVisitor(this, CleanSpecialValues(status));
return CleanSpecialValues(status);
}

Loading…
Cancel
Save