1 // Copyright 2004-2007 Castle Project - http://www.castleproject.org/
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
7 // http://www.apache.org/licenses/LICENSE-2.0
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
18 using System
.Collections
;
20 public class BreadthFirstWalker
: ITreeWalker
22 public void Walk(Folder folder
, Anakia
.Act act
)
24 Queue queue
= new Queue();
26 queue
.Enqueue(folder
);
28 WalkQueue(queue
, act
);
31 private void WalkQueue(Queue queue
, Act act
)
33 while(queue
.Count
!= 0)
35 Folder node
= (Folder
) queue
.Dequeue();
37 foreach(DocumentNode n
in node
.Documents
)
42 foreach(Folder child
in node
.Folders
)