|
|
|
@ -12,7 +12,7 @@ namespace ICSharpCode.Decompiler.CSharp
@@ -12,7 +12,7 @@ namespace ICSharpCode.Decompiler.CSharp
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Translates from ILAst to C# expressions.
|
|
|
|
|
/// </summary>
|
|
|
|
|
class ExpressionBuilder |
|
|
|
|
class ExpressionBuilder(private readonly ICompilation compilation) |
|
|
|
|
{ |
|
|
|
|
struct ConvertedExpression(public readonly Expression Expression, public readonly IType Type) { } |
|
|
|
|
|
|
|
|
@ -22,7 +22,7 @@ namespace ICSharpCode.Decompiler.CSharp
@@ -22,7 +22,7 @@ namespace ICSharpCode.Decompiler.CSharp
|
|
|
|
|
expr.AddAnnotation(inst); |
|
|
|
|
return expr; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ConvertedExpression ConvertArgument(ILInstruction inst) |
|
|
|
|
{ |
|
|
|
|
var cexpr = TransformExpression(inst); |
|
|
|
@ -33,6 +33,14 @@ namespace ICSharpCode.Decompiler.CSharp
@@ -33,6 +33,14 @@ namespace ICSharpCode.Decompiler.CSharp
|
|
|
|
|
ConvertedExpression TransformExpression(ILInstruction inst) |
|
|
|
|
{ |
|
|
|
|
switch (inst.OpCode) { |
|
|
|
|
case OpCode.LdcI4: |
|
|
|
|
return new ConvertedExpression( |
|
|
|
|
new PrimitiveExpression(((ConstantI4)inst).Value), |
|
|
|
|
compilation.FindType(KnownTypeCode.Int32)); |
|
|
|
|
case OpCode.LogicNot: |
|
|
|
|
return new ConvertedExpression( |
|
|
|
|
new UnaryOperatorExpression(UnaryOperatorType.Not, ConvertCondition(((LogicNotInstruction)inst).Operand)), |
|
|
|
|
compilation.FindType(KnownTypeCode.Boolean)); |
|
|
|
|
default: |
|
|
|
|
return ErrorExpression("OpCode not supported: " + inst.OpCode); |
|
|
|
|
} |
|
|
|
@ -44,5 +52,16 @@ namespace ICSharpCode.Decompiler.CSharp
@@ -44,5 +52,16 @@ namespace ICSharpCode.Decompiler.CSharp
|
|
|
|
|
e.AddChild(new Comment(message, CommentType.MultiLine), Roles.Comment); |
|
|
|
|
return new ConvertedExpression(e, SpecialType.UnknownType); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
public Expression ConvertCondition(ILInstruction condition) |
|
|
|
|
{ |
|
|
|
|
var expr = ConvertArgument(condition); |
|
|
|
|
if (expr.Type.IsKnownType(KnownTypeCode.Boolean) || expr.Type.Kind == TypeKind.Unknown) |
|
|
|
|
return expr.Expression; |
|
|
|
|
else if (expr.Type.Kind == TypeKind.Pointer) |
|
|
|
|
return new BinaryOperatorExpression(expr.Expression, BinaryOperatorType.InEquality, new NullReferenceExpression()); |
|
|
|
|
else |
|
|
|
|
return new BinaryOperatorExpression(expr.Expression, BinaryOperatorType.InEquality, new PrimitiveExpression(0)); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|