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
{ {
IdentifierExpression ident = left as IdentifierExpression; IdentifierExpression ident = left as IdentifierExpression;
if (ident != null && ident.Identifier == analysis.variableName) { if (ident != null && ident.Identifier == analysis.variableName) {
// right==null is special case when handling 'out' expressions
if (right != null)
right.AcceptVisitor(this, initialStatus); right.AcceptVisitor(this, initialStatus);
return DefiniteAssignmentStatus.DefinitelyAssigned; return DefiniteAssignmentStatus.DefinitelyAssigned;
} else { } else {
DefiniteAssignmentStatus status = left.AcceptVisitor(this, initialStatus); DefiniteAssignmentStatus status = left.AcceptVisitor(this, initialStatus);
if (right != null)
status = right.AcceptVisitor(this, CleanSpecialValues(status)); status = right.AcceptVisitor(this, CleanSpecialValues(status));
return CleanSpecialValues(status); return CleanSpecialValues(status);
} }

Loading…
Cancel
Save