void StructMemberDecl( #line 753 "Frames/cs.ATG" ModifierList m, List<AttributeSection> attributes) { #line 755 "Frames/cs.ATG" string qualident = null; TypeReference type; Expression expr; List<ParameterDeclarationExpression> p = new List<ParameterDeclarationExpression>(); Statement stmt = null; List<TemplateDefinition> templates = new List<TemplateDefinition>(); TypeReference explicitInterface = null; bool isExtensionMethod = false; if (la.kind == 60) { #line 765 "Frames/cs.ATG" m.Check(Modifiers.Constants); lexer.NextToken(); #line 766 "Frames/cs.ATG" Location startPos = t.Location; Type( #line 767 "Frames/cs.ATG" out type); Identifier(); #line 767 "Frames/cs.ATG" FieldDeclaration fd = new FieldDeclaration(attributes, type, m.Modifier | Modifiers.Const); fd.StartLocation = m.GetDeclarationLocation(startPos); VariableDeclaration f = new VariableDeclaration(t.val); f.StartLocation = t.Location; f.TypeReference = type; SafeAdd(fd, fd.Fields, f); Expect(3); Expr( #line 774 "Frames/cs.ATG" out expr); #line 774 "Frames/cs.ATG" f.Initializer = expr; while (la.kind == 14) { lexer.NextToken(); Identifier(); #line 775 "Frames/cs.ATG" f = new VariableDeclaration(t.val); f.StartLocation = t.Location; f.TypeReference = type; SafeAdd(fd, fd.Fields, f); Expect(3); Expr( #line 780 "Frames/cs.ATG" out expr); #line 780 "Frames/cs.ATG" f.EndLocation = t.EndLocation; f.Initializer = expr; } Expect(11); #line 781 "Frames/cs.ATG" fd.EndLocation = t.EndLocation; compilationUnit.AddChild(fd); } else if ( #line 785 "Frames/cs.ATG" NotVoidPointer()) { #line 785 "Frames/cs.ATG" m.Check(Modifiers.PropertysEventsMethods); Expect(123); #line 786 "Frames/cs.ATG" Location startPos = t.Location; if ( #line 787 "Frames/cs.ATG" IsExplicitInterfaceImplementation()) { TypeName( #line 788 "Frames/cs.ATG" out explicitInterface, false); #line 789 "Frames/cs.ATG" if (la.kind != Tokens.Dot || Peek(1).kind != Tokens.This) { qualident = TypeReference.StripLastIdentifierFromType(ref explicitInterface); } } else if (StartOf(19)) { Identifier(); #line 792 "Frames/cs.ATG" qualident = t.val; } else SynErr(162); if (la.kind == 23) { TypeParameterList( #line 795 "Frames/cs.ATG" templates); } Expect(20); if (la.kind == 111) { lexer.NextToken(); #line 798 "Frames/cs.ATG" isExtensionMethod = true; /* C# 3.0 */ } if (StartOf(11)) { FormalParameterList( #line 799 "Frames/cs.ATG" p); } Expect(21); #line 800 "Frames/cs.ATG" MethodDeclaration methodDeclaration = new MethodDeclaration { Name = qualident, Modifier = m.Modifier, TypeReference = new TypeReference("System.Void", true), Parameters = p, Attributes = attributes, StartLocation = m.GetDeclarationLocation(startPos), EndLocation = t.EndLocation, Templates = templates, IsExtensionMethod = isExtensionMethod }; if (explicitInterface != null) SafeAdd(methodDeclaration, methodDeclaration.InterfaceImplementations, new InterfaceImplementation(explicitInterface, qualident)); compilationUnit.AddChild(methodDeclaration); compilationUnit.BlockStart(methodDeclaration); while (la.kind == 127) { TypeParameterConstraintsClause( #line 818 "Frames/cs.ATG" templates); } if (la.kind == 16) { Block( #line 820 "Frames/cs.ATG" out stmt); } else if (la.kind == 11) { lexer.NextToken(); } else SynErr(163); #line 820 "Frames/cs.ATG" compilationUnit.BlockEnd(); methodDeclaration.Body = (BlockStatement)stmt; } else if (la.kind == 69) { #line 824 "Frames/cs.ATG" m.Check(Modifiers.PropertysEventsMethods); lexer.NextToken(); #line 826 "Frames/cs.ATG" EventDeclaration eventDecl = new EventDeclaration { Modifier = m.Modifier, Attributes = attributes, StartLocation = t.Location }; compilationUnit.AddChild(eventDecl); compilationUnit.BlockStart(eventDecl); EventAddRegion addBlock = null; EventRemoveRegion removeBlock = null; Type( #line 836 "Frames/cs.ATG" out type); #line 836 "Frames/cs.ATG" eventDecl.TypeReference = type; if ( #line 837 "Frames/cs.ATG" IsExplicitInterfaceImplementation()) { TypeName( #line 838 "Frames/cs.ATG" out explicitInterface, false); #line 839 "Frames/cs.ATG" qualident = TypeReference.StripLastIdentifierFromType(ref explicitInterface); #line 840 "Frames/cs.ATG" eventDecl.InterfaceImplementations.Add(new InterfaceImplementation(explicitInterface, qualident)); } else if (StartOf(19)) { Identifier(); #line 842 "Frames/cs.ATG" qualident = t.val; } else SynErr(164); #line 844 "Frames/cs.ATG" eventDecl.Name = qualident; eventDecl.EndLocation = t.EndLocation; if (la.kind == 3) { lexer.NextToken(); Expr( #line 845 "Frames/cs.ATG" out expr); #line 845 "Frames/cs.ATG" eventDecl.Initializer = expr; } if (la.kind == 16) { lexer.NextToken(); #line 846 "Frames/cs.ATG" eventDecl.BodyStart = t.Location; EventAccessorDecls( #line 847 "Frames/cs.ATG" out addBlock, out removeBlock); Expect(17); #line 848 "Frames/cs.ATG" eventDecl.BodyEnd = t.EndLocation; } #line 850 "Frames/cs.ATG" compilationUnit.BlockEnd(); eventDecl.AddRegion = addBlock; eventDecl.RemoveRegion = removeBlock; while (la.kind == 14) { lexer.NextToken(); Identifier(); #line 854 "Frames/cs.ATG" EventDeclaration additionalEventDeclaration = new EventDeclaration { Modifier = eventDecl.Modifier, Attributes = eventDecl.Attributes, StartLocation = eventDecl.StartLocation, TypeReference = eventDecl.TypeReference, Name = t.val }; compilationUnit.AddChild (additionalEventDeclaration); } if (la.kind == 11) { lexer.NextToken(); } } else if ( #line 868 "Frames/cs.ATG" IdentAndLPar()) { #line 868 "Frames/cs.ATG" m.Check(Modifiers.Constructors | Modifiers.StaticConstructors); Identifier(); #line 869 "Frames/cs.ATG" string name = t.val; Location startPos = t.Location; Expect(20); if (StartOf(11)) { #line 869 "Frames/cs.ATG" m.Check(Modifiers.Constructors); FormalParameterList( #line 870 "Frames/cs.ATG" p); } Expect(21); #line 872 "Frames/cs.ATG" ConstructorInitializer init = null; if (la.kind == 9) { #line 873 "Frames/cs.ATG" m.Check(Modifiers.Constructors); ConstructorInitializer( #line 874 "Frames/cs.ATG" out init); } #line 876 "Frames/cs.ATG" ConstructorDeclaration cd = new ConstructorDeclaration(name, m.Modifier, p, init, attributes); cd.StartLocation = startPos; cd.EndLocation = t.EndLocation; if (la.kind == 16) { Block( #line 881 "Frames/cs.ATG" out stmt); } else if (la.kind == 11) { lexer.NextToken(); } else SynErr(165); #line 881 "Frames/cs.ATG" cd.Body = (BlockStatement)stmt; compilationUnit.AddChild(cd); } else if (la.kind == 70 || la.kind == 80) { #line 884 "Frames/cs.ATG" m.Check(Modifiers.Operators); if (m.isNone) Error("at least one modifier must be set"); bool isImplicit = true; Location startPos = Location.Empty; if (la.kind == 80) { lexer.NextToken(); #line 889 "Frames/cs.ATG" startPos = t.Location; } else { lexer.NextToken(); #line 889 "Frames/cs.ATG" isImplicit = false; startPos = t.Location; } Expect(92); Type( #line 890 "Frames/cs.ATG" out type); #line 890 "Frames/cs.ATG" TypeReference operatorType = type; Expect(20); Type( #line 891 "Frames/cs.ATG" out type); Identifier(); #line 891 "Frames/cs.ATG" string varName = t.val; Expect(21); #line 892 "Frames/cs.ATG" Location endPos = t.Location; if (la.kind == 16) { Block( #line 893 "Frames/cs.ATG" out stmt); } else if (la.kind == 11) { lexer.NextToken(); #line 893 "Frames/cs.ATG" stmt = null; } else SynErr(166); #line 896 "Frames/cs.ATG" List<ParameterDeclarationExpression> parameters = new List<ParameterDeclarationExpression>(); parameters.Add(new ParameterDeclarationExpression(type, varName)); OperatorDeclaration operatorDeclaration = new OperatorDeclaration { Name = (isImplicit ? "op_Implicit" : "op_Explicit"), Modifier = m.Modifier, Attributes = attributes, Parameters = parameters, TypeReference = operatorType, ConversionType = isImplicit ? ConversionType.Implicit : ConversionType.Explicit, Body = (BlockStatement)stmt, StartLocation = m.GetDeclarationLocation(startPos), EndLocation = endPos }; compilationUnit.AddChild(operatorDeclaration); } else if (StartOf(22)) { TypeDecl( #line 914 "Frames/cs.ATG" m, attributes); } else if (StartOf(10)) { Type( #line 916 "Frames/cs.ATG" out type); #line 916 "Frames/cs.ATG" Location startPos = t.Location; if (la.kind == 92) { #line 918 "Frames/cs.ATG" OverloadableOperatorType op; m.Check(Modifiers.Operators); if (m.isNone) Error("at least one modifier must be set"); lexer.NextToken(); OverloadableOperator( #line 922 "Frames/cs.ATG" out op); #line 922 "Frames/cs.ATG" TypeReference firstType, secondType = null; string secondName = null; Expect(20); Type( #line 923 "Frames/cs.ATG" out firstType); Identifier(); #line 923 "Frames/cs.ATG" string firstName = t.val; if (la.kind == 14) { lexer.NextToken(); Type( #line 924 "Frames/cs.ATG" out secondType); Identifier(); #line 924 "Frames/cs.ATG" secondName = t.val; } else if (la.kind == 21) { } else SynErr(167); #line 932 "Frames/cs.ATG" Location endPos = t.Location; Expect(21); if (la.kind == 16) { Block( #line 933 "Frames/cs.ATG" out stmt); } else if (la.kind == 11) { lexer.NextToken(); } else SynErr(168); #line 935 "Frames/cs.ATG" if (op == OverloadableOperatorType.Add && secondType == null) op = OverloadableOperatorType.UnaryPlus; if (op == OverloadableOperatorType.Subtract && secondType == null) op = OverloadableOperatorType.UnaryMinus; OperatorDeclaration operatorDeclaration = new OperatorDeclaration { Modifier = m.Modifier, Attributes = attributes, TypeReference = type, OverloadableOperator = op, Name = GetReflectionNameForOperator(op), Body = (BlockStatement)stmt, StartLocation = m.GetDeclarationLocation(startPos), EndLocation = endPos }; SafeAdd(operatorDeclaration, operatorDeclaration.Parameters, new ParameterDeclarationExpression(firstType, firstName)); if (secondType != null) { SafeAdd(operatorDeclaration, operatorDeclaration.Parameters, new ParameterDeclarationExpression(secondType, secondName)); } compilationUnit.AddChild(operatorDeclaration); } else if ( #line 957 "Frames/cs.ATG" IsVarDecl()) { #line 958 "Frames/cs.ATG" m.Check(Modifiers.Fields); FieldDeclaration fd = new FieldDeclaration(attributes, type, m.Modifier); fd.StartLocation = m.GetDeclarationLocation(startPos); if ( #line 962 "Frames/cs.ATG" m.Contains(Modifiers.Fixed)) { VariableDeclarator( #line 963 "Frames/cs.ATG" fd); Expect(18); Expr( #line 965 "Frames/cs.ATG" out expr); #line 965 "Frames/cs.ATG" if (fd.Fields.Count > 0) fd.Fields[fd.Fields.Count-1].FixedArrayInitialization = expr; Expect(19); while (la.kind == 14) { lexer.NextToken(); VariableDeclarator( #line 969 "Frames/cs.ATG" fd); Expect(18); Expr( #line 971 "Frames/cs.ATG" out expr); #line 971 "Frames/cs.ATG" if (fd.Fields.Count > 0) fd.Fields[fd.Fields.Count-1].FixedArrayInitialization = expr; Expect(19); } } else if (StartOf(19)) { VariableDeclarator( #line 976 "Frames/cs.ATG" fd); while (la.kind == 14) { lexer.NextToken(); VariableDeclarator( #line 977 "Frames/cs.ATG" fd); } } else SynErr(169); Expect(11); #line 979 "Frames/cs.ATG" fd.EndLocation = t.EndLocation; compilationUnit.AddChild(fd); } else if (la.kind == 111) { #line 982 "Frames/cs.ATG" m.Check(Modifiers.Indexers); lexer.NextToken(); Expect(18); FormalParameterList( #line 983 "Frames/cs.ATG" p); Expect(19); #line 983 "Frames/cs.ATG" Location endLocation = t.EndLocation; Expect(16); #line 984 "Frames/cs.ATG" IndexerDeclaration indexer = new IndexerDeclaration(type, p, m.Modifier, attributes); indexer.StartLocation = startPos; indexer.EndLocation = endLocation; indexer.BodyStart = t.Location; PropertyGetRegion getRegion; PropertySetRegion setRegion; AccessorDecls( #line 991 "Frames/cs.ATG" out getRegion, out setRegion); Expect(17); #line 992 "Frames/cs.ATG" indexer.BodyEnd = t.EndLocation; indexer.GetRegion = getRegion; indexer.SetRegion = setRegion; compilationUnit.AddChild(indexer); } else if ( #line 997 "Frames/cs.ATG" IsIdentifierToken(la)) { if ( #line 998 "Frames/cs.ATG" IsExplicitInterfaceImplementation()) { TypeName( #line 999 "Frames/cs.ATG" out explicitInterface, false); #line 1000 "Frames/cs.ATG" if (la.kind != Tokens.Dot || Peek(1).kind != Tokens.This) { qualident = TypeReference.StripLastIdentifierFromType(ref explicitInterface); } } else if (StartOf(19)) { Identifier(); #line 1003 "Frames/cs.ATG" qualident = t.val; } else SynErr(170); #line 1005 "Frames/cs.ATG" Location qualIdentEndLocation = t.EndLocation; if (la.kind == 16 || la.kind == 20 || la.kind == 23) { if (la.kind == 20 || la.kind == 23) { #line 1009 "Frames/cs.ATG" m.Check(Modifiers.PropertysEventsMethods); if (la.kind == 23) { TypeParameterList( #line 1011 "Frames/cs.ATG" templates); } Expect(20); if (la.kind == 111) { lexer.NextToken(); #line 1013 "Frames/cs.ATG" isExtensionMethod = true; } if (StartOf(11)) { FormalParameterList( #line 1014 "Frames/cs.ATG" p); } Expect(21); #line 1016 "Frames/cs.ATG" MethodDeclaration methodDeclaration = new MethodDeclaration { Name = qualident, Modifier = m.Modifier, TypeReference = type, Parameters = p, Attributes = attributes }; if (explicitInterface != null) methodDeclaration.InterfaceImplementations.Add(new InterfaceImplementation(explicitInterface, qualident)); methodDeclaration.StartLocation = m.GetDeclarationLocation(startPos); methodDeclaration.EndLocation = t.EndLocation; methodDeclaration.IsExtensionMethod = isExtensionMethod; methodDeclaration.Templates = templates; compilationUnit.AddChild(methodDeclaration); while (la.kind == 127) { TypeParameterConstraintsClause( #line 1031 "Frames/cs.ATG" templates); } if (la.kind == 16) { Block( #line 1032 "Frames/cs.ATG" out stmt); } else if (la.kind == 11) { lexer.NextToken(); } else SynErr(171); #line 1032 "Frames/cs.ATG" methodDeclaration.Body = (BlockStatement)stmt; } else { lexer.NextToken(); #line 1035 "Frames/cs.ATG" PropertyDeclaration pDecl = new PropertyDeclaration(qualident, type, m.Modifier, attributes); if (explicitInterface != null) pDecl.InterfaceImplementations.Add(new InterfaceImplementation(explicitInterface, qualident)); pDecl.StartLocation = m.GetDeclarationLocation(startPos); pDecl.EndLocation = qualIdentEndLocation; pDecl.BodyStart = t.Location; PropertyGetRegion getRegion; PropertySetRegion setRegion; AccessorDecls( #line 1044 "Frames/cs.ATG" out getRegion, out setRegion); Expect(17); #line 1046 "Frames/cs.ATG" pDecl.GetRegion = getRegion; pDecl.SetRegion = setRegion; pDecl.BodyEnd = t.EndLocation; compilationUnit.AddChild(pDecl); } } else if (la.kind == 15) { #line 1054 "Frames/cs.ATG" m.Check(Modifiers.Indexers); lexer.NextToken(); Expect(111); Expect(18); FormalParameterList( #line 1055 "Frames/cs.ATG" p); Expect(19); #line 1056 "Frames/cs.ATG" IndexerDeclaration indexer = new IndexerDeclaration(type, p, m.Modifier, attributes); indexer.StartLocation = m.GetDeclarationLocation(startPos); indexer.EndLocation = t.EndLocation; if (explicitInterface != null) SafeAdd(indexer, indexer.InterfaceImplementations, new InterfaceImplementation(explicitInterface, "this")); PropertyGetRegion getRegion; PropertySetRegion setRegion; Expect(16); #line 1064 "Frames/cs.ATG" Location bodyStart = t.Location; AccessorDecls( #line 1065 "Frames/cs.ATG" out getRegion, out setRegion); Expect(17); #line 1066 "Frames/cs.ATG" indexer.BodyStart = bodyStart; indexer.BodyEnd = t.EndLocation; indexer.GetRegion = getRegion; indexer.SetRegion = setRegion; compilationUnit.AddChild(indexer); } else SynErr(172); } else SynErr(173); } else SynErr(174); }
void TypeDecl( #line 362 "Frames/cs.ATG" ModifierList m, List<AttributeSection> attributes) { #line 364 "Frames/cs.ATG" TypeReference type; List<TypeReference> names; List<ParameterDeclarationExpression> p = new List<ParameterDeclarationExpression>(); string name; List<TemplateDefinition> templates; if (la.kind == 59) { #line 370 "Frames/cs.ATG" m.Check(Modifiers.Classes); lexer.NextToken(); #line 371 "Frames/cs.ATG" TypeDeclaration newType = new TypeDeclaration(m.Modifier, attributes); templates = newType.Templates; compilationUnit.AddChild(newType); compilationUnit.BlockStart(newType); newType.StartLocation = m.GetDeclarationLocation(t.Location); newType.Type = Types.Class; Identifier(); #line 379 "Frames/cs.ATG" newType.Name = t.val; if (la.kind == 23) { TypeParameterList( #line 382 "Frames/cs.ATG" templates); } if (la.kind == 9) { ClassBase( #line 384 "Frames/cs.ATG" out names); #line 384 "Frames/cs.ATG" newType.BaseTypes = names; } while (la.kind == 127) { TypeParameterConstraintsClause( #line 387 "Frames/cs.ATG" templates); } #line 389 "Frames/cs.ATG" newType.BodyStartLocation = t.EndLocation; Expect(16); ClassBody(); Expect(17); if (la.kind == 11) { lexer.NextToken(); } #line 393 "Frames/cs.ATG" newType.EndLocation = t.EndLocation; compilationUnit.BlockEnd(); } else if (StartOf(9)) { #line 396 "Frames/cs.ATG" m.Check(Modifiers.StructsInterfacesEnumsDelegates); if (la.kind == 109) { lexer.NextToken(); #line 397 "Frames/cs.ATG" TypeDeclaration newType = new TypeDeclaration(m.Modifier, attributes); templates = newType.Templates; newType.StartLocation = m.GetDeclarationLocation(t.Location); compilationUnit.AddChild(newType); compilationUnit.BlockStart(newType); newType.Type = Types.Struct; Identifier(); #line 404 "Frames/cs.ATG" newType.Name = t.val; if (la.kind == 23) { TypeParameterList( #line 407 "Frames/cs.ATG" templates); } if (la.kind == 9) { StructInterfaces( #line 409 "Frames/cs.ATG" out names); #line 409 "Frames/cs.ATG" newType.BaseTypes = names; } while (la.kind == 127) { TypeParameterConstraintsClause( #line 412 "Frames/cs.ATG" templates); } #line 415 "Frames/cs.ATG" newType.BodyStartLocation = t.EndLocation; StructBody(); if (la.kind == 11) { lexer.NextToken(); } #line 417 "Frames/cs.ATG" newType.EndLocation = t.EndLocation; compilationUnit.BlockEnd(); } else if (la.kind == 83) { lexer.NextToken(); #line 421 "Frames/cs.ATG" TypeDeclaration newType = new TypeDeclaration(m.Modifier, attributes); templates = newType.Templates; compilationUnit.AddChild(newType); compilationUnit.BlockStart(newType); newType.StartLocation = m.GetDeclarationLocation(t.Location); newType.Type = Types.Interface; Identifier(); #line 428 "Frames/cs.ATG" newType.Name = t.val; if (la.kind == 23) { TypeParameterList( #line 431 "Frames/cs.ATG" templates); } if (la.kind == 9) { InterfaceBase( #line 433 "Frames/cs.ATG" out names); #line 433 "Frames/cs.ATG" newType.BaseTypes = names; } while (la.kind == 127) { TypeParameterConstraintsClause( #line 436 "Frames/cs.ATG" templates); } #line 438 "Frames/cs.ATG" newType.BodyStartLocation = t.EndLocation; InterfaceBody(); if (la.kind == 11) { lexer.NextToken(); } #line 440 "Frames/cs.ATG" newType.EndLocation = t.EndLocation; compilationUnit.BlockEnd(); } else if (la.kind == 68) { lexer.NextToken(); #line 444 "Frames/cs.ATG" TypeDeclaration newType = new TypeDeclaration(m.Modifier, attributes); compilationUnit.AddChild(newType); compilationUnit.BlockStart(newType); newType.StartLocation = m.GetDeclarationLocation(t.Location); newType.Type = Types.Enum; Identifier(); #line 450 "Frames/cs.ATG" newType.Name = t.val; if (la.kind == 9) { lexer.NextToken(); IntegralType( #line 451 "Frames/cs.ATG" out name); #line 451 "Frames/cs.ATG" newType.BaseTypes.Add(new TypeReference(name, true)); } #line 453 "Frames/cs.ATG" newType.BodyStartLocation = t.EndLocation; EnumBody(); if (la.kind == 11) { lexer.NextToken(); } #line 455 "Frames/cs.ATG" newType.EndLocation = t.EndLocation; compilationUnit.BlockEnd(); } else { lexer.NextToken(); #line 459 "Frames/cs.ATG" DelegateDeclaration delegateDeclr = new DelegateDeclaration(m.Modifier, attributes); templates = delegateDeclr.Templates; delegateDeclr.StartLocation = m.GetDeclarationLocation(t.Location); if ( #line 463 "Frames/cs.ATG" NotVoidPointer()) { Expect(123); #line 463 "Frames/cs.ATG" delegateDeclr.ReturnType = new TypeReference("System.Void", true); } else if (StartOf(10)) { Type( #line 464 "Frames/cs.ATG" out type); #line 464 "Frames/cs.ATG" delegateDeclr.ReturnType = type; } else SynErr(152); Identifier(); #line 466 "Frames/cs.ATG" delegateDeclr.Name = t.val; if (la.kind == 23) { TypeParameterList( #line 469 "Frames/cs.ATG" templates); } Expect(20); if (StartOf(11)) { FormalParameterList( #line 471 "Frames/cs.ATG" p); #line 471 "Frames/cs.ATG" delegateDeclr.Parameters = p; } Expect(21); while (la.kind == 127) { TypeParameterConstraintsClause( #line 475 "Frames/cs.ATG" templates); } Expect(11); #line 477 "Frames/cs.ATG" delegateDeclr.EndLocation = t.EndLocation; compilationUnit.AddChild(delegateDeclr); } } else SynErr(153); }
void ClassMemberDecl( #line 1076 "Frames/cs.ATG" ModifierList m, List<AttributeSection> attributes) { #line 1077 "Frames/cs.ATG" Statement stmt = null; if (StartOf(21)) { StructMemberDecl( #line 1079 "Frames/cs.ATG" m, attributes); } else if (la.kind == 27) { #line 1080 "Frames/cs.ATG" m.Check(Modifiers.Destructors); Location startPos = la.Location; lexer.NextToken(); Identifier(); #line 1081 "Frames/cs.ATG" DestructorDeclaration d = new DestructorDeclaration(t.val, m.Modifier, attributes); d.Modifier = m.Modifier; d.StartLocation = m.GetDeclarationLocation(startPos); Expect(20); Expect(21); #line 1085 "Frames/cs.ATG" d.EndLocation = t.EndLocation; if (la.kind == 16) { Block( #line 1085 "Frames/cs.ATG" out stmt); } else if (la.kind == 11) { lexer.NextToken(); } else SynErr(160); #line 1086 "Frames/cs.ATG" d.Body = (BlockStatement)stmt; compilationUnit.AddChild(d); } else SynErr(161); }