hlslTokenStream.h 3.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. //
  2. // Copyright (C) 2016 Google, Inc.
  3. //
  4. // All rights reserved.
  5. //
  6. // Redistribution and use in source and binary forms, with or without
  7. // modification, are permitted provided that the following conditions
  8. // are met:
  9. //
  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. //
  22. // 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.
  34. //
  35. #ifndef HLSLTOKENSTREAM_H_
  36. #define HLSLTOKENSTREAM_H_
  37. #include "hlslScanContext.h"
  38. namespace glslang {
  39. class HlslTokenStream {
  40. public:
  41. explicit HlslTokenStream(HlslScanContext& scanner)
  42. : scanner(scanner), preTokenStackSize(0), tokenBufferPos(0) { }
  43. virtual ~HlslTokenStream() { }
  44. public:
  45. void advanceToken();
  46. void recedeToken();
  47. bool acceptTokenClass(EHlslTokenClass);
  48. EHlslTokenClass peek() const;
  49. bool peekTokenClass(EHlslTokenClass) const;
  50. glslang::TBuiltInVariable mapSemantic(const char* upperCase) { return scanner.mapSemantic(upperCase); }
  51. void pushTokenStream(const TVector<HlslToken>* tokens);
  52. void popTokenStream();
  53. protected:
  54. HlslToken token; // the token we are currently looking at, but have not yet accepted
  55. private:
  56. HlslTokenStream();
  57. HlslTokenStream& operator=(const HlslTokenStream&);
  58. HlslScanContext& scanner; // lexical scanner, to get next token from source file
  59. TVector<const TVector<HlslToken>*> tokenStreamStack; // for getting the next token from an existing vector of tokens
  60. TVector<int> tokenPosition;
  61. TVector<HlslToken> currentTokenStack;
  62. // This is the number of tokens we can recedeToken() over.
  63. static const int tokenBufferSize = 2;
  64. // Previously scanned tokens, returned for future advances,
  65. // so logically in front of the token stream.
  66. // Is logically a stack; needs last in last out semantics.
  67. // Currently implemented as a stack of size 2.
  68. HlslToken preTokenStack[tokenBufferSize];
  69. int preTokenStackSize;
  70. void pushPreToken(const HlslToken&);
  71. HlslToken popPreToken();
  72. // Previously scanned tokens, not yet returned for future advances,
  73. // but available for that.
  74. // Is logically a fifo for normal advances, and a stack for recession.
  75. // Currently implemented with an intrinsic size of 2.
  76. HlslToken tokenBuffer[tokenBufferSize];
  77. int tokenBufferPos;
  78. void pushTokenBuffer(const HlslToken&);
  79. HlslToken popTokenBuffer();
  80. };
  81. } // end namespace glslang
  82. #endif // HLSLTOKENSTREAM_H_