-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathANTLRCharQueue.h
67 lines (52 loc) · 2.49 KB
/
ANTLRCharQueue.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
/* CharQueue.h
Copyright (C) 1998, 1999 Helge Hess and Manuel Guesdon
All rights reserved.
Authors: Helge Hess <[email protected]>
Manuel Guesdon <[email protected]>
This file is part of the ANTLR Objective-C Library.
Permission to use, copy, modify, and distribute this software and its
documentation for any purpose and without fee is hereby granted, provided
that the above copyright notice appear in all copies and that both that
copyright notice and this permission notice appear in supporting
documentation.
We disclaim all warranties with regard to this software, including all
implied warranties of merchantability and fitness, in no event shall
we be liable for any special, indirect or consequential damages or any
damages whatsoever resulting from loss of use, data or profits, whether in
an action of contract, negligence or other tortious action, arising out of
or in connection with the use or performance of this software.
---------------------------------------------------------------------------
This code is based on ANTLR toolkit (http://www.antlr.org)
from MageLang Institute:
"We encourage users to develop software with ANTLR. However,
we do ask that credit is given to us for developing
ANTLR. By "credit", we mean that if you use ANTLR or
incorporate any source code into one of your programs
(commercial product, research project, or otherwise) that
you acknowledge this fact somewhere in the documentation,
research report, etc... If you like ANTLR and have
developed a nice tool with the output, please mention that
you developed it using ANTLR."
*/
#ifndef _ANTLRCharQueue_h_
#define _ANTLRCharQueue_h_
@interface ANTLRCharQueue : NSObject // final
{
unichar *buffer; // Physical circular buffer of characters
int bufLen;
int sizeLessOne; // bufLen-1 for quick modulous
int offset; // physical index of front token
@public // performance critical, used in ANTLRCharBuffer*
unsigned int count; // number of characters in the queue
}
+(id)charQueueWithCapacity:(unsigned)_capacity;
-(id)initWithCapacity:(unsigned)_capacity;
-(void)append:(unichar)_token; // Add token to end of the queue
-(void)removeFirst; // Remove token from front of queue
// Fetch a token from the queue by index
// @param idx The index of the token to fetch, where zero is the token at
// the front of the queue
-(unichar)elementAt:(int)_idx;
-(unsigned int)count;
@end
#endif //_ANTLRCharQueue_h_