• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1//
2//  ANTLRStreamEnumertor.m
3//  ANTLR
4//
5//  Created by Ian Michell on 29/04/2010.
6// [The "BSD licence"]
7// Copyright (c) 2010 Ian Michell 2010 Alan Condit
8// All rights reserved.
9//
10// Redistribution and use in source and binary forms, with or without
11// modification, are permitted provided that the following conditions
12// are met:
13// 1. Redistributions of source code must retain the above copyright
14//    notice, this list of conditions and the following disclaimer.
15// 2. Redistributions in binary form must reproduce the above copyright
16//    notice, this list of conditions and the following disclaimer in the
17//    documentation and/or other materials provided with the distribution.
18// 3. The name of the author may not be used to endorse or promote products
19//    derived from this software without specific prior written permission.
20//
21// THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
22// IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
23// OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
24// IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
25// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
26// NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
30// THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31
32#import "ANTLRStreamEnumerator.h"
33
34
35@implementation ANTLRStreamEnumerator
36
37-(id) init
38{
39	self = [super init];
40	if (self)
41	{
42		i = 0;
43	}
44	return self;
45}
46
47-(id) initWithNodes:(AMutableArray *) n andEOF:(id) obj
48{
49	self = [self init];
50	if (self)
51	{
52		nodes = n;
53		eof = obj;
54	}
55	return self;
56}
57
58-(BOOL) hasNext
59{
60	return i < [nodes count];
61}
62
63-(id) nextObject
64{
65	NSUInteger current = i;
66	i++;
67	if (current < [nodes count])
68	{
69		return [nodes objectAtIndex:current];
70	}
71	return eof;
72}
73
74@synthesize i;
75@synthesize eof;
76@synthesize nodes;
77@end
78