#develop (short for SharpDevelop) is a free IDE for .NET programming languages.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

3023 lines
96 KiB

// Copyright (c) AlphaSierraPapa for the SharpDevelop Team (for details please see \doc\copyright.txt)
// This code is distributed under the GNU LGPL (for details please see \doc\license.txt)
using System;
using System.Linq;
using System.Collections;
using System.Collections.Generic;
using System.Diagnostics;
using System.Globalization;
using System.Text;
using ICSharpCode.NRefactory.VB.Dom;
using ICSharpCode.NRefactory.VB.Parser;
using ICSharpCode.NRefactory.VB.Visitors;
namespace ICSharpCode.NRefactory.VB.PrettyPrinter
{
public sealed class VBNetOutputVisitor : NodeTrackingAstVisitor, IOutputAstVisitor
{
Errors errors = new Errors();
VBNetOutputFormatter outputFormatter;
VBNetPrettyPrintOptions prettyPrintOptions = new VBNetPrettyPrintOptions();
TypeDeclaration currentType;
Stack<int> exitTokenStack = new Stack<int>();
public string Text {
get {
return outputFormatter.Text;
}
}
public Errors Errors {
get {
return errors;
}
}
AbstractPrettyPrintOptions IOutputAstVisitor.Options {
get { return prettyPrintOptions; }
}
public VBNetPrettyPrintOptions Options {
get { return prettyPrintOptions; }
}
public IOutputFormatter OutputFormatter {
get {
return outputFormatter;
}
}
public VBNetOutputVisitor()
{
outputFormatter = new VBNetOutputFormatter(prettyPrintOptions);
}
public event Action<INode> BeforeNodeVisit;
public event Action<INode> AfterNodeVisit;
protected override void BeginVisit(INode node)
{
if (BeforeNodeVisit != null) {
BeforeNodeVisit(node);
}
base.BeginVisit(node);
}
protected override void EndVisit(INode node)
{
base.EndVisit(node);
if (AfterNodeVisit != null) {
AfterNodeVisit(node);
}
}
object TrackedVisit(INode node, object data)
{
return node.AcceptVisitor(this, data);
}
void Error(string text, Location position)
{
errors.Error(position.Line, position.Column, text);
}
void UnsupportedNode(INode node)
{
Error(node.GetType().Name + " is unsupported", node.StartLocation);
}
#region ICSharpCode.NRefactory.Parser.IASTVisitor interface implementation
public override object TrackedVisitCompilationUnit(CompilationUnit compilationUnit, object data)
{
compilationUnit.AcceptChildren(this, data);
outputFormatter.EndFile();
return null;
}
/// <summary>
/// Converts type name to primitive type name. Returns typeString if typeString is not
/// a primitive type.
/// </summary>
static string ConvertTypeString(string typeString)
{
string primitiveType;
if (TypeReference.PrimitiveTypesVBReverse.TryGetValue(typeString, out primitiveType))
return primitiveType;
else
return typeString;
}
public override object TrackedVisitTypeReference(TypeReference typeReference, object data)
{
if (typeReference == TypeReference.ClassConstraint) {
outputFormatter.PrintToken(Tokens.Class);
} else if (typeReference == TypeReference.StructConstraint) {
outputFormatter.PrintToken(Tokens.Structure);
} else if (typeReference == TypeReference.NewConstraint) {
outputFormatter.PrintToken(Tokens.New);
} else {
PrintTypeReferenceWithoutArray(typeReference);
if (typeReference.IsArrayType) {
PrintArrayRank(typeReference.RankSpecifier, 0);
}
}
return null;
}
void PrintTypeReferenceWithoutArray(TypeReference typeReference)
{
if (typeReference.IsGlobal) {
outputFormatter.PrintToken(Tokens.Global);
outputFormatter.PrintToken(Tokens.Dot);
}
bool printGenerics = true;
if (typeReference.IsKeyword) {
outputFormatter.PrintText(ConvertTypeString(typeReference.Type));
} else {
outputFormatter.PrintIdentifier(typeReference.Type);
}
if (printGenerics && typeReference.GenericTypes != null && typeReference.GenericTypes.Count > 0) {
outputFormatter.PrintToken(Tokens.OpenParenthesis);
outputFormatter.PrintToken(Tokens.Of);
outputFormatter.Space();
AppendCommaSeparatedList(typeReference.GenericTypes);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
}
for (int i = 0; i < typeReference.PointerNestingLevel; ++i) {
outputFormatter.PrintToken(Tokens.Times);
}
}
void PrintArrayRank(int[] rankSpecifier, int startRank)
{
for (int i = startRank; i < rankSpecifier.Length; ++i) {
outputFormatter.PrintToken(Tokens.OpenParenthesis);
for (int j = 0; j < rankSpecifier[i]; ++j) {
outputFormatter.PrintToken(Tokens.Comma);
}
outputFormatter.PrintToken(Tokens.CloseParenthesis);
}
}
public override object TrackedVisitInnerClassTypeReference(InnerClassTypeReference innerClassTypeReference, object data)
{
TrackedVisit(innerClassTypeReference.BaseType, data);
outputFormatter.PrintToken(Tokens.Dot);
return VisitTypeReference((TypeReference)innerClassTypeReference, data);
}
#region Global scope
bool printAttributeSectionInline; // is set to true when printing parameter's attributes
public override object TrackedVisitAttributeSection(AttributeSection attributeSection, object data)
{
if (!printAttributeSectionInline)
outputFormatter.Indent();
outputFormatter.PrintText("<");
if (!string.IsNullOrEmpty(attributeSection.AttributeTarget) && !string.Equals(attributeSection.AttributeTarget, "return", StringComparison.OrdinalIgnoreCase)) {
outputFormatter.PrintText(char.ToUpperInvariant(attributeSection.AttributeTarget[0]) + attributeSection.AttributeTarget.Substring(1));
outputFormatter.PrintToken(Tokens.Colon);
outputFormatter.Space();
}
Debug.Assert(attributeSection.Attributes != null);
AppendCommaSeparatedList(attributeSection.Attributes);
outputFormatter.PrintText(">");
if ("assembly".Equals(attributeSection.AttributeTarget, StringComparison.InvariantCultureIgnoreCase)
|| "module".Equals(attributeSection.AttributeTarget, StringComparison.InvariantCultureIgnoreCase)) {
outputFormatter.NewLine();
} else {
if (printAttributeSectionInline)
outputFormatter.Space();
else
outputFormatter.PrintLineContinuation();
}
return null;
}
public override object TrackedVisitAttribute(ICSharpCode.NRefactory.VB.Dom.Attribute attribute, object data)
{
outputFormatter.PrintIdentifier(attribute.Name);
if (attribute.PositionalArguments.Count > 0 || attribute.NamedArguments.Count > 0) {
outputFormatter.PrintToken(Tokens.OpenParenthesis);
AppendCommaSeparatedList(attribute.PositionalArguments);
if (attribute.NamedArguments.Count > 0) {
if (attribute.PositionalArguments.Count > 0) {
outputFormatter.PrintToken(Tokens.Comma);
outputFormatter.Space();
}
AppendCommaSeparatedList(attribute.NamedArguments);
}
outputFormatter.PrintToken(Tokens.CloseParenthesis);
}
return null;
}
public override object TrackedVisitNamedArgumentExpression(NamedArgumentExpression namedArgumentExpression, object data)
{
outputFormatter.PrintIdentifier(namedArgumentExpression.Name);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Colon);
outputFormatter.PrintToken(Tokens.Assign);
outputFormatter.Space();
TrackedVisit(namedArgumentExpression.Expression, data);
return null;
}
public override object TrackedVisitUsing(Using @using, object data)
{
Debug.Fail("Should never be called. The usings should be handled in Visit(UsingDeclaration)");
return null;
}
public override object TrackedVisitUsingDeclaration(UsingDeclaration usingDeclaration, object data)
{
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.Imports);
outputFormatter.Space();
for (int i = 0; i < usingDeclaration.Usings.Count; ++i) {
outputFormatter.PrintIdentifier(((Using)usingDeclaration.Usings[i]).Name);
if (((Using)usingDeclaration.Usings[i]).IsAlias) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Assign);
outputFormatter.Space();
TrackedVisit(((Using)usingDeclaration.Usings[i]).Alias, data);
}
if (i + 1 < usingDeclaration.Usings.Count) {
outputFormatter.PrintToken(Tokens.Comma);
outputFormatter.Space();
}
}
outputFormatter.NewLine();
return null;
}
public override object TrackedVisitNamespaceDeclaration(NamespaceDeclaration namespaceDeclaration, object data)
{
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.Namespace);
outputFormatter.Space();
outputFormatter.PrintIdentifier(namespaceDeclaration.Name);
outputFormatter.NewLine();
++outputFormatter.IndentationLevel;
namespaceDeclaration.AcceptChildren(this, data);
--outputFormatter.IndentationLevel;
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Namespace);
outputFormatter.NewLine();
return null;
}
static int GetTypeToken(TypeDeclaration typeDeclaration)
{
switch (typeDeclaration.Type) {
case ClassType.Class:
return Tokens.Class;
case ClassType.Enum:
return Tokens.Enum;
case ClassType.Interface:
return Tokens.Interface;
case ClassType.Struct:
return Tokens.Structure;
case ClassType.Module:
return Tokens.Module;
default:
return Tokens.Class;
}
}
void PrintTemplates(List<TemplateDefinition> templates)
{
if (templates != null && templates.Count > 0) {
outputFormatter.PrintToken(Tokens.OpenParenthesis);
outputFormatter.PrintToken(Tokens.Of);
outputFormatter.Space();
AppendCommaSeparatedList(templates);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
}
}
public override object TrackedVisitTypeDeclaration(TypeDeclaration typeDeclaration, object data)
{
VisitAttributes(typeDeclaration.Attributes, data);
outputFormatter.Indent();
OutputModifier(typeDeclaration.Modifier, true, false);
int typeToken = GetTypeToken(typeDeclaration);
outputFormatter.PrintToken(typeToken);
outputFormatter.Space();
outputFormatter.PrintIdentifier(typeDeclaration.Name);
PrintTemplates(typeDeclaration.Templates);
if (typeDeclaration.Type == ClassType.Enum
&& typeDeclaration.BaseTypes != null && typeDeclaration.BaseTypes.Count > 0)
{
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.As);
outputFormatter.Space();
foreach (TypeReference baseTypeRef in typeDeclaration.BaseTypes) {
TrackedVisit(baseTypeRef, data);
}
}
outputFormatter.NewLine();
++outputFormatter.IndentationLevel;
if (typeDeclaration.BaseTypes != null && typeDeclaration.Type != ClassType.Enum) {
foreach (TypeReference baseTypeRef in typeDeclaration.BaseTypes) {
outputFormatter.Indent();
string baseType = baseTypeRef.Type;
if (baseType.IndexOf('.') >= 0) {
baseType = baseType.Substring(baseType.LastIndexOf('.') + 1);
}
bool baseTypeIsInterface = baseType.Length >= 2 && baseType[0] == 'I' && Char.IsUpper(baseType[1]);
if (!baseTypeIsInterface || typeDeclaration.Type == ClassType.Interface) {
outputFormatter.PrintToken(Tokens.Inherits);
} else {
outputFormatter.PrintToken(Tokens.Implements);
}
outputFormatter.Space();
TrackedVisit(baseTypeRef, data);
outputFormatter.NewLine();
}
}
TypeDeclaration oldType = currentType;
currentType = typeDeclaration;
if (typeDeclaration.Type == ClassType.Enum) {
OutputEnumMembers(typeDeclaration, data);
} else {
typeDeclaration.AcceptChildren(this, data);
}
currentType = oldType;
--outputFormatter.IndentationLevel;
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintToken(typeToken);
outputFormatter.NewLine();
return null;
}
void OutputEnumMembers(TypeDeclaration typeDeclaration, object data)
{
foreach (FieldDeclaration fieldDeclaration in typeDeclaration.Children) {
BeginVisit(fieldDeclaration);
VariableDeclaration f = (VariableDeclaration)fieldDeclaration.Fields[0];
VisitAttributes(fieldDeclaration.Attributes, data);
outputFormatter.Indent();
outputFormatter.PrintIdentifier(f.Name);
if (f.Initializer != null && !f.Initializer.IsNull) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Assign);
outputFormatter.Space();
TrackedVisit(f.Initializer, data);
}
outputFormatter.NewLine();
EndVisit(fieldDeclaration);
}
}
public override object TrackedVisitTemplateDefinition(TemplateDefinition templateDefinition, object data)
{
VisitAttributes(templateDefinition.Attributes, data);
switch (templateDefinition.VarianceModifier) {
case VarianceModifier.Invariant:
// nothing
break;
case VarianceModifier.Covariant:
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Out);
outputFormatter.Space();
break;
case VarianceModifier.Contravariant:
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.In);
outputFormatter.Space();
break;
default:
throw new Exception("Invalid value for VarianceModifier");
}
outputFormatter.PrintIdentifier(templateDefinition.Name);
if (templateDefinition.Bases.Count > 0) {
outputFormatter.PrintText(" As ");
VisitReturnTypeAttributes(templateDefinition.Attributes, data);
if (templateDefinition.Bases.Count == 1) {
TrackedVisit(templateDefinition.Bases[0], data);
} else {
outputFormatter.PrintToken(Tokens.OpenCurlyBrace);
AppendCommaSeparatedList(templateDefinition.Bases);
outputFormatter.PrintToken(Tokens.CloseCurlyBrace);
}
}
return null;
}
public override object TrackedVisitDelegateDeclaration(DelegateDeclaration delegateDeclaration, object data)
{
VisitAttributes(delegateDeclaration.Attributes, data);
outputFormatter.Indent();
OutputModifier(delegateDeclaration.Modifier, true, false);
outputFormatter.PrintToken(Tokens.Delegate);
outputFormatter.Space();
bool isFunction = (delegateDeclaration.ReturnType.Type != "System.Void");
if (isFunction) {
outputFormatter.PrintToken(Tokens.Function);
outputFormatter.Space();
} else {
outputFormatter.PrintToken(Tokens.Sub);
outputFormatter.Space();
}
outputFormatter.PrintIdentifier(delegateDeclaration.Name);
PrintTemplates(delegateDeclaration.Templates);
outputFormatter.PrintToken(Tokens.OpenParenthesis);
AppendCommaSeparatedList(delegateDeclaration.Parameters);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
if (isFunction) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.As);
outputFormatter.Space();
VisitReturnTypeAttributes(delegateDeclaration.Attributes, data);
TrackedVisit(delegateDeclaration.ReturnType, data);
}
outputFormatter.NewLine();
return null;
}
public override object TrackedVisitOptionDeclaration(OptionDeclaration optionDeclaration, object data)
{
outputFormatter.PrintToken(Tokens.Option);
outputFormatter.Space();
switch (optionDeclaration.OptionType) {
case OptionType.Strict:
outputFormatter.PrintToken(Tokens.Strict);
outputFormatter.Space();
outputFormatter.PrintToken(optionDeclaration.OptionValue ? Tokens.On : Tokens.Off);
break;
case OptionType.Explicit:
outputFormatter.PrintToken(Tokens.Explicit);
outputFormatter.Space();
outputFormatter.PrintToken(optionDeclaration.OptionValue ? Tokens.On : Tokens.Off);
break;
case OptionType.Infer:
outputFormatter.PrintToken(Tokens.Infer);
outputFormatter.Space();
outputFormatter.PrintToken(optionDeclaration.OptionValue ? Tokens.On : Tokens.Off);
break;
case OptionType.CompareBinary:
outputFormatter.PrintToken(Tokens.Compare);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Binary);
break;
case OptionType.CompareText:
outputFormatter.PrintToken(Tokens.Compare);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Text);
break;
}
outputFormatter.NewLine();
return null;
}
#endregion
#region Type level
TypeReference currentVariableType;
public override object TrackedVisitFieldDeclaration(FieldDeclaration fieldDeclaration, object data)
{
VisitAttributes(fieldDeclaration.Attributes, data);
outputFormatter.Indent();
if (fieldDeclaration.Modifier == Modifiers.None) {
outputFormatter.PrintToken(Tokens.Private);
outputFormatter.Space();
} else {
OutputModifier(fieldDeclaration.Modifier, false, true);
}
currentVariableType = fieldDeclaration.TypeReference;
AppendCommaSeparatedList(fieldDeclaration.Fields);
currentVariableType = null;
outputFormatter.NewLine();
return null;
}
public override object TrackedVisitVariableDeclaration(VariableDeclaration variableDeclaration, object data)
{
outputFormatter.PrintIdentifier(variableDeclaration.Name);
TypeReference varType = currentVariableType;
if (varType != null && varType.IsNull)
varType = null;
if (varType == null && !variableDeclaration.TypeReference.IsNull)
varType = variableDeclaration.TypeReference;
if (varType != null) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.As);
outputFormatter.Space();
ObjectCreateExpression init = variableDeclaration.Initializer as ObjectCreateExpression;
if (init != null && TypeReference.AreEqualReferences(init.CreateType, varType)) {
TrackedVisit(variableDeclaration.Initializer, data);
return null;
} else {
TrackedVisit(varType, data);
}
}
if (!variableDeclaration.Initializer.IsNull) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Assign);
outputFormatter.Space();
TrackedVisit(variableDeclaration.Initializer, data);
}
return null;
}
public override object TrackedVisitPropertyDeclaration(PropertyDeclaration propertyDeclaration, object data)
{
VisitAttributes(propertyDeclaration.Attributes, data);
outputFormatter.Indent();
OutputModifier(propertyDeclaration.Modifier);
if ((propertyDeclaration.Modifier & (Modifiers.ReadOnly | Modifiers.WriteOnly)) == Modifiers.None) {
if (propertyDeclaration.IsReadOnly) {
outputFormatter.PrintToken(Tokens.ReadOnly);
outputFormatter.Space();
} else if (propertyDeclaration.IsWriteOnly) {
outputFormatter.PrintToken(Tokens.WriteOnly);
outputFormatter.Space();
}
}
outputFormatter.PrintToken(Tokens.Property);
outputFormatter.Space();
outputFormatter.PrintIdentifier(propertyDeclaration.Name);
outputFormatter.PrintToken(Tokens.OpenParenthesis);
AppendCommaSeparatedList(propertyDeclaration.Parameters);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
if (!propertyDeclaration.TypeReference.IsNull) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.As);
outputFormatter.Space();
VisitReturnTypeAttributes(propertyDeclaration.Attributes, data);
ObjectCreateExpression init = propertyDeclaration.Initializer as ObjectCreateExpression;
if (init != null && TypeReference.AreEqualReferences(init.CreateType, propertyDeclaration.TypeReference)) {
TrackedVisit(propertyDeclaration.Initializer, data);
} else {
TrackedVisit(propertyDeclaration.TypeReference, data);
}
}
PrintInterfaceImplementations(propertyDeclaration.InterfaceImplementations);
if (!propertyDeclaration.Initializer.IsNull && !(propertyDeclaration.Initializer is ObjectCreateExpression)) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Assign);
outputFormatter.Space();
TrackedVisit(propertyDeclaration.Initializer, data);
}
outputFormatter.NewLine();
if (!IsAbstract(propertyDeclaration) && (propertyDeclaration.GetRegion.Block != NullBlockStatement.Instance || propertyDeclaration.SetRegion.Block != NullBlockStatement.Instance)) {
outputFormatter.IsInMemberBody = true;
++outputFormatter.IndentationLevel;
exitTokenStack.Push(Tokens.Property);
TrackedVisit(propertyDeclaration.GetRegion, data);
TrackedVisit(propertyDeclaration.SetRegion, data);
exitTokenStack.Pop();
--outputFormatter.IndentationLevel;
outputFormatter.IsInMemberBody = false;
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Property);
outputFormatter.NewLine();
}
return null;
}
public override object TrackedVisitPropertyGetRegion(PropertyGetRegion propertyGetRegion, object data)
{
VisitAttributes(propertyGetRegion.Attributes, data);
outputFormatter.Indent();
OutputModifier(propertyGetRegion.Modifier);
outputFormatter.PrintToken(Tokens.Get);
outputFormatter.NewLine();
++outputFormatter.IndentationLevel;
TrackedVisit(propertyGetRegion.Block, data);
--outputFormatter.IndentationLevel;
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Get);
outputFormatter.NewLine();
return null;
}
public override object TrackedVisitPropertySetRegion(PropertySetRegion propertySetRegion, object data)
{
VisitAttributes(propertySetRegion.Attributes, data);
outputFormatter.Indent();
OutputModifier(propertySetRegion.Modifier);
outputFormatter.PrintToken(Tokens.Set);
outputFormatter.NewLine();
++outputFormatter.IndentationLevel;
TrackedVisit(propertySetRegion.Block, data);
--outputFormatter.IndentationLevel;
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Set);
outputFormatter.NewLine();
return null;
}
TypeReference currentEventType = null;
public override object TrackedVisitEventDeclaration(EventDeclaration eventDeclaration, object data)
{
bool customEvent = eventDeclaration.HasAddRegion || eventDeclaration.HasRemoveRegion;
VisitAttributes(eventDeclaration.Attributes, data);
outputFormatter.Indent();
OutputModifier(eventDeclaration.Modifier);
if (customEvent) {
outputFormatter.PrintText("Custom");
outputFormatter.Space();
}
outputFormatter.PrintToken(Tokens.Event);
outputFormatter.Space();
outputFormatter.PrintIdentifier(eventDeclaration.Name);
if (eventDeclaration.Parameters.Count > 0) {
outputFormatter.PrintToken(Tokens.OpenParenthesis);
this.AppendCommaSeparatedList(eventDeclaration.Parameters);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
}
if (!eventDeclaration.TypeReference.IsNull) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.As);
outputFormatter.Space();
VisitReturnTypeAttributes(eventDeclaration.Attributes, data);
TrackedVisit(eventDeclaration.TypeReference, data);
}
PrintInterfaceImplementations(eventDeclaration.InterfaceImplementations);
if (!eventDeclaration.Initializer.IsNull) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Assign);
outputFormatter.Space();
TrackedVisit(eventDeclaration.Initializer, data);
}
outputFormatter.NewLine();
if (customEvent) {
++outputFormatter.IndentationLevel;
currentEventType = eventDeclaration.TypeReference;
exitTokenStack.Push(Tokens.Sub);
TrackedVisit(eventDeclaration.AddRegion, data);
TrackedVisit(eventDeclaration.RemoveRegion, data);
exitTokenStack.Pop();
--outputFormatter.IndentationLevel;
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Event);
outputFormatter.NewLine();
}
return null;
}
void PrintInterfaceImplementations(IList<InterfaceImplementation> list)
{
if (list == null || list.Count == 0)
return;
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Implements);
for (int i = 0; i < list.Count; i++) {
if (i > 0)
outputFormatter.PrintToken(Tokens.Comma);
outputFormatter.Space();
TrackedVisit(list[i].InterfaceType, null);
outputFormatter.PrintToken(Tokens.Dot);
outputFormatter.PrintIdentifier(list[i].MemberName);
}
}
public override object TrackedVisitEventAddRegion(EventAddRegion eventAddRegion, object data)
{
VisitAttributes(eventAddRegion.Attributes, data);
outputFormatter.Indent();
outputFormatter.PrintText("AddHandler(");
if (eventAddRegion.Parameters.Count == 0) {
outputFormatter.PrintToken(Tokens.ByVal);
outputFormatter.Space();
outputFormatter.PrintIdentifier("value");
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.As);
outputFormatter.Space();
TrackedVisit(currentEventType, data);
} else {
this.AppendCommaSeparatedList(eventAddRegion.Parameters);
}
outputFormatter.PrintToken(Tokens.CloseParenthesis);
outputFormatter.NewLine();
++outputFormatter.IndentationLevel;
TrackedVisit(eventAddRegion.Block, data);
--outputFormatter.IndentationLevel;
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintText("AddHandler");
outputFormatter.NewLine();
return null;
}
public override object TrackedVisitEventRemoveRegion(EventRemoveRegion eventRemoveRegion, object data)
{
VisitAttributes(eventRemoveRegion.Attributes, data);
outputFormatter.Indent();
outputFormatter.PrintText("RemoveHandler");
outputFormatter.PrintToken(Tokens.OpenParenthesis);
if (eventRemoveRegion.Parameters.Count == 0) {
outputFormatter.PrintToken(Tokens.ByVal);
outputFormatter.Space();
outputFormatter.PrintIdentifier("value");
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.As);
outputFormatter.Space();
TrackedVisit(currentEventType, data);
} else {
this.AppendCommaSeparatedList(eventRemoveRegion.Parameters);
}
outputFormatter.PrintToken(Tokens.CloseParenthesis);
outputFormatter.NewLine();
++outputFormatter.IndentationLevel;
TrackedVisit(eventRemoveRegion.Block, data);
--outputFormatter.IndentationLevel;
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintText("RemoveHandler");
outputFormatter.NewLine();
return null;
}
public override object TrackedVisitEventRaiseRegion(EventRaiseRegion eventRaiseRegion, object data)
{
VisitAttributes(eventRaiseRegion.Attributes, data);
outputFormatter.Indent();
outputFormatter.PrintText("RaiseEvent");
outputFormatter.PrintToken(Tokens.OpenParenthesis);
if (eventRaiseRegion.Parameters.Count == 0) {
outputFormatter.PrintToken(Tokens.ByVal);
outputFormatter.Space();
outputFormatter.PrintIdentifier("value");
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.As);
outputFormatter.Space();
TrackedVisit(currentEventType, data);
} else {
this.AppendCommaSeparatedList(eventRaiseRegion.Parameters);
}
outputFormatter.PrintToken(Tokens.CloseParenthesis);
outputFormatter.NewLine();
++outputFormatter.IndentationLevel;
TrackedVisit(eventRaiseRegion.Block, data);
--outputFormatter.IndentationLevel;
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintText("RaiseEvent");
outputFormatter.NewLine();
return null;
}
public override object TrackedVisitParameterDeclarationExpression(ParameterDeclarationExpression parameterDeclarationExpression, object data)
{
printAttributeSectionInline = true;
VisitAttributes(parameterDeclarationExpression.Attributes, data);
printAttributeSectionInline = false;
OutputModifier(parameterDeclarationExpression.ParamModifier);
outputFormatter.PrintIdentifier(parameterDeclarationExpression.ParameterName);
if (!parameterDeclarationExpression.TypeReference.IsNull) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.As);
outputFormatter.Space();
VisitReturnTypeAttributes(parameterDeclarationExpression.Attributes, data);
TrackedVisit(parameterDeclarationExpression.TypeReference, data);
}
if (!parameterDeclarationExpression.DefaultValue.IsNull) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Assign);
outputFormatter.Space();
TrackedVisit(parameterDeclarationExpression.DefaultValue, data);
}
return null;
}
public override object TrackedVisitMethodDeclaration(MethodDeclaration methodDeclaration, object data)
{
VisitAttributes(methodDeclaration.Attributes, data);
if (methodDeclaration.IsExtensionMethod) {
outputFormatter.Indent();
outputFormatter.PrintText("<System.Runtime.CompilerServices.Extension> _");
outputFormatter.NewLine();
}
outputFormatter.Indent();
OutputModifier(methodDeclaration.Modifier);
bool isSub = methodDeclaration.TypeReference.IsNull ||
methodDeclaration.TypeReference.Type == "System.Void";
if (isSub) {
outputFormatter.PrintToken(Tokens.Sub);
} else {
outputFormatter.PrintToken(Tokens.Function);
}
outputFormatter.Space();
outputFormatter.PrintIdentifier(methodDeclaration.Name);
PrintTemplates(methodDeclaration.Templates);
outputFormatter.PrintToken(Tokens.OpenParenthesis);
AppendCommaSeparatedList(methodDeclaration.Parameters);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
if (!isSub) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.As);
outputFormatter.Space();
VisitReturnTypeAttributes(methodDeclaration.Attributes, data);
TrackedVisit(methodDeclaration.TypeReference, data);
}
PrintInterfaceImplementations(methodDeclaration.InterfaceImplementations);
if (methodDeclaration.HandlesClause.Count > 0) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Handles);
for (int i = 0; i < methodDeclaration.HandlesClause.Count; i++) {
if (i > 0)
outputFormatter.PrintToken(Tokens.Comma);
outputFormatter.Space();
outputFormatter.PrintText(methodDeclaration.HandlesClause[i]);
}
}
outputFormatter.NewLine();
if (!IsAbstract(methodDeclaration)) {
outputFormatter.IsInMemberBody = true;
BeginVisit(methodDeclaration.Body);
++outputFormatter.IndentationLevel;
exitTokenStack.Push(isSub ? Tokens.Sub : Tokens.Function);
// we're doing the tracking manually using BeginVisit/EndVisit, so call Tracked... directly
this.TrackedVisitBlockStatement(methodDeclaration.Body, data);
exitTokenStack.Pop();
--outputFormatter.IndentationLevel;
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
if (isSub) {
outputFormatter.PrintToken(Tokens.Sub);
} else {
outputFormatter.PrintToken(Tokens.Function);
}
outputFormatter.NewLine();
EndVisit(methodDeclaration.Body);
outputFormatter.IsInMemberBody = false;
}
return null;
}
public override object TrackedVisitInterfaceImplementation(InterfaceImplementation interfaceImplementation, object data)
{
throw new InvalidOperationException();
}
bool IsAbstract(AttributedNode node)
{
if ((node.Modifier & Modifiers.Abstract) == Modifiers.Abstract)
return true;
return currentType != null && currentType.Type == ClassType.Interface;
}
public override object TrackedVisitConstructorDeclaration(ConstructorDeclaration constructorDeclaration, object data)
{
VisitAttributes(constructorDeclaration.Attributes, data);
outputFormatter.Indent();
OutputModifier(constructorDeclaration.Modifier);
outputFormatter.PrintToken(Tokens.Sub);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.New);
outputFormatter.PrintToken(Tokens.OpenParenthesis);
AppendCommaSeparatedList(constructorDeclaration.Parameters);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
outputFormatter.NewLine();
outputFormatter.IsInMemberBody = true;
++outputFormatter.IndentationLevel;
exitTokenStack.Push(Tokens.Sub);
TrackedVisit(constructorDeclaration.ConstructorInitializer, data);
TrackedVisit(constructorDeclaration.Body, data);
exitTokenStack.Pop();
--outputFormatter.IndentationLevel;
outputFormatter.IsInMemberBody = false;
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Sub);
outputFormatter.NewLine();
return null;
}
public override object TrackedVisitConstructorInitializer(ConstructorInitializer constructorInitializer, object data)
{
outputFormatter.Indent();
if (constructorInitializer.ConstructorInitializerType == ConstructorInitializerType.This) {
outputFormatter.PrintToken(Tokens.Me);
} else {
outputFormatter.PrintToken(Tokens.MyBase);
}
outputFormatter.PrintToken(Tokens.Dot);
outputFormatter.PrintToken(Tokens.New);
outputFormatter.PrintToken(Tokens.OpenParenthesis);
AppendCommaSeparatedList(constructorInitializer.Arguments);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
outputFormatter.NewLine();
return null;
}
public override object TrackedVisitOperatorDeclaration(OperatorDeclaration operatorDeclaration, object data)
{
VisitAttributes(operatorDeclaration.Attributes, data);
outputFormatter.Indent();
OutputModifier(operatorDeclaration.Modifier);
if (operatorDeclaration.IsConversionOperator) {
if (operatorDeclaration.ConversionType == ConversionType.Implicit) {
outputFormatter.PrintToken(Tokens.Widening);
} else {
outputFormatter.PrintToken(Tokens.Narrowing);
}
outputFormatter.Space();
}
outputFormatter.PrintToken(Tokens.Operator);
outputFormatter.Space();
int op = -1;
switch(operatorDeclaration.OverloadableOperator)
{
case OverloadableOperatorType.Add:
case OverloadableOperatorType.UnaryPlus:
op = Tokens.Plus;
break;
case OverloadableOperatorType.UnaryMinus:
case OverloadableOperatorType.Subtract:
op = Tokens.Minus;
break;
case OverloadableOperatorType.Multiply:
op = Tokens.Times;
break;
case OverloadableOperatorType.Divide:
op = Tokens.Div;
break;
case OverloadableOperatorType.Modulus:
op = Tokens.Mod;
break;
case OverloadableOperatorType.Concat:
op = Tokens.ConcatString;
break;
case OverloadableOperatorType.Not:
op = Tokens.Not;
break;
case OverloadableOperatorType.BitNot:
op = Tokens.Not;
break;
case OverloadableOperatorType.BitwiseAnd:
op = Tokens.And;
break;
case OverloadableOperatorType.BitwiseOr:
op = Tokens.Or;
break;
case OverloadableOperatorType.ExclusiveOr:
op = Tokens.Xor;
break;
case OverloadableOperatorType.ShiftLeft:
op = Tokens.ShiftLeft;
break;
case OverloadableOperatorType.ShiftRight:
op = Tokens.ShiftRight;
break;
case OverloadableOperatorType.GreaterThan:
op = Tokens.GreaterThan;
break;
case OverloadableOperatorType.GreaterThanOrEqual:
op = Tokens.GreaterEqual;
break;
case OverloadableOperatorType.Equality:
op = Tokens.Assign;
break;
case OverloadableOperatorType.InEquality:
op = Tokens.NotEqual;
break;
case OverloadableOperatorType.LessThan:
op = Tokens.LessThan;
break;
case OverloadableOperatorType.LessThanOrEqual:
op = Tokens.LessEqual;
break;
case OverloadableOperatorType.Increment:
Error("Increment operator is not supported in Visual Basic", operatorDeclaration.StartLocation);
break;
case OverloadableOperatorType.Decrement:
Error("Decrement operator is not supported in Visual Basic", operatorDeclaration.StartLocation);
break;
case OverloadableOperatorType.IsTrue:
outputFormatter.PrintText("IsTrue");
break;
case OverloadableOperatorType.IsFalse:
outputFormatter.PrintText("IsFalse");
break;
case OverloadableOperatorType.Like:
op = Tokens.Like;
break;
case OverloadableOperatorType.Power:
op = Tokens.Power;
break;
case OverloadableOperatorType.CType:
op = Tokens.CType;
break;
case OverloadableOperatorType.DivideInteger:
op = Tokens.DivInteger;
break;
}
if (operatorDeclaration.IsConversionOperator) {
outputFormatter.PrintToken(Tokens.CType);
} else {
if(op != -1) outputFormatter.PrintToken(op);
}
PrintTemplates(operatorDeclaration.Templates);
outputFormatter.PrintToken(Tokens.OpenParenthesis);
AppendCommaSeparatedList(operatorDeclaration.Parameters);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
if (!operatorDeclaration.TypeReference.IsNull) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.As);
outputFormatter.Space();
VisitReturnTypeAttributes(operatorDeclaration.Attributes, data);
TrackedVisit(operatorDeclaration.TypeReference, data);
}
outputFormatter.NewLine();
++outputFormatter.IndentationLevel;
TrackedVisit(operatorDeclaration.Body, data);
--outputFormatter.IndentationLevel;
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Operator);
outputFormatter.NewLine();
return null;
}
public override object TrackedVisitDeclareDeclaration(DeclareDeclaration declareDeclaration, object data)
{
VisitAttributes(declareDeclaration.Attributes, data);
outputFormatter.Indent();
OutputModifier(declareDeclaration.Modifier);
outputFormatter.PrintToken(Tokens.Declare);
outputFormatter.Space();
switch (declareDeclaration.Charset) {
case CharsetModifier.Auto:
outputFormatter.PrintToken(Tokens.Auto);
outputFormatter.Space();
break;
case CharsetModifier.Unicode:
outputFormatter.PrintToken(Tokens.Unicode);
outputFormatter.Space();
break;
case CharsetModifier.Ansi:
outputFormatter.PrintToken(Tokens.Ansi);
outputFormatter.Space();
break;
}
bool isVoid = declareDeclaration.TypeReference.IsNull || declareDeclaration.TypeReference.Type == "System.Void";
if (isVoid) {
outputFormatter.PrintToken(Tokens.Sub);
} else {
outputFormatter.PrintToken(Tokens.Function);
}
outputFormatter.Space();
outputFormatter.PrintIdentifier(declareDeclaration.Name);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Lib);
outputFormatter.Space();
outputFormatter.PrintText(ConvertString(declareDeclaration.Library));
outputFormatter.Space();
if (declareDeclaration.Alias.Length > 0) {
outputFormatter.PrintToken(Tokens.Alias);
outputFormatter.Space();
outputFormatter.PrintText(ConvertString(declareDeclaration.Alias));
outputFormatter.Space();
}
outputFormatter.PrintToken(Tokens.OpenParenthesis);
AppendCommaSeparatedList(declareDeclaration.Parameters);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
if (!isVoid) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.As);
outputFormatter.Space();
VisitReturnTypeAttributes(declareDeclaration.Attributes, data);
TrackedVisit(declareDeclaration.TypeReference, data);
}
outputFormatter.NewLine();
return null;
}
#endregion
#region Statements
public override object TrackedVisitBlockStatement(BlockStatement blockStatement, object data)
{
if (blockStatement.Parent is BlockStatement) {
outputFormatter.Indent();
outputFormatter.PrintText("If True Then");
outputFormatter.NewLine();
outputFormatter.IndentationLevel += 1;
}
VisitStatementList(blockStatement.Children);
if (blockStatement.Parent is BlockStatement) {
outputFormatter.IndentationLevel -= 1;
outputFormatter.Indent();
outputFormatter.PrintText("End If");
outputFormatter.NewLine();
}
return null;
}
void PrintIndentedBlock(Statement stmt)
{
outputFormatter.IndentationLevel += 1;
if (stmt is BlockStatement) {
TrackedVisit(stmt, null);
} else {
outputFormatter.Indent();
TrackedVisit(stmt, null);
outputFormatter.NewLine();
}
outputFormatter.IndentationLevel -= 1;
}
void PrintIndentedBlock(IEnumerable statements)
{
outputFormatter.IndentationLevel += 1;
VisitStatementList(statements);
outputFormatter.IndentationLevel -= 1;
}
void VisitStatementList(IEnumerable statements)
{
foreach (Statement stmt in statements) {
if (stmt is BlockStatement) {
TrackedVisit(stmt, null);
} else {
outputFormatter.Indent();
TrackedVisit(stmt, null);
outputFormatter.NewLine();
}
}
}
public override object TrackedVisitAddHandlerStatement(AddHandlerStatement addHandlerStatement, object data)
{
outputFormatter.PrintToken(Tokens.AddHandler);
outputFormatter.Space();
TrackedVisit(addHandlerStatement.EventExpression, data);
outputFormatter.PrintToken(Tokens.Comma);
outputFormatter.Space();
TrackedVisit(addHandlerStatement.HandlerExpression, data);
return null;
}
public override object TrackedVisitRemoveHandlerStatement(RemoveHandlerStatement removeHandlerStatement, object data)
{
outputFormatter.PrintToken(Tokens.RemoveHandler);
outputFormatter.Space();
TrackedVisit(removeHandlerStatement.EventExpression, data);
outputFormatter.PrintToken(Tokens.Comma);
outputFormatter.Space();
TrackedVisit(removeHandlerStatement.HandlerExpression, data);
return null;
}
public override object TrackedVisitRaiseEventStatement(RaiseEventStatement raiseEventStatement, object data)
{
outputFormatter.PrintToken(Tokens.RaiseEvent);
outputFormatter.Space();
outputFormatter.PrintIdentifier(raiseEventStatement.EventName);
outputFormatter.PrintToken(Tokens.OpenParenthesis);
AppendCommaSeparatedList(raiseEventStatement.Arguments);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
return null;
}
public override object TrackedVisitEraseStatement(EraseStatement eraseStatement, object data)
{
outputFormatter.PrintToken(Tokens.Erase);
outputFormatter.Space();
AppendCommaSeparatedList(eraseStatement.Expressions);
return null;
}
public override object TrackedVisitErrorStatement(ErrorStatement errorStatement, object data)
{
outputFormatter.PrintToken(Tokens.Error);
outputFormatter.Space();
TrackedVisit(errorStatement.Expression, data);
return null;
}
public override object TrackedVisitOnErrorStatement(OnErrorStatement onErrorStatement, object data)
{
outputFormatter.PrintToken(Tokens.On);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Error);
outputFormatter.Space();
TrackedVisit(onErrorStatement.EmbeddedStatement, data);
return null;
}
public override object TrackedVisitReDimStatement(ReDimStatement reDimStatement, object data)
{
outputFormatter.PrintToken(Tokens.ReDim);
outputFormatter.Space();
if (reDimStatement.IsPreserve) {
outputFormatter.PrintToken(Tokens.Preserve);
outputFormatter.Space();
}
AppendCommaSeparatedList(reDimStatement.ReDimClauses);
return null;
}
public override object TrackedVisitExpressionStatement(ExpressionStatement expressionStatement, object data)
{
TrackedVisit(expressionStatement.Expression, data);
return null;
}
public override object TrackedVisitLocalVariableDeclaration(LocalVariableDeclaration localVariableDeclaration, object data)
{
if (localVariableDeclaration.Modifier != Modifiers.None) {
OutputModifier(localVariableDeclaration.Modifier & ~Modifiers.Dim);
}
if (!isUsingResourceAcquisition) {
if ((localVariableDeclaration.Modifier & Modifiers.Const) == 0) {
outputFormatter.PrintToken(Tokens.Dim);
}
outputFormatter.Space();
}
currentVariableType = localVariableDeclaration.TypeReference;
AppendCommaSeparatedList(localVariableDeclaration.Variables);
currentVariableType = null;
return null;
}
public override object TrackedVisitReturnStatement(ReturnStatement returnStatement, object data)
{
outputFormatter.PrintToken(Tokens.Return);
if (!returnStatement.Expression.IsNull) {
outputFormatter.Space();
TrackedVisit(returnStatement.Expression, data);
}
return null;
}
public override object TrackedVisitIfElseStatement(IfElseStatement ifElseStatement, object data)
{
outputFormatter.PrintToken(Tokens.If);
outputFormatter.Space();
TrackedVisit(ifElseStatement.Condition, data);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Then);
outputFormatter.NewLine();
PrintIndentedBlock(ifElseStatement.TrueStatement);
foreach (ElseIfSection elseIfSection in ifElseStatement.ElseIfSections) {
TrackedVisit(elseIfSection, data);
}
if (ifElseStatement.HasElseStatements) {
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.Else);
outputFormatter.NewLine();
PrintIndentedBlock(ifElseStatement.FalseStatement);
}
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.If);
return null;
}
public override object TrackedVisitElseIfSection(ElseIfSection elseIfSection, object data)
{
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.ElseIf);
outputFormatter.Space();
TrackedVisit(elseIfSection.Condition, data);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Then);
outputFormatter.NewLine();
PrintIndentedBlock(elseIfSection.EmbeddedStatement);
return null;
}
public override object TrackedVisitLabelStatement(LabelStatement labelStatement, object data)
{
outputFormatter.PrintIdentifier(labelStatement.Label);
outputFormatter.PrintToken(Tokens.Colon);
return null;
}
public override object TrackedVisitGotoStatement(GotoStatement gotoStatement, object data)
{
outputFormatter.PrintToken(Tokens.GoTo);
outputFormatter.Space();
outputFormatter.PrintIdentifier(gotoStatement.Label);
return null;
}
public override object TrackedVisitSwitchStatement(SwitchStatement switchStatement, object data)
{
exitTokenStack.Push(Tokens.Select);
outputFormatter.PrintToken(Tokens.Select);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Case);
outputFormatter.Space();
TrackedVisit(switchStatement.SwitchExpression, data);
outputFormatter.NewLine();
++outputFormatter.IndentationLevel;
foreach (SwitchSection section in switchStatement.SwitchSections) {
TrackedVisit(section, data);
}
--outputFormatter.IndentationLevel;
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Select);
exitTokenStack.Pop();
return null;
}
public override object TrackedVisitSwitchSection(SwitchSection switchSection, object data)
{
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.Case);
outputFormatter.Space();
this.AppendCommaSeparatedList(switchSection.SwitchLabels);
outputFormatter.NewLine();
PrintIndentedBlock(switchSection.Children);
return null;
}
public override object TrackedVisitCaseLabel(CaseLabel caseLabel, object data)
{
if (caseLabel.IsDefault) {
outputFormatter.PrintToken(Tokens.Else);
} else {
if (caseLabel.BinaryOperatorType != BinaryOperatorType.None) {
switch (caseLabel.BinaryOperatorType) {
case BinaryOperatorType.Equality:
outputFormatter.PrintToken(Tokens.Assign);
break;
case BinaryOperatorType.InEquality:
outputFormatter.PrintToken(Tokens.LessThan);
outputFormatter.PrintToken(Tokens.GreaterThan);
break;
case BinaryOperatorType.GreaterThan:
outputFormatter.PrintToken(Tokens.GreaterThan);
break;
case BinaryOperatorType.GreaterThanOrEqual:
outputFormatter.PrintToken(Tokens.GreaterEqual);
break;
case BinaryOperatorType.LessThan:
outputFormatter.PrintToken(Tokens.LessThan);
break;
case BinaryOperatorType.LessThanOrEqual:
outputFormatter.PrintToken(Tokens.LessEqual);
break;
}
outputFormatter.Space();
}
TrackedVisit(caseLabel.Label, data);
if (!caseLabel.ToExpression.IsNull) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.To);
outputFormatter.Space();
TrackedVisit(caseLabel.ToExpression, data);
}
}
return null;
}
public override object TrackedVisitStopStatement(StopStatement stopStatement, object data)
{
outputFormatter.PrintToken(Tokens.Stop);
return null;
}
public override object TrackedVisitResumeStatement(ResumeStatement resumeStatement, object data)
{
outputFormatter.PrintToken(Tokens.Resume);
outputFormatter.Space();
if (resumeStatement.IsResumeNext) {
outputFormatter.PrintToken(Tokens.Next);
} else {
outputFormatter.PrintIdentifier(resumeStatement.LabelName);
}
return null;
}
public override object TrackedVisitEndStatement(EndStatement endStatement, object data)
{
outputFormatter.PrintToken(Tokens.End);
return null;
}
public override object TrackedVisitContinueStatement(ContinueStatement continueStatement, object data)
{
outputFormatter.PrintToken(Tokens.Continue);
outputFormatter.Space();
switch (continueStatement.ContinueType) {
case ContinueType.Do:
outputFormatter.PrintToken(Tokens.Do);
break;
case ContinueType.For:
outputFormatter.PrintToken(Tokens.For);
break;
case ContinueType.While:
outputFormatter.PrintToken(Tokens.While);
break;
default:
outputFormatter.PrintToken(exitTokenStack.Peek());
break;
}
return null;
}
public override object TrackedVisitDoLoopStatement(DoLoopStatement doLoopStatement, object data)
{
if (doLoopStatement.ConditionPosition == ConditionPosition.None) {
Error(String.Format("Unknown condition position for loop : {0}.", doLoopStatement), doLoopStatement.StartLocation);
}
if (doLoopStatement.ConditionPosition == ConditionPosition.Start) {
switch (doLoopStatement.ConditionType) {
case ConditionType.DoWhile:
exitTokenStack.Push(Tokens.Do);
outputFormatter.PrintToken(Tokens.Do);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.While);
break;
case ConditionType.While:
exitTokenStack.Push(Tokens.While);
outputFormatter.PrintToken(Tokens.While);
break;
case ConditionType.Until:
exitTokenStack.Push(Tokens.Do);
outputFormatter.PrintToken(Tokens.Do);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.While);
break;
default:
throw new InvalidOperationException();
}
outputFormatter.Space();
TrackedVisit(doLoopStatement.Condition, null);
} else {
exitTokenStack.Push(Tokens.Do);
outputFormatter.PrintToken(Tokens.Do);
}
outputFormatter.NewLine();
PrintIndentedBlock(doLoopStatement.EmbeddedStatement);
outputFormatter.Indent();
if (doLoopStatement.ConditionPosition == ConditionPosition.Start && doLoopStatement.ConditionType == ConditionType.While) {
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.While);
} else {
outputFormatter.PrintToken(Tokens.Loop);
}
if (doLoopStatement.ConditionPosition == ConditionPosition.End && !doLoopStatement.Condition.IsNull) {
outputFormatter.Space();
switch (doLoopStatement.ConditionType) {
case ConditionType.While:
case ConditionType.DoWhile:
outputFormatter.PrintToken(Tokens.While);
break;
case ConditionType.Until:
outputFormatter.PrintToken(Tokens.Until);
break;
}
outputFormatter.Space();
TrackedVisit(doLoopStatement.Condition, null);
}
exitTokenStack.Pop();
return null;
}
public override object TrackedVisitForeachStatement(ForeachStatement foreachStatement, object data)
{
exitTokenStack.Push(Tokens.For);
outputFormatter.PrintToken(Tokens.For);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Each);
outputFormatter.Space();
// loop control variable
outputFormatter.PrintIdentifier(foreachStatement.VariableName);
if (!foreachStatement.TypeReference.IsNull) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.As);
outputFormatter.Space();
TrackedVisit(foreachStatement.TypeReference, data);
}
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.In);
outputFormatter.Space();
TrackedVisit(foreachStatement.Expression, data);
outputFormatter.NewLine();
PrintIndentedBlock(foreachStatement.EmbeddedStatement);
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.Next);
if (!foreachStatement.NextExpression.IsNull) {
outputFormatter.Space();
TrackedVisit(foreachStatement.NextExpression, data);
}
exitTokenStack.Pop();
return null;
}
public override object TrackedVisitLockStatement(LockStatement lockStatement, object data)
{
outputFormatter.PrintToken(Tokens.SyncLock);
outputFormatter.Space();
TrackedVisit(lockStatement.LockExpression, data);
outputFormatter.NewLine();
PrintIndentedBlock(lockStatement.EmbeddedStatement);
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.SyncLock);
return null;
}
bool isUsingResourceAcquisition;
public override object TrackedVisitUsingStatement(UsingStatement usingStatement, object data)
{
outputFormatter.PrintToken(Tokens.Using);
outputFormatter.Space();
isUsingResourceAcquisition = true;
TrackedVisit(usingStatement.ResourceAcquisition, data);
isUsingResourceAcquisition = false;
outputFormatter.NewLine();
PrintIndentedBlock(usingStatement.EmbeddedStatement);
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Using);
return null;
}
public override object TrackedVisitWithStatement(WithStatement withStatement, object data)
{
outputFormatter.PrintToken(Tokens.With);
outputFormatter.Space();
TrackedVisit(withStatement.Expression, data);
outputFormatter.NewLine();
PrintIndentedBlock(withStatement.Body);
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.With);
return null;
}
public override object TrackedVisitTryCatchStatement(TryCatchStatement tryCatchStatement, object data)
{
exitTokenStack.Push(Tokens.Try);
outputFormatter.PrintToken(Tokens.Try);
outputFormatter.NewLine();
PrintIndentedBlock(tryCatchStatement.StatementBlock);
foreach (CatchClause catchClause in tryCatchStatement.CatchClauses) {
TrackedVisit(catchClause, data);
}
if (!tryCatchStatement.FinallyBlock.IsNull) {
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.Finally);
outputFormatter.NewLine();
PrintIndentedBlock(tryCatchStatement.FinallyBlock);
}
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Try);
exitTokenStack.Pop();
return null;
}
public override object TrackedVisitCatchClause(CatchClause catchClause, object data)
{
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.Catch);
if (!catchClause.TypeReference.IsNull) {
outputFormatter.Space();
if (catchClause.VariableName.Length > 0) {
outputFormatter.PrintIdentifier(catchClause.VariableName);
} else {
outputFormatter.PrintIdentifier("generatedExceptionName");
}
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.As);
outputFormatter.Space();
outputFormatter.PrintIdentifier(catchClause.TypeReference.Type);
}
if (!catchClause.Condition.IsNull) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.When);
outputFormatter.Space();
TrackedVisit(catchClause.Condition, data);
}
outputFormatter.NewLine();
PrintIndentedBlock(catchClause.StatementBlock);
return null;
}
public override object TrackedVisitThrowStatement(ThrowStatement throwStatement, object data)
{
outputFormatter.PrintToken(Tokens.Throw);
if (!throwStatement.Expression.IsNull) {
outputFormatter.Space();
TrackedVisit(throwStatement.Expression, data);
}
return null;
}
public override object TrackedVisitExitStatement(ExitStatement exitStatement, object data)
{
outputFormatter.PrintToken(Tokens.Exit);
if (exitStatement.ExitType != ExitType.None) {
outputFormatter.Space();
switch (exitStatement.ExitType) {
case ExitType.Sub:
outputFormatter.PrintToken(Tokens.Sub);
break;
case ExitType.Function:
outputFormatter.PrintToken(Tokens.Function);
break;
case ExitType.Property:
outputFormatter.PrintToken(Tokens.Property);
break;
case ExitType.Do:
outputFormatter.PrintToken(Tokens.Do);
break;
case ExitType.For:
outputFormatter.PrintToken(Tokens.For);
break;
case ExitType.Try:
outputFormatter.PrintToken(Tokens.Try);
break;
case ExitType.While:
outputFormatter.PrintToken(Tokens.While);
break;
case ExitType.Select:
outputFormatter.PrintToken(Tokens.Select);
break;
default:
Error(String.Format("Unsupported exit type : {0}", exitStatement.ExitType), exitStatement.StartLocation);
break;
}
}
return null;
}
public override object TrackedVisitForNextStatement(ForNextStatement forNextStatement, object data)
{
exitTokenStack.Push(Tokens.For);
outputFormatter.PrintToken(Tokens.For);
outputFormatter.Space();
if (!forNextStatement.LoopVariableExpression.IsNull) {
TrackedVisit(forNextStatement.LoopVariableExpression, data);
} else {
outputFormatter.PrintIdentifier(forNextStatement.VariableName);
if (!forNextStatement.TypeReference.IsNull) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.As);
outputFormatter.Space();
TrackedVisit(forNextStatement.TypeReference, data);
}
}
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Assign);
outputFormatter.Space();
TrackedVisit(forNextStatement.Start, data);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.To);
outputFormatter.Space();
TrackedVisit(forNextStatement.End, data);
if (!forNextStatement.Step.IsNull) {
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Step);
outputFormatter.Space();
TrackedVisit(forNextStatement.Step, data);
}
outputFormatter.NewLine();
PrintIndentedBlock(forNextStatement.EmbeddedStatement);
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.Next);
if (forNextStatement.NextExpressions.Count > 0) {
outputFormatter.Space();
AppendCommaSeparatedList(forNextStatement.NextExpressions);
}
exitTokenStack.Pop();
return null;
}
#endregion
#region Expressions
public override object TrackedVisitClassReferenceExpression(ClassReferenceExpression classReferenceExpression, object data)
{
outputFormatter.PrintToken(Tokens.MyClass);
return null;
}
static string ConvertCharLiteral(char ch)
{
if (Char.IsControl(ch)) {
string charName = GetCharName(ch);
if (charName != null)
return "ControlChars." + charName;
else
return "ChrW(" + ((int)ch).ToString() + ")";
} else if (ch == '"') {
return "\"\"\"\"C";
} else {
return "\"" + ch.ToString() + "\"C";
}
}
static string GetCharName(char ch)
{
switch (ch) {
case '\b':
return "Back";
case '\r':
return "Cr";
case '\f':
return "FormFeed";
case '\n':
return "Lf";
case '\0':
return "NullChar";
case '\t':
return "Tab";
case '\v':
return "VerticalTab";
default:
return null;
}
}
static string ConvertString(string str)
{
StringBuilder sb = new StringBuilder();
bool inString = false;
foreach (char ch in str) {
if (char.IsControl(ch)) {
if (inString) {
sb.Append('"');
inString = false;
}
if (sb.Length > 0)
sb.Append(" & ");
string charName = GetCharName(ch);
if (charName != null)
sb.Append("vb" + charName);
else
sb.Append("ChrW(" + ((int)ch) + ")");
} else {
if (!inString) {
if (sb.Length > 0)
sb.Append(" & ");
sb.Append('"');
inString = true;
}
if (ch == '"') {
sb.Append("\"\"");
} else {
sb.Append(ch);
}
}
}
if (inString)
sb.Append('"');
if (sb.Length == 0)
return "\"\"";
return sb.ToString();
}
public override object TrackedVisitPrimitiveExpression(PrimitiveExpression primitiveExpression, object data)
{
outputFormatter.PrintText(ToVBNetString(primitiveExpression));
return null;
}
internal static string ToVBNetString(PrimitiveExpression primitiveExpression)
{
object val = primitiveExpression.Value;
if (val == null) {
return "Nothing";
}
if (val is bool) {
if ((bool)primitiveExpression.Value) {
return "True";
} else {
return "False";
}
}
if (val is string) {
return ConvertString((string)val);
}
if (val is char) {
return ConvertCharLiteral((char)primitiveExpression.Value);
}
if (val is decimal) {
return ((decimal)primitiveExpression.Value).ToString(NumberFormatInfo.InvariantInfo) + "D";
}
if (val is float) {
return ((float)primitiveExpression.Value).ToString(NumberFormatInfo.InvariantInfo) + "F";
}
if (val is double) {
string text = ((double)val).ToString(NumberFormatInfo.InvariantInfo);
if (text.IndexOf('.') < 0 && text.IndexOf('E') < 0)
return text + ".0";
else
return text;
}
if (val is IFormattable) {
StringBuilder b = new StringBuilder();
if (primitiveExpression.LiteralFormat == LiteralFormat.HexadecimalNumber) {
b.Append("&H");
b.Append(((IFormattable)val).ToString("x", NumberFormatInfo.InvariantInfo));
} else {
b.Append(((IFormattable)val).ToString(null, NumberFormatInfo.InvariantInfo));
}
if (val is ushort || val is uint || val is ulong) {
b.Append('U');
if (val is uint)
b.Append('I');
}
if (val is long || val is ulong)
b.Append('L');
if (val is short || val is ushort)
b.Append('S');
return b.ToString();
} else {
return val.ToString();
}
}
public override object TrackedVisitBinaryOperatorExpression(BinaryOperatorExpression binaryOperatorExpression, object data)
{
int op = 0;
switch (binaryOperatorExpression.Op) {
case BinaryOperatorType.Concat:
op = Tokens.ConcatString;
break;
case BinaryOperatorType.Add:
op = Tokens.Plus;
break;
case BinaryOperatorType.Subtract:
op = Tokens.Minus;
break;
case BinaryOperatorType.Multiply:
op = Tokens.Times;
break;
case BinaryOperatorType.Divide:
op = Tokens.Div;
break;
case BinaryOperatorType.DivideInteger:
op = Tokens.DivInteger;
break;
case BinaryOperatorType.Modulus:
op = Tokens.Mod;
break;
case BinaryOperatorType.ShiftLeft:
op = Tokens.ShiftLeft;
break;
case BinaryOperatorType.ShiftRight:
op = Tokens.ShiftRight;
break;
case BinaryOperatorType.BitwiseAnd:
op = Tokens.And;
break;
case BinaryOperatorType.BitwiseOr:
op = Tokens.Or;
break;
case BinaryOperatorType.ExclusiveOr:
op = Tokens.Xor;
break;
case BinaryOperatorType.LogicalAnd:
op = Tokens.AndAlso;
break;
case BinaryOperatorType.LogicalOr:
op = Tokens.OrElse;
break;
case BinaryOperatorType.ReferenceEquality:
op = Tokens.Is;
break;
case BinaryOperatorType.ReferenceInequality:
op = Tokens.IsNot;
break;
case BinaryOperatorType.Equality:
op = Tokens.Assign;
break;
case BinaryOperatorType.GreaterThan:
op = Tokens.GreaterThan;
break;
case BinaryOperatorType.GreaterThanOrEqual:
op = Tokens.GreaterEqual;
break;
case BinaryOperatorType.InEquality:
op = Tokens.NotEqual;
break;
case BinaryOperatorType.NullCoalescing:
outputFormatter.PrintText("If(");
TrackedVisit(binaryOperatorExpression.Left, data);
outputFormatter.PrintToken(Tokens.Comma);
outputFormatter.Space();
TrackedVisit(binaryOperatorExpression.Right, data);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
return null;
case BinaryOperatorType.DictionaryAccess:
{
PrimitiveExpression pright = binaryOperatorExpression.Right as PrimitiveExpression;
TrackedVisit(binaryOperatorExpression.Left, data);
if (pright != null && pright.Value is string) {
outputFormatter.PrintText("!" + (string)pright.Value);
} else {
outputFormatter.PrintToken(Tokens.OpenParenthesis);
TrackedVisit(binaryOperatorExpression.Right, data);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
}
return null;
}
case BinaryOperatorType.LessThan:
op = Tokens.LessThan;
break;
case BinaryOperatorType.LessThanOrEqual:
op = Tokens.LessEqual;
break;
}
BinaryOperatorExpression childBoe = binaryOperatorExpression.Left as BinaryOperatorExpression;
bool requireParenthesis = childBoe != null && OperatorPrecedence.ComparePrecedenceVB(binaryOperatorExpression.Op, childBoe.Op) > 0;
if (requireParenthesis)
outputFormatter.PrintToken(Tokens.OpenParenthesis);
TrackedVisit(binaryOperatorExpression.Left, data);
if (requireParenthesis)
outputFormatter.PrintToken(Tokens.CloseParenthesis);
outputFormatter.Space();
outputFormatter.PrintToken(op);
outputFormatter.Space();
childBoe = binaryOperatorExpression.Right as BinaryOperatorExpression;
requireParenthesis = childBoe != null && OperatorPrecedence.ComparePrecedenceVB(binaryOperatorExpression.Op, childBoe.Op) >= 0;
if (requireParenthesis)
outputFormatter.PrintToken(Tokens.OpenParenthesis);
TrackedVisit(binaryOperatorExpression.Right, data);
if (requireParenthesis)
outputFormatter.PrintToken(Tokens.CloseParenthesis);
return null;
}
public override object TrackedVisitParenthesizedExpression(ParenthesizedExpression parenthesizedExpression, object data)
{
outputFormatter.PrintToken(Tokens.OpenParenthesis);
TrackedVisit(parenthesizedExpression.Expression, data);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
return null;
}
public override object TrackedVisitInvocationExpression(InvocationExpression invocationExpression, object data)
{
TrackedVisit(invocationExpression.TargetObject, data);
outputFormatter.PrintToken(Tokens.OpenParenthesis);
AppendCommaSeparatedList(invocationExpression.Arguments);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
return null;
}
void PrintTypeArguments(List<TypeReference> typeArguments)
{
if (typeArguments != null && typeArguments.Count > 0) {
outputFormatter.PrintToken(Tokens.OpenParenthesis);
outputFormatter.PrintToken(Tokens.Of);
outputFormatter.Space();
AppendCommaSeparatedList(typeArguments);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
}
}
public override object TrackedVisitIdentifierExpression(IdentifierExpression identifierExpression, object data)
{
outputFormatter.PrintIdentifier(identifierExpression.Identifier);
PrintTypeArguments(identifierExpression.TypeArguments);
return null;
}
public override object TrackedVisitTypeReferenceExpression(TypeReferenceExpression typeReferenceExpression, object data)
{
TrackedVisit(typeReferenceExpression.TypeReference, data);
return null;
}
public override object TrackedVisitUnaryOperatorExpression(UnaryOperatorExpression unaryOperatorExpression, object data)
{
switch (unaryOperatorExpression.Op) {
case UnaryOperatorType.Not:
case UnaryOperatorType.BitNot:
outputFormatter.PrintToken(Tokens.Not);
outputFormatter.Space();
TrackedVisit(unaryOperatorExpression.Expression, data);
return null;
case UnaryOperatorType.Decrement:
outputFormatter.PrintText("System.Threading.Interlocked.Decrement(");
TrackedVisit(unaryOperatorExpression.Expression, data);
outputFormatter.PrintText(")");
return null;
case UnaryOperatorType.Increment:
outputFormatter.PrintText("System.Threading.Interlocked.Increment(");
TrackedVisit(unaryOperatorExpression.Expression, data);
outputFormatter.PrintText(")");
return null;
case UnaryOperatorType.Minus:
outputFormatter.PrintToken(Tokens.Minus);
TrackedVisit(unaryOperatorExpression.Expression, data);
return null;
case UnaryOperatorType.Plus:
outputFormatter.PrintToken(Tokens.Plus);
TrackedVisit(unaryOperatorExpression.Expression, data);
return null;
case UnaryOperatorType.PostDecrement:
outputFormatter.PrintText("System.Math.Max(System.Threading.Interlocked.Decrement(");
TrackedVisit(unaryOperatorExpression.Expression, data);
outputFormatter.PrintText("),");
TrackedVisit(unaryOperatorExpression.Expression, data);
outputFormatter.PrintText(" + 1)");
return null;
case UnaryOperatorType.PostIncrement:
outputFormatter.PrintText("System.Math.Max(System.Threading.Interlocked.Increment(");
TrackedVisit(unaryOperatorExpression.Expression, data);
outputFormatter.PrintText("),");
TrackedVisit(unaryOperatorExpression.Expression, data);
outputFormatter.PrintText(" - 1)");
return null;
case UnaryOperatorType.Dereference:
outputFormatter.PrintToken(Tokens.Times);
TrackedVisit(unaryOperatorExpression.Expression, data);
return null;
case UnaryOperatorType.AddressOf:
outputFormatter.PrintToken(Tokens.AddressOf);
TrackedVisit(unaryOperatorExpression.Expression, data);
return null;
default:
Error("unknown unary operator: " + unaryOperatorExpression.Op.ToString(), unaryOperatorExpression.StartLocation);
outputFormatter.PrintText(unaryOperatorExpression.Op.ToString());
outputFormatter.PrintText("(");
TrackedVisit(unaryOperatorExpression.Expression, data);
outputFormatter.PrintText(")");
return null;
}
}
public override object TrackedVisitAssignmentExpression(AssignmentExpression assignmentExpression, object data)
{
int op = 0;
bool unsupportedOpAssignment = false;
switch (assignmentExpression.Op) {
case AssignmentOperatorType.Assign:
op = Tokens.Assign;
break;
case AssignmentOperatorType.Add:
op = Tokens.PlusAssign;
break;
case AssignmentOperatorType.Subtract:
op = Tokens.MinusAssign;
break;
case AssignmentOperatorType.Multiply:
op = Tokens.TimesAssign;
break;
case AssignmentOperatorType.Divide:
op = Tokens.DivAssign;
break;
case AssignmentOperatorType.ShiftLeft:
op = Tokens.ShiftLeftAssign;
break;
case AssignmentOperatorType.ShiftRight:
op = Tokens.ShiftRightAssign;
break;
case AssignmentOperatorType.ExclusiveOr:
op = Tokens.Xor;
unsupportedOpAssignment = true;
break;
case AssignmentOperatorType.Modulus:
op = Tokens.Mod;
unsupportedOpAssignment = true;
break;
case AssignmentOperatorType.BitwiseAnd:
op = Tokens.And;
unsupportedOpAssignment = true;
break;
case AssignmentOperatorType.BitwiseOr:
op = Tokens.Or;
unsupportedOpAssignment = true;
break;
}
TrackedVisit(assignmentExpression.Left, data);
outputFormatter.Space();
if (unsupportedOpAssignment) { // left = left OP right
outputFormatter.PrintToken(Tokens.Assign);
outputFormatter.Space();
TrackedVisit(assignmentExpression.Left, data);
outputFormatter.Space();
}
outputFormatter.PrintToken(op);
outputFormatter.Space();
TrackedVisit(assignmentExpression.Right, data);
return null;
}
public override object TrackedVisitTypeOfExpression(TypeOfExpression typeOfExpression, object data)
{
outputFormatter.PrintToken(Tokens.GetType);
outputFormatter.PrintToken(Tokens.OpenParenthesis);
TrackedVisit(typeOfExpression.TypeReference, data);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
return null;
}
public override object TrackedVisitDefaultValueExpression(DefaultValueExpression defaultValueExpression, object data)
{
// assigning nothing to a generic type in VB compiles to a DefaultValueExpression
outputFormatter.PrintToken(Tokens.Nothing);
return null;
}
public override object TrackedVisitTypeOfIsExpression(TypeOfIsExpression typeOfIsExpression, object data)
{
outputFormatter.PrintToken(Tokens.TypeOf);
outputFormatter.Space();
TrackedVisit(typeOfIsExpression.Expression, data);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Is);
outputFormatter.Space();
TrackedVisit(typeOfIsExpression.TypeReference, data);
return null;
}
public override object TrackedVisitAddressOfExpression(AddressOfExpression addressOfExpression, object data)
{
outputFormatter.PrintToken(Tokens.AddressOf);
outputFormatter.Space();
TrackedVisit(addressOfExpression.Expression, data);
return null;
}
public override object TrackedVisitCastExpression(CastExpression castExpression, object data)
{
if (castExpression.CastType == CastType.TryCast) {
return PrintCast(Tokens.TryCast, castExpression);
}
if (castExpression.CastType == CastType.Cast || castExpression.CastTo.IsArrayType) {
return PrintCast(Tokens.DirectCast, castExpression);
}
switch (castExpression.CastTo.Type) {
case "System.Boolean":
outputFormatter.PrintToken(Tokens.CBool);
break;
case "System.Byte":
outputFormatter.PrintToken(Tokens.CByte);
break;
case "System.SByte":
outputFormatter.PrintToken(Tokens.CSByte);
break;
case "System.Char":
outputFormatter.PrintToken(Tokens.CChar);
break;
case "System.DateTime":
outputFormatter.PrintToken(Tokens.CDate);
break;
case "System.Decimal":
outputFormatter.PrintToken(Tokens.CDec);
break;
case "System.Double":
outputFormatter.PrintToken(Tokens.CDbl);
break;
case "System.Int16":
outputFormatter.PrintToken(Tokens.CShort);
break;
case "System.Int32":
outputFormatter.PrintToken(Tokens.CInt);
break;
case "System.Int64":
outputFormatter.PrintToken(Tokens.CLng);
break;
case "System.UInt16":
outputFormatter.PrintToken(Tokens.CUShort);
break;
case "System.UInt32":
outputFormatter.PrintToken(Tokens.CUInt);
break;
case "System.UInt64":
outputFormatter.PrintToken(Tokens.CULng);
break;
case "System.Object":
outputFormatter.PrintToken(Tokens.CObj);
break;
case "System.Single":
outputFormatter.PrintToken(Tokens.CSng);
break;
case "System.String":
outputFormatter.PrintToken(Tokens.CStr);
break;
default:
return PrintCast(Tokens.CType, castExpression);
}
outputFormatter.PrintToken(Tokens.OpenParenthesis);
TrackedVisit(castExpression.Expression, data);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
return null;
}
object PrintCast(int castToken, CastExpression castExpression)
{
outputFormatter.PrintToken(castToken);
outputFormatter.PrintToken(Tokens.OpenParenthesis);
TrackedVisit(castExpression.Expression, null);
outputFormatter.PrintToken(Tokens.Comma);
outputFormatter.Space();
TrackedVisit(castExpression.CastTo, null);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
return null;
}
public override object TrackedVisitThisReferenceExpression(ThisReferenceExpression thisReferenceExpression, object data)
{
outputFormatter.PrintToken(Tokens.Me);
return null;
}
public override object TrackedVisitBaseReferenceExpression(BaseReferenceExpression baseReferenceExpression, object data)
{
outputFormatter.PrintToken(Tokens.MyBase);
return null;
}
public override object TrackedVisitObjectCreateExpression(ObjectCreateExpression objectCreateExpression, object data)
{
outputFormatter.PrintToken(Tokens.New);
if (!objectCreateExpression.IsAnonymousType) {
outputFormatter.Space();
TrackedVisit(objectCreateExpression.CreateType, data);
outputFormatter.PrintToken(Tokens.OpenParenthesis);
AppendCommaSeparatedList(objectCreateExpression.Parameters);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
}
CollectionInitializerExpression initializer = objectCreateExpression.ObjectInitializer;
if (!initializer.IsNull) {
outputFormatter.Space();
if (initializer.CreateExpressions.Any(ce => ce is MemberInitializerExpression))
outputFormatter.PrintToken(Tokens.With);
else
outputFormatter.PrintToken(Tokens.From);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.OpenCurlyBrace);
outputFormatter.IndentationLevel++;
for (int i = 0; i < initializer.CreateExpressions.Count; i++) {
Expression expr = initializer.CreateExpressions[i];
if (i > 0)
outputFormatter.PrintToken(Tokens.Comma);
outputFormatter.PrintLineContinuation();
outputFormatter.Indent();
TrackedVisit(expr, data);
}
outputFormatter.IndentationLevel--;
outputFormatter.PrintLineContinuation();
outputFormatter.Indent();
outputFormatter.PrintToken(Tokens.CloseCurlyBrace);
}
return null;
}
public override object TrackedVisitArrayCreateExpression(ArrayCreateExpression arrayCreateExpression, object data)
{
outputFormatter.PrintToken(Tokens.New);
outputFormatter.Space();
PrintTypeReferenceWithoutArray(arrayCreateExpression.CreateType);
if (arrayCreateExpression.Arguments.Count > 0) {
outputFormatter.PrintToken(Tokens.OpenParenthesis);
AppendCommaSeparatedList(arrayCreateExpression.Arguments);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
PrintArrayRank(arrayCreateExpression.CreateType.RankSpecifier, 1);
} else {
PrintArrayRank(arrayCreateExpression.CreateType.RankSpecifier, 0);
}
outputFormatter.Space();
if (arrayCreateExpression.ArrayInitializer.IsNull) {
outputFormatter.PrintToken(Tokens.OpenCurlyBrace);
outputFormatter.PrintToken(Tokens.CloseCurlyBrace);
} else {
TrackedVisit(arrayCreateExpression.ArrayInitializer, data);
}
return null;
}
public override object TrackedVisitCollectionInitializerExpression(CollectionInitializerExpression arrayInitializerExpression, object data)
{
outputFormatter.PrintToken(Tokens.OpenCurlyBrace);
this.AppendCommaSeparatedList(arrayInitializerExpression.CreateExpressions);
outputFormatter.PrintToken(Tokens.CloseCurlyBrace);
return null;
}
public override object TrackedVisitMemberInitializerExpression(MemberInitializerExpression memberInitializerExpression, object data)
{
if (memberInitializerExpression.IsKey) {
outputFormatter.PrintToken(Tokens.Key);
outputFormatter.Space();
}
outputFormatter.PrintToken(Tokens.Dot);
outputFormatter.PrintIdentifier(memberInitializerExpression.Name);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Assign);
outputFormatter.Space();
TrackedVisit(memberInitializerExpression.Expression, data);
return null;
}
public override object TrackedVisitMemberReferenceExpression(MemberReferenceExpression memberReferenceExpression, object data)
{
TrackedVisit(memberReferenceExpression.TargetObject, data);
outputFormatter.PrintToken(Tokens.Dot);
if (string.Equals(memberReferenceExpression.MemberName, "New", StringComparison.OrdinalIgnoreCase)
&& (memberReferenceExpression.TargetObject is BaseReferenceExpression || memberReferenceExpression.TargetObject is ThisReferenceExpression || memberReferenceExpression.TargetObject is ClassReferenceExpression))
{
outputFormatter.PrintToken(Tokens.New);
} else {
outputFormatter.PrintIdentifier(memberReferenceExpression.MemberName);
}
PrintTypeArguments(memberReferenceExpression.TypeArguments);
return null;
}
public override object TrackedVisitDirectionExpression(DirectionExpression directionExpression, object data)
{
// VB does not need to specify the direction in method calls
TrackedVisit(directionExpression.Expression, data);
return null;
}
public override object TrackedVisitConditionalExpression(ConditionalExpression conditionalExpression, object data)
{
outputFormatter.PrintText("If");
outputFormatter.PrintToken(Tokens.OpenParenthesis);
TrackedVisit(conditionalExpression.Condition, data);
outputFormatter.PrintToken(Tokens.Comma);
outputFormatter.Space();
TrackedVisit(conditionalExpression.TrueExpression, data);
outputFormatter.PrintToken(Tokens.Comma);
outputFormatter.Space();
TrackedVisit(conditionalExpression.FalseExpression, data);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
return null;
}
#endregion
#endregion
void OutputModifier(ParameterModifiers modifier)
{
if ((modifier & ParameterModifiers.Optional) == ParameterModifiers.Optional) {
outputFormatter.PrintToken(Tokens.Optional);
outputFormatter.Space();
}
if ((modifier & ParameterModifiers.Ref) == ParameterModifiers.Ref
|| (modifier & ParameterModifiers.Out) == ParameterModifiers.Out) {
outputFormatter.PrintToken(Tokens.ByRef);
outputFormatter.Space();
}
if ((modifier & ParameterModifiers.Params) == ParameterModifiers.Params) {
outputFormatter.PrintToken(Tokens.ParamArray);
outputFormatter.Space();
}
if (prettyPrintOptions.OutputByValModifier &&
(modifier & (ParameterModifiers.Params | ParameterModifiers.Ref)) == ParameterModifiers.None)
{
outputFormatter.PrintToken(Tokens.ByVal);
outputFormatter.Space();
}
}
void OutputModifier(Modifiers modifier)
{
OutputModifier(modifier, false, false);
}
void OutputModifier(Modifiers modifier, bool forTypeDecl, bool forFieldDecl)
{
if ((modifier & Modifiers.Public) == Modifiers.Public) {
outputFormatter.PrintToken(Tokens.Public);
outputFormatter.Space();
} else if ((modifier & Modifiers.Private) == Modifiers.Private) {
outputFormatter.PrintToken(Tokens.Private);
outputFormatter.Space();
} else if ((modifier & (Modifiers.Protected | Modifiers.Internal)) == (Modifiers.Protected | Modifiers.Internal)) {
outputFormatter.PrintToken(Tokens.Protected);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Friend);
outputFormatter.Space();
} else if ((modifier & Modifiers.Internal) == Modifiers.Internal) {
outputFormatter.PrintToken(Tokens.Friend);
outputFormatter.Space();
} else if ((modifier & Modifiers.Protected) == Modifiers.Protected) {
outputFormatter.PrintToken(Tokens.Protected);
outputFormatter.Space();
}
if ((modifier & Modifiers.Static) == Modifiers.Static) {
outputFormatter.PrintToken(Tokens.Shared);
outputFormatter.Space();
}
if ((modifier & Modifiers.Virtual) == Modifiers.Virtual) {
outputFormatter.PrintToken(Tokens.Overridable);
outputFormatter.Space();
}
if ((modifier & Modifiers.Abstract) == Modifiers.Abstract) {
if (forFieldDecl)
outputFormatter.PrintToken(Tokens.Dim);
else if (forTypeDecl)
outputFormatter.PrintToken(Tokens.MustInherit);
else
outputFormatter.PrintToken(Tokens.MustOverride);
outputFormatter.Space();
}
if ((modifier & Modifiers.Dim) == Modifiers.Dim) {
outputFormatter.PrintToken(Tokens.Dim);
outputFormatter.Space();
}
if ((modifier & Modifiers.Overloads) == Modifiers.Overloads) {
outputFormatter.PrintToken(Tokens.Overloads);
outputFormatter.Space();
}
if ((modifier & Modifiers.Override) == Modifiers.Override) {
outputFormatter.PrintToken(Tokens.Overrides);
outputFormatter.Space();
}
if ((modifier & Modifiers.New) == Modifiers.New) {
outputFormatter.PrintToken(Tokens.Shadows);
outputFormatter.Space();
}
if ((modifier & Modifiers.Sealed) == Modifiers.Sealed) {
outputFormatter.PrintToken(forTypeDecl ? Tokens.NotInheritable : Tokens.NotOverridable);
outputFormatter.Space();
}
if ((modifier & Modifiers.ReadOnly) == Modifiers.ReadOnly) {
outputFormatter.PrintToken(Tokens.ReadOnly);
outputFormatter.Space();
}
if ((modifier & Modifiers.WriteOnly) == Modifiers.WriteOnly) {
outputFormatter.PrintToken(Tokens.WriteOnly);
outputFormatter.Space();
}
if ((modifier & Modifiers.Const) == Modifiers.Const) {
outputFormatter.PrintToken(Tokens.Const);
outputFormatter.Space();
}
if ((modifier & Modifiers.WithEvents) == Modifiers.WithEvents) {
outputFormatter.PrintToken(Tokens.WithEvents);
outputFormatter.Space();
}
if ((modifier & Modifiers.Partial) == Modifiers.Partial) {
outputFormatter.PrintToken(Tokens.Partial);
outputFormatter.Space();
}
if ((modifier & Modifiers.Extern) == Modifiers.Extern) {
// not required in VB
}
if ((modifier & Modifiers.Default) == Modifiers.Default) {
outputFormatter.PrintToken(Tokens.Default);
outputFormatter.Space();
}
if ((modifier & Modifiers.Volatile) == Modifiers.Volatile) {
Error("'Volatile' modifier not convertable", Location.Empty);
}
if ((modifier & Modifiers.Unsafe) == Modifiers.Unsafe) {
Error("'Unsafe' modifier not convertable", Location.Empty);
}
}
public void AppendCommaSeparatedList<T>(ICollection<T> list) where T : class, INode
{
if (list != null) {
int i = 0;
foreach (T node in list) {
TrackedVisit(node, null);
if (i + 1 < list.Count) {
outputFormatter.PrintToken(Tokens.Comma);
outputFormatter.Space();
if ((i + 1) % 6 == 0) {
outputFormatter.PrintLineContinuation();
outputFormatter.Indent();
outputFormatter.PrintText("\t");
}
}
i++;
}
}
}
void VisitAttributes(ICollection attributes, object data)
{
if (attributes == null) {
return;
}
foreach (AttributeSection section in attributes) {
if (string.Equals(section.AttributeTarget, "return", StringComparison.OrdinalIgnoreCase))
continue;
TrackedVisit(section, data);
}
}
void VisitReturnTypeAttributes(ICollection attributes, object data)
{
if (attributes == null) {
return;
}
printAttributeSectionInline = true;
foreach (AttributeSection section in attributes) {
if (string.Equals(section.AttributeTarget, "return", StringComparison.OrdinalIgnoreCase)) {
TrackedVisit(section, data);
}
}
printAttributeSectionInline = false;
}
public override object TrackedVisitLambdaExpression(LambdaExpression lambdaExpression, object data)
{
bool isSub = !lambdaExpression.ReturnType.IsNull &&
lambdaExpression.ReturnType.Type == "System.Void" && lambdaExpression.ReturnType.IsKeyword;
if (isSub)
outputFormatter.PrintToken(Tokens.Sub);
else
outputFormatter.PrintToken(Tokens.Function);
outputFormatter.PrintToken(Tokens.OpenParenthesis);
AppendCommaSeparatedList(lambdaExpression.Parameters);
outputFormatter.PrintToken(Tokens.CloseParenthesis);
outputFormatter.Space();
if (!lambdaExpression.ExpressionBody.IsNull) {
return lambdaExpression.ExpressionBody.AcceptVisitor(this, data);
} else {
if (!isSub && !lambdaExpression.ReturnType.IsNull) {
outputFormatter.PrintToken(Tokens.As);
outputFormatter.Space();
TrackedVisit(lambdaExpression.ReturnType, data);
}
if (lambdaExpression.StatementBody is BlockStatement)
outputFormatter.NewLine();
TrackedVisit(lambdaExpression.StatementBody, data);
if (lambdaExpression.StatementBody is BlockStatement) {
outputFormatter.NewLine();
outputFormatter.PrintToken(Tokens.End);
outputFormatter.Space();
if (isSub)
outputFormatter.PrintToken(Tokens.Sub);
else
outputFormatter.PrintToken(Tokens.Function);
}
return null;
}
}
public override object TrackedVisitQueryExpression(QueryExpression queryExpression, object data)
{
outputFormatter.IndentationLevel++;
for (int i = 0; i < queryExpression.Clauses.Count; i++) {
QueryExpressionClause clause = queryExpression.Clauses[i];
if (!clause.IsNull) {
if (i != 0) {
outputFormatter.PrintLineContinuation();
outputFormatter.Indent();
}
clause.AcceptVisitor(this, null);
}
}
outputFormatter.IndentationLevel--;
return null;
}
void PrintClause(QueryExpressionClause clause)
{
}
public override object TrackedVisitQueryExpressionFromClause(QueryExpressionFromClause fromClause, object data)
{
outputFormatter.PrintText("From");
outputFormatter.Space();
for (int i = 0; i < fromClause.Sources.Count; i++) {
CollectionRangeVariable clause = fromClause.Sources[i];
outputFormatter.PrintIdentifier(clause.Identifier);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.In);
outputFormatter.Space();
clause.Expression.AcceptVisitor(this, data);
if (i < fromClause.Sources.Count - 1)
outputFormatter.PrintToken(Tokens.Comma);
}
return null;
}
public override object TrackedVisitQueryExpressionJoinClause(QueryExpressionJoinClause joinClause, object data)
{
outputFormatter.PrintText("Join");
outputFormatter.Space();
CollectionRangeVariable clause = joinClause.Source;
outputFormatter.PrintIdentifier(clause.Identifier);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.In);
outputFormatter.Space();
clause.Expression.AcceptVisitor(this, data);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.On);
outputFormatter.Space();
joinClause.OnExpression.AcceptVisitor(this, data);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Assign);
outputFormatter.Space();
joinClause.EqualsExpression.AcceptVisitor(this, data);
if (!string.IsNullOrEmpty(joinClause.IntoIdentifier)) {
outputFormatter.Space();
outputFormatter.PrintText("Into");
outputFormatter.Space();
outputFormatter.PrintIdentifier(joinClause.IntoIdentifier);
}
return null;
}
// void VisitQueryExpressionFromOrJoinClause(QueryExpressionFromOrJoinClause clause, object data)
// {
// outputFormatter.PrintIdentifier(clause.Identifier);
// outputFormatter.Space();
// outputFormatter.PrintToken(Tokens.In);
// outputFormatter.Space();
// clause.InExpression.AcceptVisitor(this, data);
// }
public override object TrackedVisitQueryExpressionLetClause(QueryExpressionLetClause letClause, object data)
{
outputFormatter.PrintToken(Tokens.Let);
outputFormatter.Space();
outputFormatter.PrintIdentifier(letClause.Identifier);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.Assign);
outputFormatter.Space();
return letClause.Expression.AcceptVisitor(this, data);
}
public override object TrackedVisitQueryExpressionGroupClause(QueryExpressionGroupClause groupClause, object data)
{
outputFormatter.PrintText("Group");
outputFormatter.Space();
groupClause.Projection.AcceptVisitor(this, data);
outputFormatter.Space();
outputFormatter.PrintText("By");
outputFormatter.Space();
return groupClause.GroupBy.AcceptVisitor(this, data);
}
public override object TrackedVisitQueryExpressionOrderClause(QueryExpressionOrderClause queryExpressionOrderClause, object data)
{
outputFormatter.PrintText("Order By");
outputFormatter.Space();
AppendCommaSeparatedList(queryExpressionOrderClause.Orderings);
return null;
}
public override object TrackedVisitQueryExpressionOrdering(QueryExpressionOrdering ordering, object data)
{
ordering.Criteria.AcceptVisitor(this, data);
if (ordering.Direction == QueryExpressionOrderingDirection.Ascending) {
outputFormatter.Space();
outputFormatter.PrintText("Ascending");
} else if (ordering.Direction == QueryExpressionOrderingDirection.Descending) {
outputFormatter.Space();
outputFormatter.PrintText("Descending");
}
return null;
}
public override object TrackedVisitQueryExpressionSelectVBClause(QueryExpressionSelectVBClause selectClause, object data)
{
outputFormatter.PrintToken(Tokens.Select);
outputFormatter.Space();
foreach (ExpressionRangeVariable var in selectClause.Variables) {
var.AcceptVisitor(this, data);
}
return null;
}
public override object TrackedVisitQueryExpressionWhereClause(QueryExpressionWhereClause whereClause, object data)
{
outputFormatter.Space();
outputFormatter.PrintText("Where");
outputFormatter.Space();
return whereClause.Condition.AcceptVisitor(this, data);
}
public override object TrackedVisitExternAliasDirective(ExternAliasDirective externAliasDirective, object data)
{
UnsupportedNode(externAliasDirective);
return null;
}
public override object TrackedVisitXmlContentExpression(XmlContentExpression xmlContentExpression, object data)
{
switch (xmlContentExpression.Type) {
case XmlContentType.Comment:
outputFormatter.PrintText("<!--" + xmlContentExpression.Content + "-->");
break;
case XmlContentType.Text:
outputFormatter.PrintText(xmlContentExpression.Content);
break;
case XmlContentType.CData:
outputFormatter.PrintText("<![CDATA[" + xmlContentExpression.Content + "]]>");
break;
case XmlContentType.ProcessingInstruction:
outputFormatter.PrintText("<?" + xmlContentExpression.Content + "?>");
break;
default:
throw new Exception("Invalid value for XmlContentType");
}
return null;
}
public override object TrackedVisitXmlEmbeddedExpression(XmlEmbeddedExpression xmlEmbeddedExpression, object data)
{
outputFormatter.PrintText("<%=");
outputFormatter.Space();
xmlEmbeddedExpression.InlineVBExpression.AcceptVisitor(this, data);
outputFormatter.Space();
outputFormatter.PrintText("%>");
return null;
}
public override object TrackedVisitXmlAttributeExpression(XmlAttributeExpression xmlAttributeExpression, object data)
{
outputFormatter.PrintText(xmlAttributeExpression.Name);
outputFormatter.PrintToken(Tokens.Assign);
if (xmlAttributeExpression.IsLiteralValue) {
if (xmlAttributeExpression.UseDoubleQuotes)
outputFormatter.PrintText("\"");
else
outputFormatter.PrintText("'");
outputFormatter.PrintText(xmlAttributeExpression.LiteralValue);
if (xmlAttributeExpression.UseDoubleQuotes)
outputFormatter.PrintText("\"");
else
outputFormatter.PrintText("'");
} else
xmlAttributeExpression.ExpressionValue.AcceptVisitor(this, data);
return null;
}
public override object TrackedVisitXmlElementExpression(XmlElementExpression xmlElementExpression, object data)
{
outputFormatter.PrintText("<");
if (xmlElementExpression.NameIsExpression) {
outputFormatter.PrintToken(Tokens.XmlStartInlineVB);
outputFormatter.Space();
xmlElementExpression.NameExpression.AcceptVisitor(this, data);
outputFormatter.Space();
outputFormatter.PrintToken(Tokens.XmlEndInlineVB);
} else {
outputFormatter.PrintText(xmlElementExpression.XmlName);
}
foreach (XmlExpression attribute in xmlElementExpression.Attributes) {
outputFormatter.Space();
attribute.AcceptVisitor(this, data);
}
if (xmlElementExpression.Children.Any()) {
outputFormatter.PrintText(">");
foreach (INode node in xmlElementExpression.Children) {
node.AcceptVisitor(this, data);
}
outputFormatter.PrintText("</");
if (!xmlElementExpression.NameIsExpression)
outputFormatter.PrintText(xmlElementExpression.XmlName);
outputFormatter.PrintText(">");
} else {
outputFormatter.Space();
outputFormatter.PrintText("/>");
}
return null;
}
public override object TrackedVisitXmlMemberAccessExpression(XmlMemberAccessExpression xmlMemberAccessExpression, object data)
{
xmlMemberAccessExpression.TargetObject.AcceptVisitor(this, data);
switch (xmlMemberAccessExpression.AxisType) {
case XmlAxisType.Element:
outputFormatter.PrintToken(Tokens.Dot);
break;
case XmlAxisType.Attribute:
outputFormatter.PrintToken(Tokens.DotAt);
break;
case XmlAxisType.Descendents:
outputFormatter.PrintToken(Tokens.TripleDot);
break;
default:
throw new Exception("Invalid value for XmlAxisType");
}
if (xmlMemberAccessExpression.IsXmlIdentifier)
outputFormatter.PrintText("<" + xmlMemberAccessExpression.Identifier + ">");
else
outputFormatter.PrintIdentifier(xmlMemberAccessExpression.Identifier);
return null;
}
}
}