blob: cb6c9e7234fecf23c8069c30c8f6770aefc1523f [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;
John Kessenich2dd643f2017-03-14 21:50:06 -060055 glslang::TBuiltInVariable mapSemantic(const char* upperCase) { return scanner.mapSemantic(upperCase); }
John Kessenich9c86c6a2016-05-03 22:49:24 -060056
John Kessenichb16f7e62017-03-11 19:32:47 -070057 void pushTokenStream(const TVector<HlslToken>* tokens);
58 void popTokenStream();
59
John Kessenich9c86c6a2016-05-03 22:49:24 -060060 protected:
John Kessenich1cc1a282016-06-03 16:55:49 -060061 HlslToken token; // the token we are currently looking at, but have not yet accepted
62
John Kessenich9c86c6a2016-05-03 22:49:24 -060063 private:
John Kessenich7f349c72016-07-08 22:09:10 -060064 HlslTokenStream();
65 HlslTokenStream& operator=(const HlslTokenStream&);
66
John Kessenichb16f7e62017-03-11 19:32:47 -070067 HlslScanContext& scanner; // lexical scanner, to get next token from source file
68 TVector<const TVector<HlslToken>*> tokenStreamStack; // for getting the next token from an existing vector of tokens
69 TVector<int> tokenPosition;
70 TVector<HlslToken> currentTokenStack;
John Kessenich1cc1a282016-06-03 16:55:49 -060071
steve-lunarg5964c642016-07-30 07:38:55 -060072 // This is the number of tokens we can recedeToken() over.
73 static const int tokenBufferSize = 2;
74
John Kessenich1cc1a282016-06-03 16:55:49 -060075 // Previously scanned tokens, returned for future advances,
76 // so logically in front of the token stream.
77 // Is logically a stack; needs last in last out semantics.
steve-lunarg5964c642016-07-30 07:38:55 -060078 // Currently implemented as a stack of size 2.
79 HlslToken preTokenStack[tokenBufferSize];
John Kessenich1cc1a282016-06-03 16:55:49 -060080 int preTokenStackSize;
81 void pushPreToken(const HlslToken&);
82 HlslToken popPreToken();
83
steve-lunarg5964c642016-07-30 07:38:55 -060084 // Previously scanned tokens, not yet returned for future advances,
John Kessenich1cc1a282016-06-03 16:55:49 -060085 // but available for that.
86 // Is logically a fifo for normal advances, and a stack for recession.
steve-lunarg5964c642016-07-30 07:38:55 -060087 // Currently implemented with an intrinsic size of 2.
88 HlslToken tokenBuffer[tokenBufferSize];
89 int tokenBufferPos;
John Kessenich1cc1a282016-06-03 16:55:49 -060090 void pushTokenBuffer(const HlslToken&);
91 HlslToken popTokenBuffer();
John Kessenich9c86c6a2016-05-03 22:49:24 -060092 };
93
94} // end namespace glslang
95
96#endif // HLSLTOKENSTREAM_H_