blob: 9558998888588e6f012f8f7bde9e893c5bad40b1 [file] [log] [blame]
John Kessenich9c86c6a2016-05-03 22:49:24 -06001//
John Kessenich927608b2017-01-06 12:34:14 -07002// Copyright (C) 2016 Google, Inc.
John Kessenich9c86c6a2016-05-03 22:49:24 -06003//
John Kessenich927608b2017-01-06 12:34:14 -07004// All rights reserved.
John Kessenich9c86c6a2016-05-03 22:49:24 -06005//
John Kessenich927608b2017-01-06 12:34:14 -07006// Redistribution and use in source and binary forms, with or without
7// modification, are permitted provided that the following conditions
8// are met:
John Kessenich9c86c6a2016-05-03 22:49:24 -06009//
10// Redistributions of source code must retain the above copyright
11// notice, this list of conditions and the following disclaimer.
12//
13// Redistributions in binary form must reproduce the above
14// copyright notice, this list of conditions and the following
15// disclaimer in the documentation and/or other materials provided
16// with the distribution.
17//
18// Neither the name of Google, Inc., nor the names of its
19// contributors may be used to endorse or promote products derived
20// from this software without specific prior written permission.
21//
John Kessenich927608b2017-01-06 12:34:14 -070022// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
25// FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
26// COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
27// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
28// BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
29// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
30// CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31// LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
32// ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33// POSSIBILITY OF SUCH DAMAGE.
John Kessenich9c86c6a2016-05-03 22:49:24 -060034//
35
36#ifndef HLSLTOKENSTREAM_H_
37#define HLSLTOKENSTREAM_H_
38
39#include "hlslScanContext.h"
40
41namespace glslang {
42
43 class HlslTokenStream {
44 public:
John Kessenich34fb0362016-05-03 23:17:20 -060045 explicit HlslTokenStream(HlslScanContext& scanner)
steve-lunarg5964c642016-07-30 07:38:55 -060046 : scanner(scanner), preTokenStackSize(0), tokenBufferPos(0) { }
John Kessenich9c86c6a2016-05-03 22:49:24 -060047 virtual ~HlslTokenStream() { }
48
49 public:
50 void advanceToken();
John Kessenich1cc1a282016-06-03 16:55:49 -060051 void recedeToken();
John Kessenich9c86c6a2016-05-03 22:49:24 -060052 bool acceptTokenClass(EHlslTokenClass);
53 EHlslTokenClass peek() const;
54 bool peekTokenClass(EHlslTokenClass) const;
55
56 protected:
John Kessenich1cc1a282016-06-03 16:55:49 -060057 HlslToken token; // the token we are currently looking at, but have not yet accepted
58
John Kessenich9c86c6a2016-05-03 22:49:24 -060059 private:
John Kessenich7f349c72016-07-08 22:09:10 -060060 HlslTokenStream();
61 HlslTokenStream& operator=(const HlslTokenStream&);
62
John Kessenich1cc1a282016-06-03 16:55:49 -060063 HlslScanContext& scanner; // lexical scanner, to get next token
64
steve-lunarg5964c642016-07-30 07:38:55 -060065 // This is the number of tokens we can recedeToken() over.
66 static const int tokenBufferSize = 2;
67
John Kessenich1cc1a282016-06-03 16:55:49 -060068 // Previously scanned tokens, returned for future advances,
69 // so logically in front of the token stream.
70 // Is logically a stack; needs last in last out semantics.
steve-lunarg5964c642016-07-30 07:38:55 -060071 // Currently implemented as a stack of size 2.
72 HlslToken preTokenStack[tokenBufferSize];
John Kessenich1cc1a282016-06-03 16:55:49 -060073 int preTokenStackSize;
74 void pushPreToken(const HlslToken&);
75 HlslToken popPreToken();
76
steve-lunarg5964c642016-07-30 07:38:55 -060077 // Previously scanned tokens, not yet returned for future advances,
John Kessenich1cc1a282016-06-03 16:55:49 -060078 // but available for that.
79 // Is logically a fifo for normal advances, and a stack for recession.
steve-lunarg5964c642016-07-30 07:38:55 -060080 // Currently implemented with an intrinsic size of 2.
81 HlslToken tokenBuffer[tokenBufferSize];
82 int tokenBufferPos;
John Kessenich1cc1a282016-06-03 16:55:49 -060083 void pushTokenBuffer(const HlslToken&);
84 HlslToken popTokenBuffer();
John Kessenich9c86c6a2016-05-03 22:49:24 -060085 };
86
87} // end namespace glslang
88
89#endif // HLSLTOKENSTREAM_H_