~ubuntu-branches/ubuntu/trusty/monodevelop/trusty-proposed

« back to all changes in this revision

Viewing changes to contrib/NRefactory/Project/Src/Lexer/CSharp/ConditionalCompilation.cs

  • Committer: Package Import Robot
  • Author(s): Jo Shields
  • Date: 2013-05-12 09:46:03 UTC
  • mto: This revision was merged to the branch mainline in revision 29.
  • Revision ID: package-import@ubuntu.com-20130512094603-mad323bzcxvmcam0
Tags: upstream-4.0.5+dfsg
ImportĀ upstreamĀ versionĀ 4.0.5+dfsg

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
// <file>
2
 
//     <copyright see="prj:///doc/copyright.txt"/>
3
 
//     <license see="prj:///doc/license.txt"/>
4
 
//     <owner name="Daniel Grunwald"/>
5
 
//     <version>$Revision$</version>
6
 
// </file>
7
 
 
8
 
using System;
9
 
using System.Collections.Generic;
10
 
using ICSharpCode.OldNRefactory.Ast;
11
 
using ICSharpCode.OldNRefactory.Visitors;
12
 
 
13
 
namespace ICSharpCode.OldNRefactory.Parser.CSharp
14
 
{
15
 
        public sealed class ConditionalCompilation : AbstractAstVisitor
16
 
        {
17
 
                static readonly object SymbolDefined = new object();
18
 
                Dictionary<string, object> symbols = new Dictionary<string, object>();
19
 
                
20
 
                public IDictionary<string, object> Symbols { 
21
 
                        get { return symbols; }
22
 
                }
23
 
                
24
 
                public void Define(string symbol)
25
 
                {
26
 
                        symbols[symbol] = SymbolDefined;
27
 
                }
28
 
                
29
 
                public void Undefine(string symbol)
30
 
                {
31
 
                        symbols.Remove(symbol);
32
 
                }
33
 
                
34
 
                public bool Evaluate(Expression condition)
35
 
                {
36
 
                        return condition.AcceptVisitor(this, null) == SymbolDefined;
37
 
                }
38
 
                
39
 
                public override object VisitPrimitiveExpression(PrimitiveExpression primitiveExpression, object data)
40
 
                {
41
 
                        if (primitiveExpression.Value is bool)
42
 
                                return (bool)primitiveExpression.Value ? SymbolDefined : null;
43
 
                        else
44
 
                                return null;
45
 
                }
46
 
                
47
 
                public override object VisitIdentifierExpression(IdentifierExpression identifierExpression, object data)
48
 
                {
49
 
                        return symbols.ContainsKey(identifierExpression.Identifier) ? SymbolDefined : null;
50
 
                }
51
 
                
52
 
                public override object VisitUnaryOperatorExpression(UnaryOperatorExpression unaryOperatorExpression, object data)
53
 
                {
54
 
                        if (unaryOperatorExpression.Op == UnaryOperatorType.Not) {
55
 
                                return unaryOperatorExpression.Expression.AcceptVisitor(this, data) == SymbolDefined ? null : SymbolDefined;
56
 
                        } else {
57
 
                                return null;
58
 
                        }
59
 
                }
60
 
                
61
 
                public override object VisitBinaryOperatorExpression(BinaryOperatorExpression binaryOperatorExpression, object data)
62
 
                {
63
 
                        bool lhs = binaryOperatorExpression.Left.AcceptVisitor(this, data) == SymbolDefined;
64
 
                        bool rhs = binaryOperatorExpression.Right.AcceptVisitor(this, data) == SymbolDefined;
65
 
                        bool result;
66
 
                        switch (binaryOperatorExpression.Op) {
67
 
                                case BinaryOperatorType.LogicalAnd:
68
 
                                        result = lhs && rhs;
69
 
                                        break;
70
 
                                case BinaryOperatorType.LogicalOr:
71
 
                                        result = lhs || rhs;
72
 
                                        break;
73
 
                                case BinaryOperatorType.Equality:
74
 
                                        result = lhs == rhs;
75
 
                                        break;
76
 
                                case BinaryOperatorType.InEquality:
77
 
                                        result = lhs != rhs;
78
 
                                        break;
79
 
                                default:
80
 
                                        return null;
81
 
                        }
82
 
                        return result ? SymbolDefined : null;
83
 
                }
84
 
                
85
 
                public override object VisitParenthesizedExpression(ParenthesizedExpression parenthesizedExpression, object data)
86
 
                {
87
 
                        return parenthesizedExpression.Expression.AcceptVisitor(this, data);
88
 
                }
89
 
        }
90
 
}