You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			54 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
		
		
			
		
	
	
			54 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
|   | //--------------------------------------------------------------------- | |||
|  | // <copyright file="NodeCounter.cs" company="Microsoft"> | |||
|  | //      Copyright (c) Microsoft Corporation.  All rights reserved. | |||
|  | // </copyright> | |||
|  | // | |||
|  | // @owner  [....] | |||
|  | // @backupOwner [....] | |||
|  | //--------------------------------------------------------------------- | |||
|  | 
 | |||
|  | using System; | |||
|  | using System.Collections.Generic; | |||
|  | using System.Globalization; | |||
|  | using System.Diagnostics; | |||
|  | using System.Data.Common; | |||
|  | using md=System.Data.Metadata.Edm; | |||
|  | 
 | |||
|  | namespace System.Data.Query.InternalTrees | |||
|  | { | |||
|  |     /// <summary> | |||
|  |     /// Counts the number of nodes in a tree | |||
|  |     /// </summary> | |||
|  |     internal class NodeCounter : BasicOpVisitorOfT<int> | |||
|  |     { | |||
|  |         /// <summary> | |||
|  |         /// Public entry point - Calculates the nubmer of nodes in the given subTree | |||
|  |         /// </summary> | |||
|  |         /// <param name="subTree"></param> | |||
|  |         /// <returns></returns> | |||
|  |         internal static int Count(Node subTree) | |||
|  |         { | |||
|  |             NodeCounter counter = new NodeCounter(); | |||
|  |             return counter.VisitNode(subTree); | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Common processing for all node types | |||
|  |         /// Count = 1 (self) + count of children | |||
|  |         /// </summary> | |||
|  |         /// <param name="n"></param> | |||
|  |         /// <returns></returns> | |||
|  |         protected override int VisitDefault(Node n) | |||
|  |         { | |||
|  |             int count = 1; | |||
|  |             foreach (Node child in n.Children) | |||
|  |             { | |||
|  |                 count += VisitNode(child); | |||
|  |             } | |||
|  |             return count; | |||
|  |         } | |||
|  |     } | |||
|  | } | |||
|  | 
 | |||
|  | 
 |