From: "Gao, Liming" <liming.gao@intel.com>
To: "Feng, Bob C" <bob.c.feng@intel.com>,
"edk2-devel@lists.01.org" <edk2-devel@lists.01.org>
Subject: Re: [Patch v2 33/33] BaseTools: Eot tool Python3 adaption
Date: Mon, 28 Jan 2019 11:36:47 +0000 [thread overview]
Message-ID: <4A89E2EF3DFEDB4C8BFDE51014F606A14E3D166B@SHSMSX104.ccr.corp.intel.com> (raw)
In-Reply-To: <20190128103152.18436-1-bob.c.feng@intel.com>
Bob:
Could you add notes for Patch v2?
> -----Original Message-----
> From: Feng, Bob C
> Sent: Monday, January 28, 2019 6:32 PM
> To: edk2-devel@lists.01.org
> Cc: Feng, Bob C <bob.c.feng@intel.com>; Gao, Liming <liming.gao@intel.com>
> Subject: [Patch v2 33/33] BaseTools: Eot tool Python3 adaption
>
> Eot tool Python3 adaption.
>
> Contributed-under: TianoCore Contribution Agreement 1.1
> Signed-off-by: Bob Feng <bob.c.feng@intel.com>
> Cc: Liming Gao <liming.gao@intel.com>
> ---
> BaseTools/Source/Python/Eot/{ => CParser3}/CLexer.py | 0
> BaseTools/Source/Python/Eot/{ => CParser3}/CParser.py | 0
> BaseTools/Source/Python/Eot/CParser3/__init__.py | 0
> BaseTools/Source/Python/Eot/CParser4/CLexer.py | 633
> +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
> BaseTools/Source/Python/Eot/CParser4/CListener.py | 814
> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
> ++++
> BaseTools/Source/Python/Eot/CParser4/CParser.py | 6279
> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
> +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
> BaseTools/Source/Python/Eot/CParser4/__init__.py | 0
> BaseTools/Source/Python/Eot/CodeFragmentCollector.py | 22 ++--
> 8 files changed, 7740 insertions(+), 8 deletions(-)
>
> diff --git a/BaseTools/Source/Python/Eot/CLexer.py b/BaseTools/Source/Python/Eot/CParser3/CLexer.py
> similarity index 100%
> rename from BaseTools/Source/Python/Eot/CLexer.py
> rename to BaseTools/Source/Python/Eot/CParser3/CLexer.py
> diff --git a/BaseTools/Source/Python/Eot/CParser.py b/BaseTools/Source/Python/Eot/CParser3/CParser.py
> similarity index 100%
> rename from BaseTools/Source/Python/Eot/CParser.py
> rename to BaseTools/Source/Python/Eot/CParser3/CParser.py
> diff --git a/BaseTools/Source/Python/Eot/CParser3/__init__.py b/BaseTools/Source/Python/Eot/CParser3/__init__.py
> new file mode 100644
> index 0000000000..e69de29bb2
> diff --git a/BaseTools/Source/Python/Eot/CParser4/CLexer.py b/BaseTools/Source/Python/Eot/CParser4/CLexer.py
> new file mode 100644
> index 0000000000..5bc32cd7cb
> --- /dev/null
> +++ b/BaseTools/Source/Python/Eot/CParser4/CLexer.py
> @@ -0,0 +1,633 @@
> +# Generated from C.g4 by ANTLR 4.7.1
>
> +from antlr4 import *
>
> +from io import StringIO
>
> +from typing.io import TextIO
>
> +import sys
>
> +
>
> +
>
> +## @file
>
> +# The file defines the parser for C source files.
>
> +#
>
> +# THIS FILE IS AUTO-GENENERATED. PLEASE DON NOT MODIFY THIS FILE.
>
> +# This file is generated by running:
>
> +# java org.antlr.Tool C.g
>
> +#
>
> +# Copyright (c) 2009 - 2010, Intel Corporation All rights reserved.
>
> +#
>
> +# This program and the accompanying materials are licensed and made available
>
> +# under the terms and conditions of the BSD License which accompanies this
>
> +# distribution. The full text of the license may be found at:
>
> +# http://opensource.org/licenses/bsd-license.php
>
> +#
>
> +# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
>
> +# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
>
> +#
>
> +##
>
> +
>
> +import Ecc.CodeFragment as CodeFragment
>
> +import Ecc.FileProfile as FileProfile
>
> +
>
> +
>
> +def serializedATN():
>
> + with StringIO() as buf:
>
> + buf.write("\3\u608b\ua72a\u8133\ub9ed\u417c\u3be7\u7786\u5964\2k")
>
> + buf.write("\u0383\b\1\4\2\t\2\4\3\t\3\4\4\t\4\4\5\t\5\4\6\t\6\4\7")
>
> + buf.write("\t\7\4\b\t\b\4\t\t\t\4\n\t\n\4\13\t\13\4\f\t\f\4\r\t\r")
>
> + buf.write("\4\16\t\16\4\17\t\17\4\20\t\20\4\21\t\21\4\22\t\22\4\23")
>
> + buf.write("\t\23\4\24\t\24\4\25\t\25\4\26\t\26\4\27\t\27\4\30\t\30")
>
> + buf.write("\4\31\t\31\4\32\t\32\4\33\t\33\4\34\t\34\4\35\t\35\4\36")
>
> + buf.write("\t\36\4\37\t\37\4 \t \4!\t!\4\"\t\"\4#\t#\4$\t$\4%\t%")
>
> + buf.write("\4&\t&\4\'\t\'\4(\t(\4)\t)\4*\t*\4+\t+\4,\t,\4-\t-\4.")
>
> + buf.write("\t.\4/\t/\4\60\t\60\4\61\t\61\4\62\t\62\4\63\t\63\4\64")
>
> + buf.write("\t\64\4\65\t\65\4\66\t\66\4\67\t\67\48\t8\49\t9\4:\t:")
>
> + buf.write("\4;\t;\4<\t<\4=\t=\4>\t>\4?\t?\4@\t@\4A\tA\4B\tB\4C\t")
>
> + buf.write("C\4D\tD\4E\tE\4F\tF\4G\tG\4H\tH\4I\tI\4J\tJ\4K\tK\4L\t")
>
> + buf.write("L\4M\tM\4N\tN\4O\tO\4P\tP\4Q\tQ\4R\tR\4S\tS\4T\tT\4U\t")
>
> + buf.write("U\4V\tV\4W\tW\4X\tX\4Y\tY\4Z\tZ\4[\t[\4\\\t\\\4]\t]\4")
>
> + buf.write("^\t^\4_\t_\4`\t`\4a\ta\4b\tb\4c\tc\4d\td\4e\te\4f\tf\4")
>
> + buf.write("g\tg\4h\th\4i\ti\4j\tj\4k\tk\4l\tl\4m\tm\4n\tn\4o\to\4")
>
> + buf.write("p\tp\4q\tq\4r\tr\3\2\3\2\3\3\3\3\3\4\3\4\3\4\3\4\3\4\3")
>
> + buf.write("\4\3\4\3\4\3\5\3\5\3\6\3\6\3\7\3\7\3\7\3\7\3\7\3\7\3\7")
>
> + buf.write("\3\b\3\b\3\b\3\b\3\b\3\b\3\b\3\t\3\t\3\t\3\t\3\t\3\n\3")
>
> + buf.write("\n\3\n\3\n\3\n\3\n\3\n\3\n\3\n\3\13\3\13\3\13\3\13\3\13")
>
> + buf.write("\3\13\3\13\3\f\3\f\3\f\3\f\3\f\3\r\3\r\3\r\3\r\3\r\3\16")
>
> + buf.write("\3\16\3\16\3\16\3\16\3\16\3\17\3\17\3\17\3\17\3\20\3\20")
>
> + buf.write("\3\20\3\20\3\20\3\21\3\21\3\21\3\21\3\21\3\21\3\22\3\22")
>
> + buf.write("\3\22\3\22\3\22\3\22\3\22\3\23\3\23\3\23\3\23\3\23\3\23")
>
> + buf.write("\3\23\3\24\3\24\3\24\3\24\3\24\3\24\3\24\3\24\3\24\3\25")
>
> + buf.write("\3\25\3\26\3\26\3\26\3\26\3\26\3\26\3\26\3\27\3\27\3\27")
>
> + buf.write("\3\27\3\27\3\27\3\30\3\30\3\31\3\31\3\31\3\31\3\31\3\32")
>
> + buf.write("\3\32\3\32\3\32\3\32\3\32\3\33\3\33\3\33\3\33\3\33\3\33")
>
> + buf.write("\3\33\3\33\3\33\3\34\3\34\3\34\3\35\3\35\3\35\3\35\3\36")
>
> + buf.write("\3\36\3\36\3\36\3\36\3\36\3\36\3\36\3\36\3\37\3\37\3\37")
>
> + buf.write("\3\37\3\37\3\37\3 \3 \3 \3 \3 \3 \3 \3 \3 \3 \3!\3!\3")
>
> + buf.write("!\3!\3!\3!\3!\3!\3!\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3")
>
> + buf.write("\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"")
>
> + buf.write("\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3#\3#\3#\3#\3#\3#\3#")
>
> + buf.write("\3$\3$\3$\3$\3$\3$\3$\3$\3$\3$\3$\3$\3$\3$\3$\3$\3%\3")
>
> + buf.write("%\3%\3%\3%\3%\3%\3%\3%\3%\3%\3%\3%\3%\3%\3%\3%\3%\3%\3")
>
> + buf.write("&\3&\3&\3&\3&\3&\3&\3\'\3\'\3(\3(\3)\3)\3*\3*\3+\3+\3")
>
> + buf.write(",\3,\3,\3,\3-\3-\3.\3.\3/\3/\3\60\3\60\3\61\3\61\3\61")
>
> + buf.write("\3\62\3\62\3\62\3\63\3\63\3\63\3\63\3\63\3\63\3\63\3\64")
>
> + buf.write("\3\64\3\65\3\65\3\65\3\66\3\66\3\67\3\67\38\38\39\39\3")
>
> + buf.write("9\3:\3:\3:\3;\3;\3;\3<\3<\3<\3=\3=\3=\3>\3>\3>\3>\3?\3")
>
> + buf.write("?\3?\3?\3@\3@\3@\3A\3A\3A\3B\3B\3B\3C\3C\3D\3D\3D\3E\3")
>
> + buf.write("E\3E\3F\3F\3G\3G\3H\3H\3H\3I\3I\3I\3J\3J\3K\3K\3L\3L\3")
>
> + buf.write("L\3M\3M\3M\3N\3N\3N\3O\3O\3O\3P\3P\3P\3P\3P\3P\3P\3P\3")
>
> + buf.write("Q\3Q\3Q\3Q\3Q\3R\3R\3R\3R\3R\3R\3S\3S\3S\3S\3S\3T\3T\3")
>
> + buf.write("T\3T\3T\3T\3T\3T\3U\3U\3U\3V\3V\3V\3V\3V\3W\3W\3W\3W\3")
>
> + buf.write("W\3W\3W\3X\3X\3X\3X\3X\3X\3Y\3Y\3Y\3Z\3Z\3Z\3Z\3Z\3[\3")
>
> + buf.write("[\3[\3[\3[\3[\3[\3[\3[\3\\\3\\\3\\\3\\\3\\\3\\\3]\3]\3")
>
> + buf.write("]\3]\3]\3]\3]\3^\3^\3^\7^\u02b2\n^\f^\16^\u02b5\13^\3")
>
> + buf.write("_\3_\3`\5`\u02ba\n`\3`\3`\3`\5`\u02bf\n`\3`\3`\3a\5a\u02c4")
>
> + buf.write("\na\3a\3a\3a\7a\u02c9\na\fa\16a\u02cc\13a\3a\3a\3b\3b")
>
> + buf.write("\3b\6b\u02d3\nb\rb\16b\u02d4\3b\5b\u02d8\nb\3c\3c\3c\7")
>
> + buf.write("c\u02dd\nc\fc\16c\u02e0\13c\5c\u02e2\nc\3c\5c\u02e5\n")
>
> + buf.write("c\3d\3d\6d\u02e9\nd\rd\16d\u02ea\3d\5d\u02ee\nd\3e\3e")
>
> + buf.write("\3f\3f\3f\3f\3f\3f\5f\u02f8\nf\3g\6g\u02fb\ng\rg\16g\u02fc")
>
> + buf.write("\3g\3g\7g\u0301\ng\fg\16g\u0304\13g\3g\5g\u0307\ng\3g")
>
> + buf.write("\5g\u030a\ng\3g\3g\6g\u030e\ng\rg\16g\u030f\3g\5g\u0313")
>
> + buf.write("\ng\3g\5g\u0316\ng\3g\6g\u0319\ng\rg\16g\u031a\3g\3g\5")
>
> + buf.write("g\u031f\ng\3g\6g\u0322\ng\rg\16g\u0323\3g\5g\u0327\ng")
>
> + buf.write("\3g\5g\u032a\ng\3h\3h\5h\u032e\nh\3h\6h\u0331\nh\rh\16")
>
> + buf.write("h\u0332\3i\3i\3j\3j\3j\5j\u033a\nj\3k\3k\3k\3k\3k\3k\3")
>
> + buf.write("k\3k\3k\5k\u0345\nk\3l\3l\3l\3l\3l\3l\3l\3m\3m\3m\3m\3")
>
> + buf.write("n\3n\3n\3n\3o\3o\3p\3p\3p\3p\7p\u035c\np\fp\16p\u035f")
>
> + buf.write("\13p\3p\3p\3p\3p\3p\3q\3q\3q\3q\7q\u036a\nq\fq\16q\u036d")
>
> + buf.write("\13q\3q\5q\u0370\nq\3q\3q\3q\3q\3r\3r\7r\u0378\nr\fr\16")
>
> + buf.write("r\u037b\13r\3r\5r\u037e\nr\3r\3r\3r\3r\3\u035d\2s\3\3")
>
> + buf.write("\5\4\7\5\t\6\13\7\r\b\17\t\21\n\23\13\25\f\27\r\31\16")
>
> + buf.write("\33\17\35\20\37\21!\22#\23%\24\'\25)\26+\27-\30/\31\61")
>
> + buf.write("\32\63\33\65\34\67\359\36;\37= ?!A\"C#E$G%I&K\'M(O)Q*")
>
> + buf.write("S+U,W-Y.[/]\60_\61a\62c\63e\64g\65i\66k\67m8o9q:s;u<w")
>
> + buf.write("=y>{?}@\177A\u0081B\u0083C\u0085D\u0087E\u0089F\u008b")
>
> + buf.write("G\u008dH\u008fI\u0091J\u0093K\u0095L\u0097M\u0099N\u009b")
>
> + buf.write("O\u009dP\u009fQ\u00a1R\u00a3S\u00a5T\u00a7U\u00a9V\u00ab")
>
> + buf.write("W\u00adX\u00afY\u00b1Z\u00b3[\u00b5\\\u00b7]\u00b9^\u00bb")
>
> + buf.write("_\u00bd\2\u00bf`\u00c1a\u00c3b\u00c5c\u00c7d\u00c9\2\u00cb")
>
> + buf.write("\2\u00cde\u00cf\2\u00d1\2\u00d3\2\u00d5\2\u00d7\2\u00d9")
>
> + buf.write("f\u00dbg\u00ddh\u00dfi\u00e1j\u00e3k\3\2\20\6\2&&C\\a")
>
> + buf.write("ac|\4\2))^^\4\2$$^^\4\2ZZzz\5\2\62;CHch\6\2NNWWnnww\4")
>
> + buf.write("\2WWww\4\2NNnn\4\2GGgg\4\2--//\6\2FFHHffhh\t\2))^^ddh")
>
> + buf.write("hppttvv\5\2\13\f\16\17\"\"\4\2\f\f\17\17\2\u03a2\2\3\3")
>
> + buf.write("\2\2\2\2\5\3\2\2\2\2\7\3\2\2\2\2\t\3\2\2\2\2\13\3\2\2")
>
> + buf.write("\2\2\r\3\2\2\2\2\17\3\2\2\2\2\21\3\2\2\2\2\23\3\2\2\2")
>
> + buf.write("\2\25\3\2\2\2\2\27\3\2\2\2\2\31\3\2\2\2\2\33\3\2\2\2\2")
>
> + buf.write("\35\3\2\2\2\2\37\3\2\2\2\2!\3\2\2\2\2#\3\2\2\2\2%\3\2")
>
> + buf.write("\2\2\2\'\3\2\2\2\2)\3\2\2\2\2+\3\2\2\2\2-\3\2\2\2\2/\3")
>
> + buf.write("\2\2\2\2\61\3\2\2\2\2\63\3\2\2\2\2\65\3\2\2\2\2\67\3\2")
>
> + buf.write("\2\2\29\3\2\2\2\2;\3\2\2\2\2=\3\2\2\2\2?\3\2\2\2\2A\3")
>
> + buf.write("\2\2\2\2C\3\2\2\2\2E\3\2\2\2\2G\3\2\2\2\2I\3\2\2\2\2K")
>
> + buf.write("\3\2\2\2\2M\3\2\2\2\2O\3\2\2\2\2Q\3\2\2\2\2S\3\2\2\2\2")
>
> + buf.write("U\3\2\2\2\2W\3\2\2\2\2Y\3\2\2\2\2[\3\2\2\2\2]\3\2\2\2")
>
> + buf.write("\2_\3\2\2\2\2a\3\2\2\2\2c\3\2\2\2\2e\3\2\2\2\2g\3\2\2")
>
> + buf.write("\2\2i\3\2\2\2\2k\3\2\2\2\2m\3\2\2\2\2o\3\2\2\2\2q\3\2")
>
> + buf.write("\2\2\2s\3\2\2\2\2u\3\2\2\2\2w\3\2\2\2\2y\3\2\2\2\2{\3")
>
> + buf.write("\2\2\2\2}\3\2\2\2\2\177\3\2\2\2\2\u0081\3\2\2\2\2\u0083")
>
> + buf.write("\3\2\2\2\2\u0085\3\2\2\2\2\u0087\3\2\2\2\2\u0089\3\2\2")
>
> + buf.write("\2\2\u008b\3\2\2\2\2\u008d\3\2\2\2\2\u008f\3\2\2\2\2\u0091")
>
> + buf.write("\3\2\2\2\2\u0093\3\2\2\2\2\u0095\3\2\2\2\2\u0097\3\2\2")
>
> + buf.write("\2\2\u0099\3\2\2\2\2\u009b\3\2\2\2\2\u009d\3\2\2\2\2\u009f")
>
> + buf.write("\3\2\2\2\2\u00a1\3\2\2\2\2\u00a3\3\2\2\2\2\u00a5\3\2\2")
>
> + buf.write("\2\2\u00a7\3\2\2\2\2\u00a9\3\2\2\2\2\u00ab\3\2\2\2\2\u00ad")
>
> + buf.write("\3\2\2\2\2\u00af\3\2\2\2\2\u00b1\3\2\2\2\2\u00b3\3\2\2")
>
> + buf.write("\2\2\u00b5\3\2\2\2\2\u00b7\3\2\2\2\2\u00b9\3\2\2\2\2\u00bb")
>
> + buf.write("\3\2\2\2\2\u00bf\3\2\2\2\2\u00c1\3\2\2\2\2\u00c3\3\2\2")
>
> + buf.write("\2\2\u00c5\3\2\2\2\2\u00c7\3\2\2\2\2\u00cd\3\2\2\2\2\u00d9")
>
> + buf.write("\3\2\2\2\2\u00db\3\2\2\2\2\u00dd\3\2\2\2\2\u00df\3\2\2")
>
> + buf.write("\2\2\u00e1\3\2\2\2\2\u00e3\3\2\2\2\3\u00e5\3\2\2\2\5\u00e7")
>
> + buf.write("\3\2\2\2\7\u00e9\3\2\2\2\t\u00f1\3\2\2\2\13\u00f3\3\2")
>
> + buf.write("\2\2\r\u00f5\3\2\2\2\17\u00fc\3\2\2\2\21\u0103\3\2\2\2")
>
> + buf.write("\23\u0108\3\2\2\2\25\u0111\3\2\2\2\27\u0118\3\2\2\2\31")
>
> + buf.write("\u011d\3\2\2\2\33\u0122\3\2\2\2\35\u0128\3\2\2\2\37\u012c")
>
> + buf.write("\3\2\2\2!\u0131\3\2\2\2#\u0137\3\2\2\2%\u013e\3\2\2\2")
>
> + buf.write("\'\u0145\3\2\2\2)\u014e\3\2\2\2+\u0150\3\2\2\2-\u0157")
>
> + buf.write("\3\2\2\2/\u015d\3\2\2\2\61\u015f\3\2\2\2\63\u0164\3\2")
>
> + buf.write("\2\2\65\u016a\3\2\2\2\67\u0173\3\2\2\29\u0176\3\2\2\2")
>
> + buf.write(";\u017a\3\2\2\2=\u0183\3\2\2\2?\u0189\3\2\2\2A\u0193\3")
>
> + buf.write("\2\2\2C\u019c\3\2\2\2E\u01ba\3\2\2\2G\u01c1\3\2\2\2I\u01d1")
>
> + buf.write("\3\2\2\2K\u01e4\3\2\2\2M\u01eb\3\2\2\2O\u01ed\3\2\2\2")
>
> + buf.write("Q\u01ef\3\2\2\2S\u01f1\3\2\2\2U\u01f3\3\2\2\2W\u01f5\3")
>
> + buf.write("\2\2\2Y\u01f9\3\2\2\2[\u01fb\3\2\2\2]\u01fd\3\2\2\2_\u01ff")
>
> + buf.write("\3\2\2\2a\u0201\3\2\2\2c\u0204\3\2\2\2e\u0207\3\2\2\2")
>
> + buf.write("g\u020e\3\2\2\2i\u0210\3\2\2\2k\u0213\3\2\2\2m\u0215\3")
>
> + buf.write("\2\2\2o\u0217\3\2\2\2q\u0219\3\2\2\2s\u021c\3\2\2\2u\u021f")
>
> + buf.write("\3\2\2\2w\u0222\3\2\2\2y\u0225\3\2\2\2{\u0228\3\2\2\2")
>
> + buf.write("}\u022c\3\2\2\2\177\u0230\3\2\2\2\u0081\u0233\3\2\2\2")
>
> + buf.write("\u0083\u0236\3\2\2\2\u0085\u0239\3\2\2\2\u0087\u023b\3")
>
> + buf.write("\2\2\2\u0089\u023e\3\2\2\2\u008b\u0241\3\2\2\2\u008d\u0243")
>
> + buf.write("\3\2\2\2\u008f\u0245\3\2\2\2\u0091\u0248\3\2\2\2\u0093")
>
> + buf.write("\u024b\3\2\2\2\u0095\u024d\3\2\2\2\u0097\u024f\3\2\2\2")
>
> + buf.write("\u0099\u0252\3\2\2\2\u009b\u0255\3\2\2\2\u009d\u0258\3")
>
> + buf.write("\2\2\2\u009f\u025b\3\2\2\2\u00a1\u0263\3\2\2\2\u00a3\u0268")
>
> + buf.write("\3\2\2\2\u00a5\u026e\3\2\2\2\u00a7\u0273\3\2\2\2\u00a9")
>
> + buf.write("\u027b\3\2\2\2\u00ab\u027e\3\2\2\2\u00ad\u0283\3\2\2\2")
>
> + buf.write("\u00af\u028a\3\2\2\2\u00b1\u0290\3\2\2\2\u00b3\u0293\3")
>
> + buf.write("\2\2\2\u00b5\u0298\3\2\2\2\u00b7\u02a1\3\2\2\2\u00b9\u02a7")
>
> + buf.write("\3\2\2\2\u00bb\u02ae\3\2\2\2\u00bd\u02b6\3\2\2\2\u00bf")
>
> + buf.write("\u02b9\3\2\2\2\u00c1\u02c3\3\2\2\2\u00c3\u02cf\3\2\2\2")
>
> + buf.write("\u00c5\u02e1\3\2\2\2\u00c7\u02e6\3\2\2\2\u00c9\u02ef\3")
>
> + buf.write("\2\2\2\u00cb\u02f7\3\2\2\2\u00cd\u0329\3\2\2\2\u00cf\u032b")
>
> + buf.write("\3\2\2\2\u00d1\u0334\3\2\2\2\u00d3\u0339\3\2\2\2\u00d5")
>
> + buf.write("\u0344\3\2\2\2\u00d7\u0346\3\2\2\2\u00d9\u034d\3\2\2\2")
>
> + buf.write("\u00db\u0351\3\2\2\2\u00dd\u0355\3\2\2\2\u00df\u0357\3")
>
> + buf.write("\2\2\2\u00e1\u0365\3\2\2\2\u00e3\u0375\3\2\2\2\u00e5\u00e6")
>
> + buf.write("\7}\2\2\u00e6\4\3\2\2\2\u00e7\u00e8\7=\2\2\u00e8\6\3\2")
>
> + buf.write("\2\2\u00e9\u00ea\7v\2\2\u00ea\u00eb\7{\2\2\u00eb\u00ec")
>
> + buf.write("\7r\2\2\u00ec\u00ed\7g\2\2\u00ed\u00ee\7f\2\2\u00ee\u00ef")
>
> + buf.write("\7g\2\2\u00ef\u00f0\7h\2\2\u00f0\b\3\2\2\2\u00f1\u00f2")
>
> + buf.write("\7.\2\2\u00f2\n\3\2\2\2\u00f3\u00f4\7?\2\2\u00f4\f\3\2")
>
> + buf.write("\2\2\u00f5\u00f6\7g\2\2\u00f6\u00f7\7z\2\2\u00f7\u00f8")
>
> + buf.write("\7v\2\2\u00f8\u00f9\7g\2\2\u00f9\u00fa\7t\2\2\u00fa\u00fb")
>
> + buf.write("\7p\2\2\u00fb\16\3\2\2\2\u00fc\u00fd\7u\2\2\u00fd\u00fe")
>
> + buf.write("\7v\2\2\u00fe\u00ff\7c\2\2\u00ff\u0100\7v\2\2\u0100\u0101")
>
> + buf.write("\7k\2\2\u0101\u0102\7e\2\2\u0102\20\3\2\2\2\u0103\u0104")
>
> + buf.write("\7c\2\2\u0104\u0105\7w\2\2\u0105\u0106\7v\2\2\u0106\u0107")
>
> + buf.write("\7q\2\2\u0107\22\3\2\2\2\u0108\u0109\7t\2\2\u0109\u010a")
>
> + buf.write("\7g\2\2\u010a\u010b\7i\2\2\u010b\u010c\7k\2\2\u010c\u010d")
>
> + buf.write("\7u\2\2\u010d\u010e\7v\2\2\u010e\u010f\7g\2\2\u010f\u0110")
>
> + buf.write("\7t\2\2\u0110\24\3\2\2\2\u0111\u0112\7U\2\2\u0112\u0113")
>
> + buf.write("\7V\2\2\u0113\u0114\7C\2\2\u0114\u0115\7V\2\2\u0115\u0116")
>
> + buf.write("\7K\2\2\u0116\u0117\7E\2\2\u0117\26\3\2\2\2\u0118\u0119")
>
> + buf.write("\7x\2\2\u0119\u011a\7q\2\2\u011a\u011b\7k\2\2\u011b\u011c")
>
> + buf.write("\7f\2\2\u011c\30\3\2\2\2\u011d\u011e\7e\2\2\u011e\u011f")
>
> + buf.write("\7j\2\2\u011f\u0120\7c\2\2\u0120\u0121\7t\2\2\u0121\32")
>
> + buf.write("\3\2\2\2\u0122\u0123\7u\2\2\u0123\u0124\7j\2\2\u0124\u0125")
>
> + buf.write("\7q\2\2\u0125\u0126\7t\2\2\u0126\u0127\7v\2\2\u0127\34")
>
> + buf.write("\3\2\2\2\u0128\u0129\7k\2\2\u0129\u012a\7p\2\2\u012a\u012b")
>
> + buf.write("\7v\2\2\u012b\36\3\2\2\2\u012c\u012d\7n\2\2\u012d\u012e")
>
> + buf.write("\7q\2\2\u012e\u012f\7p\2\2\u012f\u0130\7i\2\2\u0130 \3")
>
> + buf.write("\2\2\2\u0131\u0132\7h\2\2\u0132\u0133\7n\2\2\u0133\u0134")
>
> + buf.write("\7q\2\2\u0134\u0135\7c\2\2\u0135\u0136\7v\2\2\u0136\"")
>
> + buf.write("\3\2\2\2\u0137\u0138\7f\2\2\u0138\u0139\7q\2\2\u0139\u013a")
>
> + buf.write("\7w\2\2\u013a\u013b\7d\2\2\u013b\u013c\7n\2\2\u013c\u013d")
>
> + buf.write("\7g\2\2\u013d$\3\2\2\2\u013e\u013f\7u\2\2\u013f\u0140")
>
> + buf.write("\7k\2\2\u0140\u0141\7i\2\2\u0141\u0142\7p\2\2\u0142\u0143")
>
> + buf.write("\7g\2\2\u0143\u0144\7f\2\2\u0144&\3\2\2\2\u0145\u0146")
>
> + buf.write("\7w\2\2\u0146\u0147\7p\2\2\u0147\u0148\7u\2\2\u0148\u0149")
>
> + buf.write("\7k\2\2\u0149\u014a\7i\2\2\u014a\u014b\7p\2\2\u014b\u014c")
>
> + buf.write("\7g\2\2\u014c\u014d\7f\2\2\u014d(\3\2\2\2\u014e\u014f")
>
> + buf.write("\7\177\2\2\u014f*\3\2\2\2\u0150\u0151\7u\2\2\u0151\u0152")
>
> + buf.write("\7v\2\2\u0152\u0153\7t\2\2\u0153\u0154\7w\2\2\u0154\u0155")
>
> + buf.write("\7e\2\2\u0155\u0156\7v\2\2\u0156,\3\2\2\2\u0157\u0158")
>
> + buf.write("\7w\2\2\u0158\u0159\7p\2\2\u0159\u015a\7k\2\2\u015a\u015b")
>
> + buf.write("\7q\2\2\u015b\u015c\7p\2\2\u015c.\3\2\2\2\u015d\u015e")
>
> + buf.write("\7<\2\2\u015e\60\3\2\2\2\u015f\u0160\7g\2\2\u0160\u0161")
>
> + buf.write("\7p\2\2\u0161\u0162\7w\2\2\u0162\u0163\7o\2\2\u0163\62")
>
> + buf.write("\3\2\2\2\u0164\u0165\7e\2\2\u0165\u0166\7q\2\2\u0166\u0167")
>
> + buf.write("\7p\2\2\u0167\u0168\7u\2\2\u0168\u0169\7v\2\2\u0169\64")
>
> + buf.write("\3\2\2\2\u016a\u016b\7x\2\2\u016b\u016c\7q\2\2\u016c\u016d")
>
> + buf.write("\7n\2\2\u016d\u016e\7c\2\2\u016e\u016f\7v\2\2\u016f\u0170")
>
> + buf.write("\7k\2\2\u0170\u0171\7n\2\2\u0171\u0172\7g\2\2\u0172\66")
>
> + buf.write("\3\2\2\2\u0173\u0174\7K\2\2\u0174\u0175\7P\2\2\u01758")
>
> + buf.write("\3\2\2\2\u0176\u0177\7Q\2\2\u0177\u0178\7W\2\2\u0178\u0179")
>
> + buf.write("\7V\2\2\u0179:\3\2\2\2\u017a\u017b\7Q\2\2\u017b\u017c")
>
> + buf.write("\7R\2\2\u017c\u017d\7V\2\2\u017d\u017e\7K\2\2\u017e\u017f")
>
> + buf.write("\7Q\2\2\u017f\u0180\7P\2\2\u0180\u0181\7C\2\2\u0181\u0182")
>
> + buf.write("\7N\2\2\u0182<\3\2\2\2\u0183\u0184\7E\2\2\u0184\u0185")
>
> + buf.write("\7Q\2\2\u0185\u0186\7P\2\2\u0186\u0187\7U\2\2\u0187\u0188")
>
> + buf.write("\7V\2\2\u0188>\3\2\2\2\u0189\u018a\7W\2\2\u018a\u018b")
>
> + buf.write("\7P\2\2\u018b\u018c\7C\2\2\u018c\u018d\7N\2\2\u018d\u018e")
>
> + buf.write("\7K\2\2\u018e\u018f\7I\2\2\u018f\u0190\7P\2\2\u0190\u0191")
>
> + buf.write("\7G\2\2\u0191\u0192\7F\2\2\u0192@\3\2\2\2\u0193\u0194")
>
> + buf.write("\7X\2\2\u0194\u0195\7Q\2\2\u0195\u0196\7N\2\2\u0196\u0197")
>
> + buf.write("\7C\2\2\u0197\u0198\7V\2\2\u0198\u0199\7K\2\2\u0199\u019a")
>
> + buf.write("\7N\2\2\u019a\u019b\7G\2\2\u019bB\3\2\2\2\u019c\u019d")
>
> + buf.write("\7I\2\2\u019d\u019e\7N\2\2\u019e\u019f\7Q\2\2\u019f\u01a0")
>
> + buf.write("\7D\2\2\u01a0\u01a1\7C\2\2\u01a1\u01a2\7N\2\2\u01a2\u01a3")
>
> + buf.write("\7a\2\2\u01a3\u01a4\7T\2\2\u01a4\u01a5\7G\2\2\u01a5\u01a6")
>
> + buf.write("\7O\2\2\u01a6\u01a7\7Q\2\2\u01a7\u01a8\7X\2\2\u01a8\u01a9")
>
> + buf.write("\7G\2\2\u01a9\u01aa\7a\2\2\u01aa\u01ab\7K\2\2\u01ab\u01ac")
>
> + buf.write("\7H\2\2\u01ac\u01ad\7a\2\2\u01ad\u01ae\7W\2\2\u01ae\u01af")
>
> + buf.write("\7P\2\2\u01af\u01b0\7T\2\2\u01b0\u01b1\7G\2\2\u01b1\u01b2")
>
> + buf.write("\7H\2\2\u01b2\u01b3\7G\2\2\u01b3\u01b4\7T\2\2\u01b4\u01b5")
>
> + buf.write("\7G\2\2\u01b5\u01b6\7P\2\2\u01b6\u01b7\7E\2\2\u01b7\u01b8")
>
> + buf.write("\7G\2\2\u01b8\u01b9\7F\2\2\u01b9D\3\2\2\2\u01ba\u01bb")
>
> + buf.write("\7G\2\2\u01bb\u01bc\7H\2\2\u01bc\u01bd\7K\2\2\u01bd\u01be")
>
> + buf.write("\7C\2\2\u01be\u01bf\7R\2\2\u01bf\u01c0\7K\2\2\u01c0F\3")
>
> + buf.write("\2\2\2\u01c1\u01c2\7G\2\2\u01c2\u01c3\7H\2\2\u01c3\u01c4")
>
> + buf.write("\7K\2\2\u01c4\u01c5\7a\2\2\u01c5\u01c6\7D\2\2\u01c6\u01c7")
>
> + buf.write("\7Q\2\2\u01c7\u01c8\7Q\2\2\u01c8\u01c9\7V\2\2\u01c9\u01ca")
>
> + buf.write("\7U\2\2\u01ca\u01cb\7G\2\2\u01cb\u01cc\7T\2\2\u01cc\u01cd")
>
> + buf.write("\7X\2\2\u01cd\u01ce\7K\2\2\u01ce\u01cf\7E\2\2\u01cf\u01d0")
>
> + buf.write("\7G\2\2\u01d0H\3\2\2\2\u01d1\u01d2\7G\2\2\u01d2\u01d3")
>
> + buf.write("\7H\2\2\u01d3\u01d4\7K\2\2\u01d4\u01d5\7a\2\2\u01d5\u01d6")
>
> + buf.write("\7T\2\2\u01d6\u01d7\7W\2\2\u01d7\u01d8\7P\2\2\u01d8\u01d9")
>
> + buf.write("\7V\2\2\u01d9\u01da\7K\2\2\u01da\u01db\7O\2\2\u01db\u01dc")
>
> + buf.write("\7G\2\2\u01dc\u01dd\7U\2\2\u01dd\u01de\7G\2\2\u01de\u01df")
>
> + buf.write("\7T\2\2\u01df\u01e0\7X\2\2\u01e0\u01e1\7K\2\2\u01e1\u01e2")
>
> + buf.write("\7E\2\2\u01e2\u01e3\7G\2\2\u01e3J\3\2\2\2\u01e4\u01e5")
>
> + buf.write("\7R\2\2\u01e5\u01e6\7C\2\2\u01e6\u01e7\7E\2\2\u01e7\u01e8")
>
> + buf.write("\7M\2\2\u01e8\u01e9\7G\2\2\u01e9\u01ea\7F\2\2\u01eaL\3")
>
> + buf.write("\2\2\2\u01eb\u01ec\7*\2\2\u01ecN\3\2\2\2\u01ed\u01ee\7")
>
> + buf.write("+\2\2\u01eeP\3\2\2\2\u01ef\u01f0\7]\2\2\u01f0R\3\2\2\2")
>
> + buf.write("\u01f1\u01f2\7_\2\2\u01f2T\3\2\2\2\u01f3\u01f4\7,\2\2")
>
> + buf.write("\u01f4V\3\2\2\2\u01f5\u01f6\7\60\2\2\u01f6\u01f7\7\60")
>
> + buf.write("\2\2\u01f7\u01f8\7\60\2\2\u01f8X\3\2\2\2\u01f9\u01fa\7")
>
> + buf.write("-\2\2\u01faZ\3\2\2\2\u01fb\u01fc\7/\2\2\u01fc\\\3\2\2")
>
> + buf.write("\2\u01fd\u01fe\7\61\2\2\u01fe^\3\2\2\2\u01ff\u0200\7\'")
>
> + buf.write("\2\2\u0200`\3\2\2\2\u0201\u0202\7-\2\2\u0202\u0203\7-")
>
> + buf.write("\2\2\u0203b\3\2\2\2\u0204\u0205\7/\2\2\u0205\u0206\7/")
>
> + buf.write("\2\2\u0206d\3\2\2\2\u0207\u0208\7u\2\2\u0208\u0209\7k")
>
> + buf.write("\2\2\u0209\u020a\7|\2\2\u020a\u020b\7g\2\2\u020b\u020c")
>
> + buf.write("\7q\2\2\u020c\u020d\7h\2\2\u020df\3\2\2\2\u020e\u020f")
>
> + buf.write("\7\60\2\2\u020fh\3\2\2\2\u0210\u0211\7/\2\2\u0211\u0212")
>
> + buf.write("\7@\2\2\u0212j\3\2\2\2\u0213\u0214\7(\2\2\u0214l\3\2\2")
>
> + buf.write("\2\u0215\u0216\7\u0080\2\2\u0216n\3\2\2\2\u0217\u0218")
>
> + buf.write("\7#\2\2\u0218p\3\2\2\2\u0219\u021a\7,\2\2\u021a\u021b")
>
> + buf.write("\7?\2\2\u021br\3\2\2\2\u021c\u021d\7\61\2\2\u021d\u021e")
>
> + buf.write("\7?\2\2\u021et\3\2\2\2\u021f\u0220\7\'\2\2\u0220\u0221")
>
> + buf.write("\7?\2\2\u0221v\3\2\2\2\u0222\u0223\7-\2\2\u0223\u0224")
>
> + buf.write("\7?\2\2\u0224x\3\2\2\2\u0225\u0226\7/\2\2\u0226\u0227")
>
> + buf.write("\7?\2\2\u0227z\3\2\2\2\u0228\u0229\7>\2\2\u0229\u022a")
>
> + buf.write("\7>\2\2\u022a\u022b\7?\2\2\u022b|\3\2\2\2\u022c\u022d")
>
> + buf.write("\7@\2\2\u022d\u022e\7@\2\2\u022e\u022f\7?\2\2\u022f~\3")
>
> + buf.write("\2\2\2\u0230\u0231\7(\2\2\u0231\u0232\7?\2\2\u0232\u0080")
>
> + buf.write("\3\2\2\2\u0233\u0234\7`\2\2\u0234\u0235\7?\2\2\u0235\u0082")
>
> + buf.write("\3\2\2\2\u0236\u0237\7~\2\2\u0237\u0238\7?\2\2\u0238\u0084")
>
> + buf.write("\3\2\2\2\u0239\u023a\7A\2\2\u023a\u0086\3\2\2\2\u023b")
>
> + buf.write("\u023c\7~\2\2\u023c\u023d\7~\2\2\u023d\u0088\3\2\2\2\u023e")
>
> + buf.write("\u023f\7(\2\2\u023f\u0240\7(\2\2\u0240\u008a\3\2\2\2\u0241")
>
> + buf.write("\u0242\7~\2\2\u0242\u008c\3\2\2\2\u0243\u0244\7`\2\2\u0244")
>
> + buf.write("\u008e\3\2\2\2\u0245\u0246\7?\2\2\u0246\u0247\7?\2\2\u0247")
>
> + buf.write("\u0090\3\2\2\2\u0248\u0249\7#\2\2\u0249\u024a\7?\2\2\u024a")
>
> + buf.write("\u0092\3\2\2\2\u024b\u024c\7>\2\2\u024c\u0094\3\2\2\2")
>
> + buf.write("\u024d\u024e\7@\2\2\u024e\u0096\3\2\2\2\u024f\u0250\7")
>
> + buf.write(">\2\2\u0250\u0251\7?\2\2\u0251\u0098\3\2\2\2\u0252\u0253")
>
> + buf.write("\7@\2\2\u0253\u0254\7?\2\2\u0254\u009a\3\2\2\2\u0255\u0256")
>
> + buf.write("\7>\2\2\u0256\u0257\7>\2\2\u0257\u009c\3\2\2\2\u0258\u0259")
>
> + buf.write("\7@\2\2\u0259\u025a\7@\2\2\u025a\u009e\3\2\2\2\u025b\u025c")
>
> + buf.write("\7a\2\2\u025c\u025d\7a\2\2\u025d\u025e\7c\2\2\u025e\u025f")
>
> + buf.write("\7u\2\2\u025f\u0260\7o\2\2\u0260\u0261\7a\2\2\u0261\u0262")
>
> + buf.write("\7a\2\2\u0262\u00a0\3\2\2\2\u0263\u0264\7a\2\2\u0264\u0265")
>
> + buf.write("\7c\2\2\u0265\u0266\7u\2\2\u0266\u0267\7o\2\2\u0267\u00a2")
>
> + buf.write("\3\2\2\2\u0268\u0269\7a\2\2\u0269\u026a\7a\2\2\u026a\u026b")
>
> + buf.write("\7c\2\2\u026b\u026c\7u\2\2\u026c\u026d\7o\2\2\u026d\u00a4")
>
> + buf.write("\3\2\2\2\u026e\u026f\7e\2\2\u026f\u0270\7c\2\2\u0270\u0271")
>
> + buf.write("\7u\2\2\u0271\u0272\7g\2\2\u0272\u00a6\3\2\2\2\u0273\u0274")
>
> + buf.write("\7f\2\2\u0274\u0275\7g\2\2\u0275\u0276\7h\2\2\u0276\u0277")
>
> + buf.write("\7c\2\2\u0277\u0278\7w\2\2\u0278\u0279\7n\2\2\u0279\u027a")
>
> + buf.write("\7v\2\2\u027a\u00a8\3\2\2\2\u027b\u027c\7k\2\2\u027c\u027d")
>
> + buf.write("\7h\2\2\u027d\u00aa\3\2\2\2\u027e\u027f\7g\2\2\u027f\u0280")
>
> + buf.write("\7n\2\2\u0280\u0281\7u\2\2\u0281\u0282\7g\2\2\u0282\u00ac")
>
> + buf.write("\3\2\2\2\u0283\u0284\7u\2\2\u0284\u0285\7y\2\2\u0285\u0286")
>
> + buf.write("\7k\2\2\u0286\u0287\7v\2\2\u0287\u0288\7e\2\2\u0288\u0289")
>
> + buf.write("\7j\2\2\u0289\u00ae\3\2\2\2\u028a\u028b\7y\2\2\u028b\u028c")
>
> + buf.write("\7j\2\2\u028c\u028d\7k\2\2\u028d\u028e\7n\2\2\u028e\u028f")
>
> + buf.write("\7g\2\2\u028f\u00b0\3\2\2\2\u0290\u0291\7f\2\2\u0291\u0292")
>
> + buf.write("\7q\2\2\u0292\u00b2\3\2\2\2\u0293\u0294\7i\2\2\u0294\u0295")
>
> + buf.write("\7q\2\2\u0295\u0296\7v\2\2\u0296\u0297\7q\2\2\u0297\u00b4")
>
> + buf.write("\3\2\2\2\u0298\u0299\7e\2\2\u0299\u029a\7q\2\2\u029a\u029b")
>
> + buf.write("\7p\2\2\u029b\u029c\7v\2\2\u029c\u029d\7k\2\2\u029d\u029e")
>
> + buf.write("\7p\2\2\u029e\u029f\7w\2\2\u029f\u02a0\7g\2\2\u02a0\u00b6")
>
> + buf.write("\3\2\2\2\u02a1\u02a2\7d\2\2\u02a2\u02a3\7t\2\2\u02a3\u02a4")
>
> + buf.write("\7g\2\2\u02a4\u02a5\7c\2\2\u02a5\u02a6\7m\2\2\u02a6\u00b8")
>
> + buf.write("\3\2\2\2\u02a7\u02a8\7t\2\2\u02a8\u02a9\7g\2\2\u02a9\u02aa")
>
> + buf.write("\7v\2\2\u02aa\u02ab\7w\2\2\u02ab\u02ac\7t\2\2\u02ac\u02ad")
>
> + buf.write("\7p\2\2\u02ad\u00ba\3\2\2\2\u02ae\u02b3\5\u00bd_\2\u02af")
>
> + buf.write("\u02b2\5\u00bd_\2\u02b0\u02b2\4\62;\2\u02b1\u02af\3\2")
>
> + buf.write("\2\2\u02b1\u02b0\3\2\2\2\u02b2\u02b5\3\2\2\2\u02b3\u02b1")
>
> + buf.write("\3\2\2\2\u02b3\u02b4\3\2\2\2\u02b4\u00bc\3\2\2\2\u02b5")
>
> + buf.write("\u02b3\3\2\2\2\u02b6\u02b7\t\2\2\2\u02b7\u00be\3\2\2\2")
>
> + buf.write("\u02b8\u02ba\7N\2\2\u02b9\u02b8\3\2\2\2\u02b9\u02ba\3")
>
> + buf.write("\2\2\2\u02ba\u02bb\3\2\2\2\u02bb\u02be\7)\2\2\u02bc\u02bf")
>
> + buf.write("\5\u00d3j\2\u02bd\u02bf\n\3\2\2\u02be\u02bc\3\2\2\2\u02be")
>
> + buf.write("\u02bd\3\2\2\2\u02bf\u02c0\3\2\2\2\u02c0\u02c1\7)\2\2")
>
> + buf.write("\u02c1\u00c0\3\2\2\2\u02c2\u02c4\7N\2\2\u02c3\u02c2\3")
>
> + buf.write("\2\2\2\u02c3\u02c4\3\2\2\2\u02c4\u02c5\3\2\2\2\u02c5\u02ca")
>
> + buf.write("\7$\2\2\u02c6\u02c9\5\u00d3j\2\u02c7\u02c9\n\4\2\2\u02c8")
>
> + buf.write("\u02c6\3\2\2\2\u02c8\u02c7\3\2\2\2\u02c9\u02cc\3\2\2\2")
>
> + buf.write("\u02ca\u02c8\3\2\2\2\u02ca\u02cb\3\2\2\2\u02cb\u02cd\3")
>
> + buf.write("\2\2\2\u02cc\u02ca\3\2\2\2\u02cd\u02ce\7$\2\2\u02ce\u00c2")
>
> + buf.write("\3\2\2\2\u02cf\u02d0\7\62\2\2\u02d0\u02d2\t\5\2\2\u02d1")
>
> + buf.write("\u02d3\5\u00c9e\2\u02d2\u02d1\3\2\2\2\u02d3\u02d4\3\2")
>
> + buf.write("\2\2\u02d4\u02d2\3\2\2\2\u02d4\u02d5\3\2\2\2\u02d5\u02d7")
>
> + buf.write("\3\2\2\2\u02d6\u02d8\5\u00cbf\2\u02d7\u02d6\3\2\2\2\u02d7")
>
> + buf.write("\u02d8\3\2\2\2\u02d8\u00c4\3\2\2\2\u02d9\u02e2\7\62\2")
>
> + buf.write("\2\u02da\u02de\4\63;\2\u02db\u02dd\4\62;\2\u02dc\u02db")
>
> + buf.write("\3\2\2\2\u02dd\u02e0\3\2\2\2\u02de\u02dc\3\2\2\2\u02de")
>
> + buf.write("\u02df\3\2\2\2\u02df\u02e2\3\2\2\2\u02e0\u02de\3\2\2\2")
>
> + buf.write("\u02e1\u02d9\3\2\2\2\u02e1\u02da\3\2\2\2\u02e2\u02e4\3")
>
> + buf.write("\2\2\2\u02e3\u02e5\5\u00cbf\2\u02e4\u02e3\3\2\2\2\u02e4")
>
> + buf.write("\u02e5\3\2\2\2\u02e5\u00c6\3\2\2\2\u02e6\u02e8\7\62\2")
>
> + buf.write("\2\u02e7\u02e9\4\629\2\u02e8\u02e7\3\2\2\2\u02e9\u02ea")
>
> + buf.write("\3\2\2\2\u02ea\u02e8\3\2\2\2\u02ea\u02eb\3\2\2\2\u02eb")
>
> + buf.write("\u02ed\3\2\2\2\u02ec\u02ee\5\u00cbf\2\u02ed\u02ec\3\2")
>
> + buf.write("\2\2\u02ed\u02ee\3\2\2\2\u02ee\u00c8\3\2\2\2\u02ef\u02f0")
>
> + buf.write("\t\6\2\2\u02f0\u00ca\3\2\2\2\u02f1\u02f8\t\7\2\2\u02f2")
>
> + buf.write("\u02f3\t\b\2\2\u02f3\u02f8\t\t\2\2\u02f4\u02f5\t\b\2\2")
>
> + buf.write("\u02f5\u02f6\t\t\2\2\u02f6\u02f8\t\t\2\2\u02f7\u02f1\3")
>
> + buf.write("\2\2\2\u02f7\u02f2\3\2\2\2\u02f7\u02f4\3\2\2\2\u02f8\u00cc")
>
> + buf.write("\3\2\2\2\u02f9\u02fb\4\62;\2\u02fa\u02f9\3\2\2\2\u02fb")
>
> + buf.write("\u02fc\3\2\2\2\u02fc\u02fa\3\2\2\2\u02fc\u02fd\3\2\2\2")
>
> + buf.write("\u02fd\u02fe\3\2\2\2\u02fe\u0302\7\60\2\2\u02ff\u0301")
>
> + buf.write("\4\62;\2\u0300\u02ff\3\2\2\2\u0301\u0304\3\2\2\2\u0302")
>
> + buf.write("\u0300\3\2\2\2\u0302\u0303\3\2\2\2\u0303\u0306\3\2\2\2")
>
> + buf.write("\u0304\u0302\3\2\2\2\u0305\u0307\5\u00cfh\2\u0306\u0305")
>
> + buf.write("\3\2\2\2\u0306\u0307\3\2\2\2\u0307\u0309\3\2\2\2\u0308")
>
> + buf.write("\u030a\5\u00d1i\2\u0309\u0308\3\2\2\2\u0309\u030a\3\2")
>
> + buf.write("\2\2\u030a\u032a\3\2\2\2\u030b\u030d\7\60\2\2\u030c\u030e")
>
> + buf.write("\4\62;\2\u030d\u030c\3\2\2\2\u030e\u030f\3\2\2\2\u030f")
>
> + buf.write("\u030d\3\2\2\2\u030f\u0310\3\2\2\2\u0310\u0312\3\2\2\2")
>
> + buf.write("\u0311\u0313\5\u00cfh\2\u0312\u0311\3\2\2\2\u0312\u0313")
>
> + buf.write("\3\2\2\2\u0313\u0315\3\2\2\2\u0314\u0316\5\u00d1i\2\u0315")
>
> + buf.write("\u0314\3\2\2\2\u0315\u0316\3\2\2\2\u0316\u032a\3\2\2\2")
>
> + buf.write("\u0317\u0319\4\62;\2\u0318\u0317\3\2\2\2\u0319\u031a\3")
>
> + buf.write("\2\2\2\u031a\u0318\3\2\2\2\u031a\u031b\3\2\2\2\u031b\u031c")
>
> + buf.write("\3\2\2\2\u031c\u031e\5\u00cfh\2\u031d\u031f\5\u00d1i\2")
>
> + buf.write("\u031e\u031d\3\2\2\2\u031e\u031f\3\2\2\2\u031f\u032a\3")
>
> + buf.write("\2\2\2\u0320\u0322\4\62;\2\u0321\u0320\3\2\2\2\u0322\u0323")
>
> + buf.write("\3\2\2\2\u0323\u0321\3\2\2\2\u0323\u0324\3\2\2\2\u0324")
>
> + buf.write("\u0326\3\2\2\2\u0325\u0327\5\u00cfh\2\u0326\u0325\3\2")
>
> + buf.write("\2\2\u0326\u0327\3\2\2\2\u0327\u0328\3\2\2\2\u0328\u032a")
>
> + buf.write("\5\u00d1i\2\u0329\u02fa\3\2\2\2\u0329\u030b\3\2\2\2\u0329")
>
> + buf.write("\u0318\3\2\2\2\u0329\u0321\3\2\2\2\u032a\u00ce\3\2\2\2")
>
> + buf.write("\u032b\u032d\t\n\2\2\u032c\u032e\t\13\2\2\u032d\u032c")
>
> + buf.write("\3\2\2\2\u032d\u032e\3\2\2\2\u032e\u0330\3\2\2\2\u032f")
>
> + buf.write("\u0331\4\62;\2\u0330\u032f\3\2\2\2\u0331\u0332\3\2\2\2")
>
> + buf.write("\u0332\u0330\3\2\2\2\u0332\u0333\3\2\2\2\u0333\u00d0\3")
>
> + buf.write("\2\2\2\u0334\u0335\t\f\2\2\u0335\u00d2\3\2\2\2\u0336\u0337")
>
> + buf.write("\7^\2\2\u0337\u033a\t\r\2\2\u0338\u033a\5\u00d5k\2\u0339")
>
> + buf.write("\u0336\3\2\2\2\u0339\u0338\3\2\2\2\u033a\u00d4\3\2\2\2")
>
> + buf.write("\u033b\u033c\7^\2\2\u033c\u033d\4\62\65\2\u033d\u033e")
>
> + buf.write("\4\629\2\u033e\u0345\4\629\2\u033f\u0340\7^\2\2\u0340")
>
> + buf.write("\u0341\4\629\2\u0341\u0345\4\629\2\u0342\u0343\7^\2\2")
>
> + buf.write("\u0343\u0345\4\629\2\u0344\u033b\3\2\2\2\u0344\u033f\3")
>
> + buf.write("\2\2\2\u0344\u0342\3\2\2\2\u0345\u00d6\3\2\2\2\u0346\u0347")
>
> + buf.write("\7^\2\2\u0347\u0348\7w\2\2\u0348\u0349\5\u00c9e\2\u0349")
>
> + buf.write("\u034a\5\u00c9e\2\u034a\u034b\5\u00c9e\2\u034b\u034c\5")
>
> + buf.write("\u00c9e\2\u034c\u00d8\3\2\2\2\u034d\u034e\t\16\2\2\u034e")
>
> + buf.write("\u034f\3\2\2\2\u034f\u0350\bm\2\2\u0350\u00da\3\2\2\2")
>
> + buf.write("\u0351\u0352\7^\2\2\u0352\u0353\3\2\2\2\u0353\u0354\b")
>
> + buf.write("n\2\2\u0354\u00dc\3\2\2\2\u0355\u0356\4\5\0\2\u0356\u00de")
>
> + buf.write("\3\2\2\2\u0357\u0358\7\61\2\2\u0358\u0359\7,\2\2\u0359")
>
> + buf.write("\u035d\3\2\2\2\u035a\u035c\13\2\2\2\u035b\u035a\3\2\2")
>
> + buf.write("\2\u035c\u035f\3\2\2\2\u035d\u035e\3\2\2\2\u035d\u035b")
>
> + buf.write("\3\2\2\2\u035e\u0360\3\2\2\2\u035f\u035d\3\2\2\2\u0360")
>
> + buf.write("\u0361\7,\2\2\u0361\u0362\7\61\2\2\u0362\u0363\3\2\2\2")
>
> + buf.write("\u0363\u0364\bp\2\2\u0364\u00e0\3\2\2\2\u0365\u0366\7")
>
> + buf.write("\61\2\2\u0366\u0367\7\61\2\2\u0367\u036b\3\2\2\2\u0368")
>
> + buf.write("\u036a\n\17\2\2\u0369\u0368\3\2\2\2\u036a\u036d\3\2\2")
>
> + buf.write("\2\u036b\u0369\3\2\2\2\u036b\u036c\3\2\2\2\u036c\u036f")
>
> + buf.write("\3\2\2\2\u036d\u036b\3\2\2\2\u036e\u0370\7\17\2\2\u036f")
>
> + buf.write("\u036e\3\2\2\2\u036f\u0370\3\2\2\2\u0370\u0371\3\2\2\2")
>
> + buf.write("\u0371\u0372\7\f\2\2\u0372\u0373\3\2\2\2\u0373\u0374\b")
>
> + buf.write("q\2\2\u0374\u00e2\3\2\2\2\u0375\u0379\7%\2\2\u0376\u0378")
>
> + buf.write("\n\17\2\2\u0377\u0376\3\2\2\2\u0378\u037b\3\2\2\2\u0379")
>
> + buf.write("\u0377\3\2\2\2\u0379\u037a\3\2\2\2\u037a\u037d\3\2\2\2")
>
> + buf.write("\u037b\u0379\3\2\2\2\u037c\u037e\7\17\2\2\u037d\u037c")
>
> + buf.write("\3\2\2\2\u037d\u037e\3\2\2\2\u037e\u037f\3\2\2\2\u037f")
>
> + buf.write("\u0380\7\f\2\2\u0380\u0381\3\2\2\2\u0381\u0382\br\2\2")
>
> + buf.write("\u0382\u00e4\3\2\2\2\'\2\u02b1\u02b3\u02b9\u02be\u02c3")
>
> + buf.write("\u02c8\u02ca\u02d4\u02d7\u02de\u02e1\u02e4\u02ea\u02ed")
>
> + buf.write("\u02f7\u02fc\u0302\u0306\u0309\u030f\u0312\u0315\u031a")
>
> + buf.write("\u031e\u0323\u0326\u0329\u032d\u0332\u0339\u0344\u035d")
>
> + buf.write("\u036b\u036f\u0379\u037d\3\2\3\2")
>
> + return buf.getvalue()
>
> +
>
> +
>
> +class CLexer(Lexer):
>
> +
>
> + atn = ATNDeserializer().deserialize(serializedATN())
>
> +
>
> + decisionsToDFA = [ DFA(ds, i) for i, ds in enumerate(atn.decisionToState) ]
>
> +
>
> + T__0 = 1
>
> + T__1 = 2
>
> + T__2 = 3
>
> + T__3 = 4
>
> + T__4 = 5
>
> + T__5 = 6
>
> + T__6 = 7
>
> + T__7 = 8
>
> + T__8 = 9
>
> + T__9 = 10
>
> + T__10 = 11
>
> + T__11 = 12
>
> + T__12 = 13
>
> + T__13 = 14
>
> + T__14 = 15
>
> + T__15 = 16
>
> + T__16 = 17
>
> + T__17 = 18
>
> + T__18 = 19
>
> + T__19 = 20
>
> + T__20 = 21
>
> + T__21 = 22
>
> + T__22 = 23
>
> + T__23 = 24
>
> + T__24 = 25
>
> + T__25 = 26
>
> + T__26 = 27
>
> + T__27 = 28
>
> + T__28 = 29
>
> + T__29 = 30
>
> + T__30 = 31
>
> + T__31 = 32
>
> + T__32 = 33
>
> + T__33 = 34
>
> + T__34 = 35
>
> + T__35 = 36
>
> + T__36 = 37
>
> + T__37 = 38
>
> + T__38 = 39
>
> + T__39 = 40
>
> + T__40 = 41
>
> + T__41 = 42
>
> + T__42 = 43
>
> + T__43 = 44
>
> + T__44 = 45
>
> + T__45 = 46
>
> + T__46 = 47
>
> + T__47 = 48
>
> + T__48 = 49
>
> + T__49 = 50
>
> + T__50 = 51
>
> + T__51 = 52
>
> + T__52 = 53
>
> + T__53 = 54
>
> + T__54 = 55
>
> + T__55 = 56
>
> + T__56 = 57
>
> + T__57 = 58
>
> + T__58 = 59
>
> + T__59 = 60
>
> + T__60 = 61
>
> + T__61 = 62
>
> + T__62 = 63
>
> + T__63 = 64
>
> + T__64 = 65
>
> + T__65 = 66
>
> + T__66 = 67
>
> + T__67 = 68
>
> + T__68 = 69
>
> + T__69 = 70
>
> + T__70 = 71
>
> + T__71 = 72
>
> + T__72 = 73
>
> + T__73 = 74
>
> + T__74 = 75
>
> + T__75 = 76
>
> + T__76 = 77
>
> + T__77 = 78
>
> + T__78 = 79
>
> + T__79 = 80
>
> + T__80 = 81
>
> + T__81 = 82
>
> + T__82 = 83
>
> + T__83 = 84
>
> + T__84 = 85
>
> + T__85 = 86
>
> + T__86 = 87
>
> + T__87 = 88
>
> + T__88 = 89
>
> + T__89 = 90
>
> + T__90 = 91
>
> + T__91 = 92
>
> + IDENTIFIER = 93
>
> + CHARACTER_LITERAL = 94
>
> + STRING_LITERAL = 95
>
> + HEX_LITERAL = 96
>
> + DECIMAL_LITERAL = 97
>
> + OCTAL_LITERAL = 98
>
> + FLOATING_POINT_LITERAL = 99
>
> + WS = 100
>
> + BS = 101
>
> + UnicodeVocabulary = 102
>
> + COMMENT = 103
>
> + LINE_COMMENT = 104
>
> + LINE_COMMAND = 105
>
> +
>
> + channelNames = [ u"DEFAULT_TOKEN_CHANNEL", u"HIDDEN" ]
>
> +
>
> + modeNames = [ "DEFAULT_MODE" ]
>
> +
>
> + literalNames = [ "<INVALID>",
>
> + "'{'", "';'", "'typedef'", "','", "'='", "'extern'", "'static'",
>
> + "'auto'", "'register'", "'STATIC'", "'void'", "'char'", "'short'",
>
> + "'int'", "'long'", "'float'", "'double'", "'signed'", "'unsigned'",
>
> + "'}'", "'struct'", "'union'", "':'", "'enum'", "'const'", "'volatile'",
>
> + "'IN'", "'OUT'", "'OPTIONAL'", "'CONST'", "'UNALIGNED'", "'VOLATILE'",
>
> + "'GLOBAL_REMOVE_IF_UNREFERENCED'", "'EFIAPI'", "'EFI_BOOTSERVICE'",
>
> + "'EFI_RUNTIMESERVICE'", "'PACKED'", "'('", "')'", "'['", "']'",
>
> + "'*'", "'...'", "'+'", "'-'", "'/'", "'%'", "'++'", "'--'",
>
> + "'sizeof'", "'.'", "'->'", "'&'", "'~'", "'!'", "'*='", "'/='",
>
> + "'%='", "'+='", "'-='", "'<<='", "'>>='", "'&='", "'^='", "'|='",
>
> + "'?'", "'||'", "'&&'", "'|'", "'^'", "'=='", "'!='", "'<'",
>
> + "'>'", "'<='", "'>='", "'<<'", "'>>'", "'__asm__'", "'_asm'",
>
> + "'__asm'", "'case'", "'default'", "'if'", "'else'", "'switch'",
>
> + "'while'", "'do'", "'goto'", "'continue'", "'break'", "'return'" ]
>
> +
>
> + symbolicNames = [ "<INVALID>",
>
> + "IDENTIFIER", "CHARACTER_LITERAL", "STRING_LITERAL", "HEX_LITERAL",
>
> + "DECIMAL_LITERAL", "OCTAL_LITERAL", "FLOATING_POINT_LITERAL",
>
> + "WS", "BS", "UnicodeVocabulary", "COMMENT", "LINE_COMMENT",
>
> + "LINE_COMMAND" ]
>
> +
>
> + ruleNames = [ "T__0", "T__1", "T__2", "T__3", "T__4", "T__5", "T__6",
>
> + "T__7", "T__8", "T__9", "T__10", "T__11", "T__12", "T__13",
>
> + "T__14", "T__15", "T__16", "T__17", "T__18", "T__19",
>
> + "T__20", "T__21", "T__22", "T__23", "T__24", "T__25",
>
> + "T__26", "T__27", "T__28", "T__29", "T__30", "T__31",
>
> + "T__32", "T__33", "T__34", "T__35", "T__36", "T__37",
>
> + "T__38", "T__39", "T__40", "T__41", "T__42", "T__43",
>
> + "T__44", "T__45", "T__46", "T__47", "T__48", "T__49",
>
> + "T__50", "T__51", "T__52", "T__53", "T__54", "T__55",
>
> + "T__56", "T__57", "T__58", "T__59", "T__60", "T__61",
>
> + "T__62", "T__63", "T__64", "T__65", "T__66", "T__67",
>
> + "T__68", "T__69", "T__70", "T__71", "T__72", "T__73",
>
> + "T__74", "T__75", "T__76", "T__77", "T__78", "T__79",
>
> + "T__80", "T__81", "T__82", "T__83", "T__84", "T__85",
>
> + "T__86", "T__87", "T__88", "T__89", "T__90", "T__91",
>
> + "IDENTIFIER", "LETTER", "CHARACTER_LITERAL", "STRING_LITERAL",
>
> + "HEX_LITERAL", "DECIMAL_LITERAL", "OCTAL_LITERAL", "HexDigit",
>
> + "IntegerTypeSuffix", "FLOATING_POINT_LITERAL", "Exponent",
>
> + "FloatTypeSuffix", "EscapeSequence", "OctalEscape", "UnicodeEscape",
>
> + "WS", "BS", "UnicodeVocabulary", "COMMENT", "LINE_COMMENT",
>
> + "LINE_COMMAND" ]
>
> +
>
> + grammarFileName = "C.g4"
>
> +
>
> + # @param output= sys.stdout Type: TextIO
>
> + def __init__(self,input=None,output= sys.stdout):
>
> + super().__init__(input, output)
>
> + self.checkVersion("4.7.1")
>
> + self._interp = LexerATNSimulator(self, self.atn, self.decisionsToDFA, PredictionContextCache())
>
> + self._actions = None
>
> + self._predicates = None
>
> +
>
> +
>
> +
>
> + def printTokenInfo(self,line,offset,tokenText):
>
> + print(str(line)+ ',' + str(offset) + ':' + str(tokenText))
>
> +
>
> + def StorePredicateExpression(self,StartLine,StartOffset,EndLine,EndOffset,Text):
>
> + PredExp = CodeFragment.PredicateExpression(Text, (StartLine, StartOffset), (EndLine, EndOffset))
>
> + FileProfile.PredicateExpressionList.append(PredExp)
>
> +
>
> + def StoreEnumerationDefinition(self,StartLine,StartOffset,EndLine,EndOffset,Text):
>
> + EnumDef = CodeFragment.EnumerationDefinition(Text, (StartLine, StartOffset), (EndLine, EndOffset))
>
> + FileProfile.EnumerationDefinitionList.append(EnumDef)
>
> +
>
> + def StoreStructUnionDefinition(self,StartLine,StartOffset,EndLine,EndOffset,Text):
>
> + SUDef = CodeFragment.StructUnionDefinition(Text, (StartLine, StartOffset), (EndLine, EndOffset))
>
> + FileProfile.StructUnionDefinitionList.append(SUDef)
>
> +
>
> + def StoreTypedefDefinition(self,StartLine,StartOffset,EndLine,EndOffset,FromText,ToText):
>
> + Tdef = CodeFragment.TypedefDefinition(FromText, ToText, (StartLine, StartOffset), (EndLine, EndOffset))
>
> + FileProfile.TypedefDefinitionList.append(Tdef)
>
> +
>
> + def
> StoreFunctionDefinition(self,StartLine,StartOffset,EndLine,EndOffset,ModifierText,DeclText,LeftBraceLine,LeftBraceOffset,DeclLine,DeclOffse
> t):
>
> + FuncDef = CodeFragment.FunctionDefinition(ModifierText, DeclText, (StartLine, StartOffset), (EndLine, EndOffset), (LeftBraceLine,
> LeftBraceOffset), (DeclLine, DeclOffset))
>
> + FileProfile.FunctionDefinitionList.append(FuncDef)
>
> +
>
> + def StoreVariableDeclaration(self,StartLine,StartOffset,EndLine,EndOffset,ModifierText,DeclText):
>
> + VarDecl = CodeFragment.VariableDeclaration(ModifierText, DeclText, (StartLine, StartOffset), (EndLine, EndOffset))
>
> + FileProfile.VariableDeclarationList.append(VarDecl)
>
> +
>
> + def StoreFunctionCalling(self,StartLine,StartOffset,EndLine,EndOffset,FuncName,ParamList):
>
> + FuncCall = CodeFragment.FunctionCalling(FuncName, ParamList, (StartLine, StartOffset), (EndLine, EndOffset))
>
> + FileProfile.FunctionCallingList.append(FuncCall)
>
> +
>
> +
>
> +
>
> diff --git a/BaseTools/Source/Python/Eot/CParser4/CListener.py b/BaseTools/Source/Python/Eot/CParser4/CListener.py
> new file mode 100644
> index 0000000000..f745c33aad
> --- /dev/null
> +++ b/BaseTools/Source/Python/Eot/CParser4/CListener.py
> @@ -0,0 +1,814 @@
> +# Generated from C.g4 by ANTLR 4.7.1
>
> +from antlr4 import *
>
> +if __name__ is not None and "." in __name__:
>
> + from .CParser import CParser
>
> +else:
>
> + from CParser import CParser
>
> +
>
> +## @file
>
> +# The file defines the parser for C source files.
>
> +#
>
> +# THIS FILE IS AUTO-GENENERATED. PLEASE DON NOT MODIFY THIS FILE.
>
> +# This file is generated by running:
>
> +# java org.antlr.Tool C.g
>
> +#
>
> +# Copyright (c) 2009 - 2010, Intel Corporation All rights reserved.
>
> +#
>
> +# This program and the accompanying materials are licensed and made available
>
> +# under the terms and conditions of the BSD License which accompanies this
>
> +# distribution. The full text of the license may be found at:
>
> +# http://opensource.org/licenses/bsd-license.php
>
> +#
>
> +# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
>
> +# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
>
> +#
>
> +##
>
> +
>
> +import Ecc.CodeFragment as CodeFragment
>
> +import Ecc.FileProfile as FileProfile
>
> +
>
> +
>
> +# This class defines a complete listener for a parse tree produced by CParser.
>
> +class CListener(ParseTreeListener):
>
> +
>
> + # Enter a parse tree produced by CParser#translation_unit.
>
> + # @param ctx Type: CParser.Translation_unitContext
>
> + def enterTranslation_unit(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#translation_unit.
>
> + # @param ctx Type: CParser.Translation_unitContext
>
> + def exitTranslation_unit(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#external_declaration.
>
> + # @param ctx Type: CParser.External_declarationContext
>
> + def enterExternal_declaration(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#external_declaration.
>
> + # @param ctx Type: CParser.External_declarationContext
>
> + def exitExternal_declaration(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#function_definition.
>
> + # @param ctx Type: CParser.Function_definitionContext
>
> + def enterFunction_definition(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#function_definition.
>
> + # @param ctx Type: CParser.Function_definitionContext
>
> + def exitFunction_definition(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#declaration_specifiers.
>
> + # @param ctx Type: CParser.Declaration_specifiersContext
>
> + def enterDeclaration_specifiers(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#declaration_specifiers.
>
> + # @param ctx Type: CParser.Declaration_specifiersContext
>
> + def exitDeclaration_specifiers(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#declaration.
>
> + # @param ctx Type: CParser.DeclarationContext
>
> + def enterDeclaration(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#declaration.
>
> + # @param ctx Type: CParser.DeclarationContext
>
> + def exitDeclaration(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#init_declarator_list.
>
> + # @param ctx Type: CParser.Init_declarator_listContext
>
> + def enterInit_declarator_list(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#init_declarator_list.
>
> + # @param ctx Type: CParser.Init_declarator_listContext
>
> + def exitInit_declarator_list(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#init_declarator.
>
> + # @param ctx Type: CParser.Init_declaratorContext
>
> + def enterInit_declarator(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#init_declarator.
>
> + # @param ctx Type: CParser.Init_declaratorContext
>
> + def exitInit_declarator(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#storage_class_specifier.
>
> + # @param ctx Type: CParser.Storage_class_specifierContext
>
> + def enterStorage_class_specifier(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#storage_class_specifier.
>
> + # @param ctx Type: CParser.Storage_class_specifierContext
>
> + def exitStorage_class_specifier(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#type_specifier.
>
> + # @param ctx Type: CParser.Type_specifierContext
>
> + def enterType_specifier(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#type_specifier.
>
> + # @param ctx Type: CParser.Type_specifierContext
>
> + def exitType_specifier(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#type_id.
>
> + # @param ctx Type: CParser.Type_idContext
>
> + def enterType_id(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#type_id.
>
> + # @param ctx Type: CParser.Type_idContext
>
> + def exitType_id(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#struct_or_union_specifier.
>
> + # @param ctx Type: CParser.Struct_or_union_specifierContext
>
> + def enterStruct_or_union_specifier(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#struct_or_union_specifier.
>
> + # @param ctx Type: CParser.Struct_or_union_specifierContext
>
> + def exitStruct_or_union_specifier(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#struct_or_union.
>
> + # @param ctx Type: CParser.Struct_or_unionContext
>
> + def enterStruct_or_union(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#struct_or_union.
>
> + # @param ctx Type: CParser.Struct_or_unionContext
>
> + def exitStruct_or_union(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#struct_declaration_list.
>
> + # @param ctx Type: CParser.Struct_declaration_listContext
>
> + def enterStruct_declaration_list(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#struct_declaration_list.
>
> + # @param ctx Type: CParser.Struct_declaration_listContext
>
> + def exitStruct_declaration_list(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#struct_declaration.
>
> + # @param ctx Type: CParser.Struct_declarationContext
>
> + def enterStruct_declaration(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#struct_declaration.
>
> + # @param ctx Type: CParser.Struct_declarationContext
>
> + def exitStruct_declaration(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#specifier_qualifier_list.
>
> + # @param ctx Type: CParser.Specifier_qualifier_listContext
>
> + def enterSpecifier_qualifier_list(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#specifier_qualifier_list.
>
> + # @param ctx Type: CParser.Specifier_qualifier_listContext
>
> + def exitSpecifier_qualifier_list(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#struct_declarator_list.
>
> + # @param ctx Type: CParser.Struct_declarator_listContext
>
> + def enterStruct_declarator_list(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#struct_declarator_list.
>
> + # @param ctx Type: CParser.Struct_declarator_listContext
>
> + def exitStruct_declarator_list(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#struct_declarator.
>
> + # @param ctx Type: CParser.Struct_declaratorContext
>
> + def enterStruct_declarator(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#struct_declarator.
>
> + # @param ctx Type: CParser.Struct_declaratorContext
>
> + def exitStruct_declarator(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#enum_specifier.
>
> + # @param ctx Type: CParser.Enum_specifierContext
>
> + def enterEnum_specifier(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#enum_specifier.
>
> + # @param ctx Type: CParser.Enum_specifierContext
>
> + def exitEnum_specifier(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#enumerator_list.
>
> + # @param ctx Type: CParser.Enumerator_listContext
>
> + def enterEnumerator_list(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#enumerator_list.
>
> + # @param ctx Type: CParser.Enumerator_listContext
>
> + def exitEnumerator_list(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#enumerator.
>
> + # @param ctx Type: CParser.EnumeratorContext
>
> + def enterEnumerator(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#enumerator.
>
> + # @param ctx Type: CParser.EnumeratorContext
>
> + def exitEnumerator(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#type_qualifier.
>
> + # @param ctx Type: CParser.Type_qualifierContext
>
> + def enterType_qualifier(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#type_qualifier.
>
> + # @param ctx Type: CParser.Type_qualifierContext
>
> + def exitType_qualifier(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#declarator.
>
> + # @param ctx Type: CParser.DeclaratorContext
>
> + def enterDeclarator(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#declarator.
>
> + # @param ctx Type: CParser.DeclaratorContext
>
> + def exitDeclarator(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#direct_declarator.
>
> + # @param ctx Type: CParser.Direct_declaratorContext
>
> + def enterDirect_declarator(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#direct_declarator.
>
> + # @param ctx Type: CParser.Direct_declaratorContext
>
> + def exitDirect_declarator(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#declarator_suffix.
>
> + # @param ctx Type: CParser.Declarator_suffixContext
>
> + def enterDeclarator_suffix(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#declarator_suffix.
>
> + # @param ctx Type: CParser.Declarator_suffixContext
>
> + def exitDeclarator_suffix(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#pointer.
>
> + # @param ctx Type: CParser.PointerContext
>
> + def enterPointer(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#pointer.
>
> + # @param ctx Type: CParser.PointerContext
>
> + def exitPointer(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#parameter_type_list.
>
> + # @param ctx Type: CParser.Parameter_type_listContext
>
> + def enterParameter_type_list(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#parameter_type_list.
>
> + # @param ctx Type: CParser.Parameter_type_listContext
>
> + def exitParameter_type_list(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#parameter_list.
>
> + # @param ctx Type: CParser.Parameter_listContext
>
> + def enterParameter_list(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#parameter_list.
>
> + # @param ctx Type: CParser.Parameter_listContext
>
> + def exitParameter_list(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#parameter_declaration.
>
> + # @param ctx Type: CParser.Parameter_declarationContext
>
> + def enterParameter_declaration(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#parameter_declaration.
>
> + # @param ctx Type: CParser.Parameter_declarationContext
>
> + def exitParameter_declaration(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#identifier_list.
>
> + # @param ctx Type: CParser.Identifier_listContext
>
> + def enterIdentifier_list(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#identifier_list.
>
> + # @param ctx Type: CParser.Identifier_listContext
>
> + def exitIdentifier_list(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#type_name.
>
> + # @param ctx Type: CParser.Type_nameContext
>
> + def enterType_name(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#type_name.
>
> + # @param ctx Type: CParser.Type_nameContext
>
> + def exitType_name(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#abstract_declarator.
>
> + # @param ctx Type: CParser.Abstract_declaratorContext
>
> + def enterAbstract_declarator(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#abstract_declarator.
>
> + # @param ctx Type: CParser.Abstract_declaratorContext
>
> + def exitAbstract_declarator(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#direct_abstract_declarator.
>
> + # @param ctx Type: CParser.Direct_abstract_declaratorContext
>
> + def enterDirect_abstract_declarator(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#direct_abstract_declarator.
>
> + # @param ctx Type: CParser.Direct_abstract_declaratorContext
>
> + def exitDirect_abstract_declarator(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#abstract_declarator_suffix.
>
> + # @param ctx Type: CParser.Abstract_declarator_suffixContext
>
> + def enterAbstract_declarator_suffix(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#abstract_declarator_suffix.
>
> + # @param ctx Type: CParser.Abstract_declarator_suffixContext
>
> + def exitAbstract_declarator_suffix(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#initializer.
>
> + # @param ctx Type: CParser.InitializerContext
>
> + def enterInitializer(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#initializer.
>
> + # @param ctx Type: CParser.InitializerContext
>
> + def exitInitializer(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#initializer_list.
>
> + # @param ctx Type: CParser.Initializer_listContext
>
> + def enterInitializer_list(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#initializer_list.
>
> + # @param ctx Type: CParser.Initializer_listContext
>
> + def exitInitializer_list(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#argument_expression_list.
>
> + # @param ctx Type: CParser.Argument_expression_listContext
>
> + def enterArgument_expression_list(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#argument_expression_list.
>
> + # @param ctx Type: CParser.Argument_expression_listContext
>
> + def exitArgument_expression_list(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#additive_expression.
>
> + # @param ctx Type: CParser.Additive_expressionContext
>
> + def enterAdditive_expression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#additive_expression.
>
> + # @param ctx Type: CParser.Additive_expressionContext
>
> + def exitAdditive_expression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#multiplicative_expression.
>
> + # @param ctx Type: CParser.Multiplicative_expressionContext
>
> + def enterMultiplicative_expression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#multiplicative_expression.
>
> + # @param ctx Type: CParser.Multiplicative_expressionContext
>
> + def exitMultiplicative_expression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#cast_expression.
>
> + # @param ctx Type: CParser.Cast_expressionContext
>
> + def enterCast_expression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#cast_expression.
>
> + # @param ctx Type: CParser.Cast_expressionContext
>
> + def exitCast_expression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#unary_expression.
>
> + # @param ctx Type: CParser.Unary_expressionContext
>
> + def enterUnary_expression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#unary_expression.
>
> + # @param ctx Type: CParser.Unary_expressionContext
>
> + def exitUnary_expression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#postfix_expression.
>
> + # @param ctx Type: CParser.Postfix_expressionContext
>
> + def enterPostfix_expression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#postfix_expression.
>
> + # @param ctx Type: CParser.Postfix_expressionContext
>
> + def exitPostfix_expression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#macro_parameter_list.
>
> + # @param ctx Type: CParser.Macro_parameter_listContext
>
> + def enterMacro_parameter_list(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#macro_parameter_list.
>
> + # @param ctx Type: CParser.Macro_parameter_listContext
>
> + def exitMacro_parameter_list(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#unary_operator.
>
> + # @param ctx Type: CParser.Unary_operatorContext
>
> + def enterUnary_operator(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#unary_operator.
>
> + # @param ctx Type: CParser.Unary_operatorContext
>
> + def exitUnary_operator(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#primary_expression.
>
> + # @param ctx Type: CParser.Primary_expressionContext
>
> + def enterPrimary_expression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#primary_expression.
>
> + # @param ctx Type: CParser.Primary_expressionContext
>
> + def exitPrimary_expression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#constant.
>
> + # @param ctx Type: CParser.ConstantContext
>
> + def enterConstant(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#constant.
>
> + # @param ctx Type: CParser.ConstantContext
>
> + def exitConstant(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#expression.
>
> + # @param ctx Type: CParser.ExpressionContext
>
> + def enterExpression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#expression.
>
> + # @param ctx Type: CParser.ExpressionContext
>
> + def exitExpression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#constant_expression.
>
> + # @param ctx Type: CParser.Constant_expressionContext
>
> + def enterConstant_expression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#constant_expression.
>
> + # @param ctx Type: CParser.Constant_expressionContext
>
> + def exitConstant_expression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#assignment_expression.
>
> + # @param ctx Type: CParser.Assignment_expressionContext
>
> + def enterAssignment_expression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#assignment_expression.
>
> + # @param ctx Type: CParser.Assignment_expressionContext
>
> + def exitAssignment_expression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#lvalue.
>
> + # @param ctx Type: CParser.LvalueContext
>
> + def enterLvalue(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#lvalue.
>
> + # @param ctx Type: CParser.LvalueContext
>
> + def exitLvalue(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#assignment_operator.
>
> + # @param ctx Type: CParser.Assignment_operatorContext
>
> + def enterAssignment_operator(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#assignment_operator.
>
> + # @param ctx Type: CParser.Assignment_operatorContext
>
> + def exitAssignment_operator(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#conditional_expression.
>
> + # @param ctx Type: CParser.Conditional_expressionContext
>
> + def enterConditional_expression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#conditional_expression.
>
> + # @param ctx Type: CParser.Conditional_expressionContext
>
> + def exitConditional_expression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#logical_or_expression.
>
> + # @param ctx Type: CParser.Logical_or_expressionContext
>
> + def enterLogical_or_expression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#logical_or_expression.
>
> + # @param ctx Type: CParser.Logical_or_expressionContext
>
> + def exitLogical_or_expression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#logical_and_expression.
>
> + # @param ctx Type: CParser.Logical_and_expressionContext
>
> + def enterLogical_and_expression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#logical_and_expression.
>
> + # @param ctx Type: CParser.Logical_and_expressionContext
>
> + def exitLogical_and_expression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#inclusive_or_expression.
>
> + # @param ctx Type: CParser.Inclusive_or_expressionContext
>
> + def enterInclusive_or_expression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#inclusive_or_expression.
>
> + # @param ctx Type: CParser.Inclusive_or_expressionContext
>
> + def exitInclusive_or_expression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#exclusive_or_expression.
>
> + # @param ctx Type: CParser.Exclusive_or_expressionContext
>
> + def enterExclusive_or_expression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#exclusive_or_expression.
>
> + # @param ctx Type: CParser.Exclusive_or_expressionContext
>
> + def exitExclusive_or_expression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#and_expression.
>
> + # @param ctx Type: CParser.And_expressionContext
>
> + def enterAnd_expression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#and_expression.
>
> + # @param ctx Type: CParser.And_expressionContext
>
> + def exitAnd_expression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#equality_expression.
>
> + # @param ctx Type: CParser.Equality_expressionContext
>
> + def enterEquality_expression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#equality_expression.
>
> + # @param ctx Type: CParser.Equality_expressionContext
>
> + def exitEquality_expression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#relational_expression.
>
> + # @param ctx Type: CParser.Relational_expressionContext
>
> + def enterRelational_expression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#relational_expression.
>
> + # @param ctx Type: CParser.Relational_expressionContext
>
> + def exitRelational_expression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#shift_expression.
>
> + # @param ctx Type: CParser.Shift_expressionContext
>
> + def enterShift_expression(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#shift_expression.
>
> + # @param ctx Type: CParser.Shift_expressionContext
>
> + def exitShift_expression(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#statement.
>
> + # @param ctx Type: CParser.StatementContext
>
> + def enterStatement(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#statement.
>
> + # @param ctx Type: CParser.StatementContext
>
> + def exitStatement(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#asm2_statement.
>
> + # @param ctx Type: CParser.Asm2_statementContext
>
> + def enterAsm2_statement(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#asm2_statement.
>
> + # @param ctx Type: CParser.Asm2_statementContext
>
> + def exitAsm2_statement(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#asm1_statement.
>
> + # @param ctx Type: CParser.Asm1_statementContext
>
> + def enterAsm1_statement(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#asm1_statement.
>
> + # @param ctx Type: CParser.Asm1_statementContext
>
> + def exitAsm1_statement(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#asm_statement.
>
> + # @param ctx Type: CParser.Asm_statementContext
>
> + def enterAsm_statement(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#asm_statement.
>
> + # @param ctx Type: CParser.Asm_statementContext
>
> + def exitAsm_statement(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#macro_statement.
>
> + # @param ctx Type: CParser.Macro_statementContext
>
> + def enterMacro_statement(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#macro_statement.
>
> + # @param ctx Type: CParser.Macro_statementContext
>
> + def exitMacro_statement(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#labeled_statement.
>
> + # @param ctx Type: CParser.Labeled_statementContext
>
> + def enterLabeled_statement(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#labeled_statement.
>
> + # @param ctx Type: CParser.Labeled_statementContext
>
> + def exitLabeled_statement(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#compound_statement.
>
> + # @param ctx Type: CParser.Compound_statementContext
>
> + def enterCompound_statement(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#compound_statement.
>
> + # @param ctx Type: CParser.Compound_statementContext
>
> + def exitCompound_statement(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#statement_list.
>
> + # @param ctx Type: CParser.Statement_listContext
>
> + def enterStatement_list(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#statement_list.
>
> + # @param ctx Type: CParser.Statement_listContext
>
> + def exitStatement_list(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#expression_statement.
>
> + # @param ctx Type: CParser.Expression_statementContext
>
> + def enterExpression_statement(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#expression_statement.
>
> + # @param ctx Type: CParser.Expression_statementContext
>
> + def exitExpression_statement(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#selection_statement.
>
> + # @param ctx Type: CParser.Selection_statementContext
>
> + def enterSelection_statement(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#selection_statement.
>
> + # @param ctx Type: CParser.Selection_statementContext
>
> + def exitSelection_statement(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#iteration_statement.
>
> + # @param ctx Type: CParser.Iteration_statementContext
>
> + def enterIteration_statement(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#iteration_statement.
>
> + # @param ctx Type: CParser.Iteration_statementContext
>
> + def exitIteration_statement(self,ctx):
>
> + pass
>
> +
>
> +
>
> + # Enter a parse tree produced by CParser#jump_statement.
>
> + # @param ctx Type: CParser.Jump_statementContext
>
> + def enterJump_statement(self,ctx):
>
> + pass
>
> +
>
> + # Exit a parse tree produced by CParser#jump_statement.
>
> + # @param ctx Type: CParser.Jump_statementContext
>
> + def exitJump_statement(self,ctx):
>
> + pass
>
> +
>
> +
>
> diff --git a/BaseTools/Source/Python/Eot/CParser4/CParser.py b/BaseTools/Source/Python/Eot/CParser4/CParser.py
> new file mode 100644
> index 0000000000..08d8a423f4
> --- /dev/null
> +++ b/BaseTools/Source/Python/Eot/CParser4/CParser.py
> @@ -0,0 +1,6279 @@
> +# Generated from C.g4 by ANTLR 4.7.1
>
> +# encoding: utf-8
>
> +from antlr4 import *
>
> +from io import StringIO
>
> +from typing.io import TextIO
>
> +import sys
>
> +
>
> +
>
> +## @file
>
> +# The file defines the parser for C source files.
>
> +#
>
> +# THIS FILE IS AUTO-GENENERATED. PLEASE DON NOT MODIFY THIS FILE.
>
> +# This file is generated by running:
>
> +# java org.antlr.Tool C.g
>
> +#
>
> +# Copyright (c) 2009 - 2010, Intel Corporation All rights reserved.
>
> +#
>
> +# This program and the accompanying materials are licensed and made available
>
> +# under the terms and conditions of the BSD License which accompanies this
>
> +# distribution. The full text of the license may be found at:
>
> +# http://opensource.org/licenses/bsd-license.php
>
> +#
>
> +# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
>
> +# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
>
> +#
>
> +##
>
> +
>
> +import Ecc.CodeFragment as CodeFragment
>
> +import Ecc.FileProfile as FileProfile
>
> +
>
> +def serializedATN():
>
> + with StringIO() as buf:
>
> + buf.write("\3\u608b\ua72a\u8133\ub9ed\u417c\u3be7\u7786\u5964\3k")
>
> + buf.write("\u0380\4\2\t\2\4\3\t\3\4\4\t\4\4\5\t\5\4\6\t\6\4\7\t\7")
>
> + buf.write("\4\b\t\b\4\t\t\t\4\n\t\n\4\13\t\13\4\f\t\f\4\r\t\r\4\16")
>
> + buf.write("\t\16\4\17\t\17\4\20\t\20\4\21\t\21\4\22\t\22\4\23\t\23")
>
> + buf.write("\4\24\t\24\4\25\t\25\4\26\t\26\4\27\t\27\4\30\t\30\4\31")
>
> + buf.write("\t\31\4\32\t\32\4\33\t\33\4\34\t\34\4\35\t\35\4\36\t\36")
>
> + buf.write("\4\37\t\37\4 \t \4!\t!\4\"\t\"\4#\t#\4$\t$\4%\t%\4&\t")
>
> + buf.write("&\4\'\t\'\4(\t(\4)\t)\4*\t*\4+\t+\4,\t,\4-\t-\4.\t.\4")
>
> + buf.write("/\t/\4\60\t\60\4\61\t\61\4\62\t\62\4\63\t\63\4\64\t\64")
>
> + buf.write("\4\65\t\65\4\66\t\66\4\67\t\67\48\t8\49\t9\4:\t:\4;\t")
>
> + buf.write(";\4<\t<\4=\t=\4>\t>\4?\t?\4@\t@\4A\tA\4B\tB\4C\tC\4D\t")
>
> + buf.write("D\4E\tE\4F\tF\4G\tG\4H\tH\3\2\7\2\u0092\n\2\f\2\16\2\u0095")
>
> + buf.write("\13\2\3\3\5\3\u0098\n\3\3\3\3\3\7\3\u009c\n\3\f\3\16\3")
>
> + buf.write("\u009f\13\3\3\3\3\3\3\3\3\3\3\3\3\3\5\3\u00a7\n\3\5\3")
>
> + buf.write("\u00a9\n\3\3\4\5\4\u00ac\n\4\3\4\3\4\6\4\u00b0\n\4\r\4")
>
> + buf.write("\16\4\u00b1\3\4\3\4\3\4\5\4\u00b7\n\4\3\4\3\4\3\5\3\5")
>
> + buf.write("\3\5\6\5\u00be\n\5\r\5\16\5\u00bf\3\6\3\6\5\6\u00c4\n")
>
> + buf.write("\6\3\6\3\6\3\6\3\6\3\6\3\6\5\6\u00cc\n\6\3\6\3\6\3\6\5")
>
> + buf.write("\6\u00d1\n\6\3\7\3\7\3\7\7\7\u00d6\n\7\f\7\16\7\u00d9")
>
> + buf.write("\13\7\3\b\3\b\3\b\5\b\u00de\n\b\3\t\3\t\3\n\3\n\3\n\3")
>
> + buf.write("\n\3\n\3\n\3\n\3\n\3\n\3\n\3\n\3\n\3\n\3\n\3\n\3\n\3\n")
>
> + buf.write("\7\n\u00f3\n\n\f\n\16\n\u00f6\13\n\3\n\3\n\5\n\u00fa\n")
>
> + buf.write("\n\3\13\3\13\3\f\3\f\5\f\u0100\n\f\3\f\3\f\3\f\3\f\3\f")
>
> + buf.write("\3\f\3\f\5\f\u0109\n\f\3\r\3\r\3\16\6\16\u010e\n\16\r")
>
> + buf.write("\16\16\16\u010f\3\17\3\17\3\17\3\17\3\20\3\20\6\20\u0118")
>
> + buf.write("\n\20\r\20\16\20\u0119\3\21\3\21\3\21\7\21\u011f\n\21")
>
> + buf.write("\f\21\16\21\u0122\13\21\3\22\3\22\3\22\5\22\u0127\n\22")
>
> + buf.write("\3\22\3\22\5\22\u012b\n\22\3\23\3\23\3\23\3\23\5\23\u0131")
>
> + buf.write("\n\23\3\23\3\23\3\23\3\23\3\23\3\23\3\23\5\23\u013a\n")
>
> + buf.write("\23\3\23\3\23\3\23\3\23\5\23\u0140\n\23\3\24\3\24\3\24")
>
> + buf.write("\7\24\u0145\n\24\f\24\16\24\u0148\13\24\3\25\3\25\3\25")
>
> + buf.write("\5\25\u014d\n\25\3\26\3\26\3\27\5\27\u0152\n\27\3\27\5")
>
> + buf.write("\27\u0155\n\27\3\27\5\27\u0158\n\27\3\27\5\27\u015b\n")
>
> + buf.write("\27\3\27\3\27\5\27\u015f\n\27\3\30\3\30\7\30\u0163\n\30")
>
> + buf.write("\f\30\16\30\u0166\13\30\3\30\3\30\5\30\u016a\n\30\3\30")
>
> + buf.write("\3\30\3\30\6\30\u016f\n\30\r\30\16\30\u0170\5\30\u0173")
>
> + buf.write("\n\30\3\31\3\31\3\31\3\31\3\31\3\31\3\31\3\31\3\31\3\31")
>
> + buf.write("\3\31\3\31\3\31\3\31\3\31\3\31\5\31\u0185\n\31\3\32\3")
>
> + buf.write("\32\6\32\u0189\n\32\r\32\16\32\u018a\3\32\5\32\u018e\n")
>
> + buf.write("\32\3\32\3\32\3\32\5\32\u0193\n\32\3\33\3\33\3\33\5\33")
>
> + buf.write("\u0198\n\33\3\33\5\33\u019b\n\33\3\34\3\34\3\34\5\34\u01a0")
>
> + buf.write("\n\34\3\34\7\34\u01a3\n\34\f\34\16\34\u01a6\13\34\3\35")
>
> + buf.write("\3\35\3\35\7\35\u01ab\n\35\f\35\16\35\u01ae\13\35\3\35")
>
> + buf.write("\5\35\u01b1\n\35\3\35\7\35\u01b4\n\35\f\35\16\35\u01b7")
>
> + buf.write("\13\35\3\35\5\35\u01ba\n\35\3\36\3\36\3\36\7\36\u01bf")
>
> + buf.write("\n\36\f\36\16\36\u01c2\13\36\3\37\3\37\5\37\u01c6\n\37")
>
> + buf.write("\3\37\5\37\u01c9\n\37\3 \3 \5 \u01cd\n \3 \5 \u01d0\n")
>
> + buf.write(" \3!\3!\3!\3!\3!\5!\u01d7\n!\3!\7!\u01da\n!\f!\16!\u01dd")
>
> + buf.write("\13!\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\5")
>
> + buf.write("\"\u01eb\n\"\3#\3#\3#\3#\5#\u01f1\n#\3#\3#\5#\u01f5\n")
>
> + buf.write("#\3$\3$\3$\7$\u01fa\n$\f$\16$\u01fd\13$\3%\3%\5%\u0201")
>
> + buf.write("\n%\3%\3%\3%\5%\u0206\n%\7%\u0208\n%\f%\16%\u020b\13%")
>
> + buf.write("\3&\3&\3&\3&\3&\7&\u0212\n&\f&\16&\u0215\13&\3\'\3\'\3")
>
> + buf.write("\'\3\'\3\'\3\'\3\'\7\'\u021e\n\'\f\'\16\'\u0221\13\'\3")
>
> + buf.write("(\3(\3(\3(\3(\3(\5(\u0229\n(\3)\3)\3)\3)\3)\3)\3)\3)\3")
>
> + buf.write(")\3)\3)\3)\3)\3)\3)\5)\u023a\n)\3*\3*\3*\3*\3*\3*\3*\3")
>
> + buf.write("*\3*\3*\3*\3*\3*\3*\3*\3*\3*\3*\3*\3*\3*\3*\3*\3*\3*\3")
>
> + buf.write("*\3*\3*\3*\7*\u0259\n*\f*\16*\u025c\13*\3+\3+\3+\7+\u0261")
>
> + buf.write("\n+\f+\16+\u0264\13+\3,\3,\3-\3-\3-\3-\3-\3-\5-\u026e")
>
> + buf.write("\n-\3.\3.\3.\3.\3.\7.\u0275\n.\f.\16.\u0278\13.\3.\6.")
>
> + buf.write("\u027b\n.\r.\16.\u027c\6.\u027f\n.\r.\16.\u0280\3.\7.")
>
> + buf.write("\u0284\n.\f.\16.\u0287\13.\3.\5.\u028a\n.\3/\3/\3/\7/")
>
> + buf.write("\u028f\n/\f/\16/\u0292\13/\3\60\3\60\3\61\3\61\3\61\3")
>
> + buf.write("\61\3\61\5\61\u029b\n\61\3\62\3\62\3\63\3\63\3\64\3\64")
>
> + buf.write("\3\64\3\64\3\64\3\64\3\64\5\64\u02a8\n\64\3\65\3\65\3")
>
> + buf.write("\65\7\65\u02ad\n\65\f\65\16\65\u02b0\13\65\3\66\3\66\3")
>
> + buf.write("\66\7\66\u02b5\n\66\f\66\16\66\u02b8\13\66\3\67\3\67\3")
>
> + buf.write("\67\7\67\u02bd\n\67\f\67\16\67\u02c0\13\67\38\38\38\7")
>
> + buf.write("8\u02c5\n8\f8\168\u02c8\138\39\39\39\79\u02cd\n9\f9\16")
>
> + buf.write("9\u02d0\139\3:\3:\3:\7:\u02d5\n:\f:\16:\u02d8\13:\3;\3")
>
> + buf.write(";\3;\7;\u02dd\n;\f;\16;\u02e0\13;\3<\3<\3<\7<\u02e5\n")
>
> + buf.write("<\f<\16<\u02e8\13<\3=\3=\3=\3=\3=\3=\3=\3=\3=\3=\3=\5")
>
> + buf.write("=\u02f5\n=\3>\5>\u02f8\n>\3>\3>\3>\7>\u02fd\n>\f>\16>")
>
> + buf.write("\u0300\13>\3>\3>\3>\3?\3?\3?\7?\u0308\n?\f?\16?\u030b")
>
> + buf.write("\13?\3?\3?\3@\3@\3@\7@\u0312\n@\f@\16@\u0315\13@\3@\3")
>
> + buf.write("@\3A\3A\3A\7A\u031c\nA\fA\16A\u031f\13A\3A\5A\u0322\n")
>
> + buf.write("A\3A\5A\u0325\nA\3A\3A\3B\3B\3B\3B\3B\3B\3B\3B\3B\3B\3")
>
> + buf.write("B\5B\u0334\nB\3C\3C\7C\u0338\nC\fC\16C\u033b\13C\3C\5")
>
> + buf.write("C\u033e\nC\3C\3C\3D\6D\u0343\nD\rD\16D\u0344\3E\3E\3E")
>
> + buf.write("\3E\5E\u034b\nE\3F\3F\3F\3F\3F\3F\3F\3F\5F\u0355\nF\3")
>
> + buf.write("F\3F\3F\3F\3F\3F\5F\u035d\nF\3G\3G\3G\3G\3G\3G\3G\3G\3")
>
> + buf.write("G\3G\3G\3G\3G\3G\3G\3G\5G\u036f\nG\3H\3H\3H\3H\3H\3H\3")
>
> + buf.write("H\3H\3H\3H\3H\3H\3H\5H\u037e\nH\3H\2\2I\2\4\6\b\n\f\16")
>
> + buf.write("\20\22\24\26\30\32\34\36 \"$&(*,.\60\62\64\668:<>@BDF")
>
> + buf.write("HJLNPRTVXZ\\^`bdfhjlnprtvxz|~\u0080\u0082\u0084\u0086")
>
> + buf.write("\u0088\u008a\u008c\u008e\2\f\3\2\b\f\3\2\27\30\3\2\33")
>
> + buf.write("\'\5\2,,./\679\4\2\7\7:C\3\2IJ\3\2KN\3\2OP\3\2\4\4\3\2")
>
> + buf.write("\26\26\2\u03d8\2\u0093\3\2\2\2\4\u00a8\3\2\2\2\6\u00ab")
>
> + buf.write("\3\2\2\2\b\u00bd\3\2\2\2\n\u00d0\3\2\2\2\f\u00d2\3\2\2")
>
> + buf.write("\2\16\u00da\3\2\2\2\20\u00df\3\2\2\2\22\u00f9\3\2\2\2")
>
> + buf.write("\24\u00fb\3\2\2\2\26\u0108\3\2\2\2\30\u010a\3\2\2\2\32")
>
> + buf.write("\u010d\3\2\2\2\34\u0111\3\2\2\2\36\u0117\3\2\2\2 \u011b")
>
> + buf.write("\3\2\2\2\"\u012a\3\2\2\2$\u013f\3\2\2\2&\u0141\3\2\2\2")
>
> + buf.write("(\u0149\3\2\2\2*\u014e\3\2\2\2,\u015e\3\2\2\2.\u0172\3")
>
> + buf.write("\2\2\2\60\u0184\3\2\2\2\62\u0192\3\2\2\2\64\u0194\3\2")
>
> + buf.write("\2\2\66\u019c\3\2\2\28\u01b9\3\2\2\2:\u01bb\3\2\2\2<\u01c8")
>
> + buf.write("\3\2\2\2>\u01cf\3\2\2\2@\u01d6\3\2\2\2B\u01ea\3\2\2\2")
>
> + buf.write("D\u01f4\3\2\2\2F\u01f6\3\2\2\2H\u01fe\3\2\2\2J\u020c\3")
>
> + buf.write("\2\2\2L\u0216\3\2\2\2N\u0228\3\2\2\2P\u0239\3\2\2\2R\u023b")
>
> + buf.write("\3\2\2\2T\u025d\3\2\2\2V\u0265\3\2\2\2X\u026d\3\2\2\2")
>
> + buf.write("Z\u0289\3\2\2\2\\\u028b\3\2\2\2^\u0293\3\2\2\2`\u029a")
>
> + buf.write("\3\2\2\2b\u029c\3\2\2\2d\u029e\3\2\2\2f\u02a0\3\2\2\2")
>
> + buf.write("h\u02a9\3\2\2\2j\u02b1\3\2\2\2l\u02b9\3\2\2\2n\u02c1\3")
>
> + buf.write("\2\2\2p\u02c9\3\2\2\2r\u02d1\3\2\2\2t\u02d9\3\2\2\2v\u02e1")
>
> + buf.write("\3\2\2\2x\u02f4\3\2\2\2z\u02f7\3\2\2\2|\u0304\3\2\2\2")
>
> + buf.write("~\u030e\3\2\2\2\u0080\u0318\3\2\2\2\u0082\u0333\3\2\2")
>
> + buf.write("\2\u0084\u0335\3\2\2\2\u0086\u0342\3\2\2\2\u0088\u034a")
>
> + buf.write("\3\2\2\2\u008a\u035c\3\2\2\2\u008c\u036e\3\2\2\2\u008e")
>
> + buf.write("\u037d\3\2\2\2\u0090\u0092\5\4\3\2\u0091\u0090\3\2\2\2")
>
> + buf.write("\u0092\u0095\3\2\2\2\u0093\u0091\3\2\2\2\u0093\u0094\3")
>
> + buf.write("\2\2\2\u0094\3\3\2\2\2\u0095\u0093\3\2\2\2\u0096\u0098")
>
> + buf.write("\5\b\5\2\u0097\u0096\3\2\2\2\u0097\u0098\3\2\2\2\u0098")
>
> + buf.write("\u0099\3\2\2\2\u0099\u009d\5,\27\2\u009a\u009c\5\n\6\2")
>
> + buf.write("\u009b\u009a\3\2\2\2\u009c\u009f\3\2\2\2\u009d\u009b\3")
>
> + buf.write("\2\2\2\u009d\u009e\3\2\2\2\u009e\u00a0\3\2\2\2\u009f\u009d")
>
> + buf.write("\3\2\2\2\u00a0\u00a1\7\3\2\2\u00a1\u00a9\3\2\2\2\u00a2")
>
> + buf.write("\u00a9\5\6\4\2\u00a3\u00a9\5\n\6\2\u00a4\u00a6\5\u0080")
>
> + buf.write("A\2\u00a5\u00a7\7\4\2\2\u00a6\u00a5\3\2\2\2\u00a6\u00a7")
>
> + buf.write("\3\2\2\2\u00a7\u00a9\3\2\2\2\u00a8\u0097\3\2\2\2\u00a8")
>
> + buf.write("\u00a2\3\2\2\2\u00a8\u00a3\3\2\2\2\u00a8\u00a4\3\2\2\2")
>
> + buf.write("\u00a9\5\3\2\2\2\u00aa\u00ac\5\b\5\2\u00ab\u00aa\3\2\2")
>
> + buf.write("\2\u00ab\u00ac\3\2\2\2\u00ac\u00ad\3\2\2\2\u00ad\u00b6")
>
> + buf.write("\5,\27\2\u00ae\u00b0\5\n\6\2\u00af\u00ae\3\2\2\2\u00b0")
>
> + buf.write("\u00b1\3\2\2\2\u00b1\u00af\3\2\2\2\u00b1\u00b2\3\2\2\2")
>
> + buf.write("\u00b2\u00b3\3\2\2\2\u00b3\u00b4\5\u0084C\2\u00b4\u00b7")
>
> + buf.write("\3\2\2\2\u00b5\u00b7\5\u0084C\2\u00b6\u00af\3\2\2\2\u00b6")
>
> + buf.write("\u00b5\3\2\2\2\u00b7\u00b8\3\2\2\2\u00b8\u00b9\b\4\1\2")
>
> + buf.write("\u00b9\7\3\2\2\2\u00ba\u00be\5\20\t\2\u00bb\u00be\5\22")
>
> + buf.write("\n\2\u00bc\u00be\5*\26\2\u00bd\u00ba\3\2\2\2\u00bd\u00bb")
>
> + buf.write("\3\2\2\2\u00bd\u00bc\3\2\2\2\u00be\u00bf\3\2\2\2\u00bf")
>
> + buf.write("\u00bd\3\2\2\2\u00bf\u00c0\3\2\2\2\u00c0\t\3\2\2\2\u00c1")
>
> + buf.write("\u00c3\7\5\2\2\u00c2\u00c4\5\b\5\2\u00c3\u00c2\3\2\2\2")
>
> + buf.write("\u00c3\u00c4\3\2\2\2\u00c4\u00c5\3\2\2\2\u00c5\u00c6\5")
>
> + buf.write("\f\7\2\u00c6\u00c7\7\4\2\2\u00c7\u00c8\b\6\1\2\u00c8\u00d1")
>
> + buf.write("\3\2\2\2\u00c9\u00cb\5\b\5\2\u00ca\u00cc\5\f\7\2\u00cb")
>
> + buf.write("\u00ca\3\2\2\2\u00cb\u00cc\3\2\2\2\u00cc\u00cd\3\2\2\2")
>
> + buf.write("\u00cd\u00ce\7\4\2\2\u00ce\u00cf\b\6\1\2\u00cf\u00d1\3")
>
> + buf.write("\2\2\2\u00d0\u00c1\3\2\2\2\u00d0\u00c9\3\2\2\2\u00d1\13")
>
> + buf.write("\3\2\2\2\u00d2\u00d7\5\16\b\2\u00d3\u00d4\7\6\2\2\u00d4")
>
> + buf.write("\u00d6\5\16\b\2\u00d5\u00d3\3\2\2\2\u00d6\u00d9\3\2\2")
>
> + buf.write("\2\u00d7\u00d5\3\2\2\2\u00d7\u00d8\3\2\2\2\u00d8\r\3\2")
>
> + buf.write("\2\2\u00d9\u00d7\3\2\2\2\u00da\u00dd\5,\27\2\u00db\u00dc")
>
> + buf.write("\7\7\2\2\u00dc\u00de\5D#\2\u00dd\u00db\3\2\2\2\u00dd\u00de")
>
> + buf.write("\3\2\2\2\u00de\17\3\2\2\2\u00df\u00e0\t\2\2\2\u00e0\21")
>
> + buf.write("\3\2\2\2\u00e1\u00fa\7\r\2\2\u00e2\u00fa\7\16\2\2\u00e3")
>
> + buf.write("\u00fa\7\17\2\2\u00e4\u00fa\7\20\2\2\u00e5\u00fa\7\21")
>
> + buf.write("\2\2\u00e6\u00fa\7\22\2\2\u00e7\u00fa\7\23\2\2\u00e8\u00fa")
>
> + buf.write("\7\24\2\2\u00e9\u00fa\7\25\2\2\u00ea\u00eb\5\26\f\2\u00eb")
>
> + buf.write("\u00ec\b\n\1\2\u00ec\u00fa\3\2\2\2\u00ed\u00ee\5$\23\2")
>
> + buf.write("\u00ee\u00ef\b\n\1\2\u00ef\u00fa\3\2\2\2\u00f0\u00f4\7")
>
> + buf.write("_\2\2\u00f1\u00f3\5*\26\2\u00f2\u00f1\3\2\2\2\u00f3\u00f6")
>
> + buf.write("\3\2\2\2\u00f4\u00f2\3\2\2\2\u00f4\u00f5\3\2\2\2\u00f5")
>
> + buf.write("\u00f7\3\2\2\2\u00f6\u00f4\3\2\2\2\u00f7\u00fa\5,\27\2")
>
> + buf.write("\u00f8\u00fa\5\24\13\2\u00f9\u00e1\3\2\2\2\u00f9\u00e2")
>
> + buf.write("\3\2\2\2\u00f9\u00e3\3\2\2\2\u00f9\u00e4\3\2\2\2\u00f9")
>
> + buf.write("\u00e5\3\2\2\2\u00f9\u00e6\3\2\2\2\u00f9\u00e7\3\2\2\2")
>
> + buf.write("\u00f9\u00e8\3\2\2\2\u00f9\u00e9\3\2\2\2\u00f9\u00ea\3")
>
> + buf.write("\2\2\2\u00f9\u00ed\3\2\2\2\u00f9\u00f0\3\2\2\2\u00f9\u00f8")
>
> + buf.write("\3\2\2\2\u00fa\23\3\2\2\2\u00fb\u00fc\7_\2\2\u00fc\25")
>
> + buf.write("\3\2\2\2\u00fd\u00ff\5\30\r\2\u00fe\u0100\7_\2\2\u00ff")
>
> + buf.write("\u00fe\3\2\2\2\u00ff\u0100\3\2\2\2\u0100\u0101\3\2\2\2")
>
> + buf.write("\u0101\u0102\7\3\2\2\u0102\u0103\5\32\16\2\u0103\u0104")
>
> + buf.write("\7\26\2\2\u0104\u0109\3\2\2\2\u0105\u0106\5\30\r\2\u0106")
>
> + buf.write("\u0107\7_\2\2\u0107\u0109\3\2\2\2\u0108\u00fd\3\2\2\2")
>
> + buf.write("\u0108\u0105\3\2\2\2\u0109\27\3\2\2\2\u010a\u010b\t\3")
>
> + buf.write("\2\2\u010b\31\3\2\2\2\u010c\u010e\5\34\17\2\u010d\u010c")
>
> + buf.write("\3\2\2\2\u010e\u010f\3\2\2\2\u010f\u010d\3\2\2\2\u010f")
>
> + buf.write("\u0110\3\2\2\2\u0110\33\3\2\2\2\u0111\u0112\5\36\20\2")
>
> + buf.write("\u0112\u0113\5 \21\2\u0113\u0114\7\4\2\2\u0114\35\3\2")
>
> + buf.write("\2\2\u0115\u0118\5*\26\2\u0116\u0118\5\22\n\2\u0117\u0115")
>
> + buf.write("\3\2\2\2\u0117\u0116\3\2\2\2\u0118\u0119\3\2\2\2\u0119")
>
> + buf.write("\u0117\3\2\2\2\u0119\u011a\3\2\2\2\u011a\37\3\2\2\2\u011b")
>
> + buf.write("\u0120\5\"\22\2\u011c\u011d\7\6\2\2\u011d\u011f\5\"\22")
>
> + buf.write("\2\u011e\u011c\3\2\2\2\u011f\u0122\3\2\2\2\u0120\u011e")
>
> + buf.write("\3\2\2\2\u0120\u0121\3\2\2\2\u0121!\3\2\2\2\u0122\u0120")
>
> + buf.write("\3\2\2\2\u0123\u0126\5,\27\2\u0124\u0125\7\31\2\2\u0125")
>
> + buf.write("\u0127\5^\60\2\u0126\u0124\3\2\2\2\u0126\u0127\3\2\2\2")
>
> + buf.write("\u0127\u012b\3\2\2\2\u0128\u0129\7\31\2\2\u0129\u012b")
>
> + buf.write("\5^\60\2\u012a\u0123\3\2\2\2\u012a\u0128\3\2\2\2\u012b")
>
> + buf.write("#\3\2\2\2\u012c\u012d\7\32\2\2\u012d\u012e\7\3\2\2\u012e")
>
> + buf.write("\u0130\5&\24\2\u012f\u0131\7\6\2\2\u0130\u012f\3\2\2\2")
>
> + buf.write("\u0130\u0131\3\2\2\2\u0131\u0132\3\2\2\2\u0132\u0133\7")
>
> + buf.write("\26\2\2\u0133\u0140\3\2\2\2\u0134\u0135\7\32\2\2\u0135")
>
> + buf.write("\u0136\7_\2\2\u0136\u0137\7\3\2\2\u0137\u0139\5&\24\2")
>
> + buf.write("\u0138\u013a\7\6\2\2\u0139\u0138\3\2\2\2\u0139\u013a\3")
>
> + buf.write("\2\2\2\u013a\u013b\3\2\2\2\u013b\u013c\7\26\2\2\u013c")
>
> + buf.write("\u0140\3\2\2\2\u013d\u013e\7\32\2\2\u013e\u0140\7_\2\2")
>
> + buf.write("\u013f\u012c\3\2\2\2\u013f\u0134\3\2\2\2\u013f\u013d\3")
>
> + buf.write("\2\2\2\u0140%\3\2\2\2\u0141\u0146\5(\25\2\u0142\u0143")
>
> + buf.write("\7\6\2\2\u0143\u0145\5(\25\2\u0144\u0142\3\2\2\2\u0145")
>
> + buf.write("\u0148\3\2\2\2\u0146\u0144\3\2\2\2\u0146\u0147\3\2\2\2")
>
> + buf.write("\u0147\'\3\2\2\2\u0148\u0146\3\2\2\2\u0149\u014c\7_\2")
>
> + buf.write("\2\u014a\u014b\7\7\2\2\u014b\u014d\5^\60\2\u014c\u014a")
>
> + buf.write("\3\2\2\2\u014c\u014d\3\2\2\2\u014d)\3\2\2\2\u014e\u014f")
>
> + buf.write("\t\4\2\2\u014f+\3\2\2\2\u0150\u0152\5\62\32\2\u0151\u0150")
>
> + buf.write("\3\2\2\2\u0151\u0152\3\2\2\2\u0152\u0154\3\2\2\2\u0153")
>
> + buf.write("\u0155\7$\2\2\u0154\u0153\3\2\2\2\u0154\u0155\3\2\2\2")
>
> + buf.write("\u0155\u0157\3\2\2\2\u0156\u0158\7%\2\2\u0157\u0156\3")
>
> + buf.write("\2\2\2\u0157\u0158\3\2\2\2\u0158\u015a\3\2\2\2\u0159\u015b")
>
> + buf.write("\7&\2\2\u015a\u0159\3\2\2\2\u015a\u015b\3\2\2\2\u015b")
>
> + buf.write("\u015c\3\2\2\2\u015c\u015f\5.\30\2\u015d\u015f\5\62\32")
>
> + buf.write("\2\u015e\u0151\3\2\2\2\u015e\u015d\3\2\2\2\u015f-\3\2")
>
> + buf.write("\2\2\u0160\u0164\7_\2\2\u0161\u0163\5\60\31\2\u0162\u0161")
>
> + buf.write("\3\2\2\2\u0163\u0166\3\2\2\2\u0164\u0162\3\2\2\2\u0164")
>
> + buf.write("\u0165\3\2\2\2\u0165\u0173\3\2\2\2\u0166\u0164\3\2\2\2")
>
> + buf.write("\u0167\u0169\7(\2\2\u0168\u016a\7$\2\2\u0169\u0168\3\2")
>
> + buf.write("\2\2\u0169\u016a\3\2\2\2\u016a\u016b\3\2\2\2\u016b\u016c")
>
> + buf.write("\5,\27\2\u016c\u016e\7)\2\2\u016d\u016f\5\60\31\2\u016e")
>
> + buf.write("\u016d\3\2\2\2\u016f\u0170\3\2\2\2\u0170\u016e\3\2\2\2")
>
> + buf.write("\u0170\u0171\3\2\2\2\u0171\u0173\3\2\2\2\u0172\u0160\3")
>
> + buf.write("\2\2\2\u0172\u0167\3\2\2\2\u0173/\3\2\2\2\u0174\u0175")
>
> + buf.write("\7*\2\2\u0175\u0176\5^\60\2\u0176\u0177\7+\2\2\u0177\u0185")
>
> + buf.write("\3\2\2\2\u0178\u0179\7*\2\2\u0179\u0185\7+\2\2\u017a\u017b")
>
> + buf.write("\7(\2\2\u017b\u017c\5\64\33\2\u017c\u017d\7)\2\2\u017d")
>
> + buf.write("\u0185\3\2\2\2\u017e\u017f\7(\2\2\u017f\u0180\5:\36\2")
>
> + buf.write("\u0180\u0181\7)\2\2\u0181\u0185\3\2\2\2\u0182\u0183\7")
>
> + buf.write("(\2\2\u0183\u0185\7)\2\2\u0184\u0174\3\2\2\2\u0184\u0178")
>
> + buf.write("\3\2\2\2\u0184\u017a\3\2\2\2\u0184\u017e\3\2\2\2\u0184")
>
> + buf.write("\u0182\3\2\2\2\u0185\61\3\2\2\2\u0186\u0188\7,\2\2\u0187")
>
> + buf.write("\u0189\5*\26\2\u0188\u0187\3\2\2\2\u0189\u018a\3\2\2\2")
>
> + buf.write("\u018a\u0188\3\2\2\2\u018a\u018b\3\2\2\2\u018b\u018d\3")
>
> + buf.write("\2\2\2\u018c\u018e\5\62\32\2\u018d\u018c\3\2\2\2\u018d")
>
> + buf.write("\u018e\3\2\2\2\u018e\u0193\3\2\2\2\u018f\u0190\7,\2\2")
>
> + buf.write("\u0190\u0193\5\62\32\2\u0191\u0193\7,\2\2\u0192\u0186")
>
> + buf.write("\3\2\2\2\u0192\u018f\3\2\2\2\u0192\u0191\3\2\2\2\u0193")
>
> + buf.write("\63\3\2\2\2\u0194\u019a\5\66\34\2\u0195\u0197\7\6\2\2")
>
> + buf.write("\u0196\u0198\7\37\2\2\u0197\u0196\3\2\2\2\u0197\u0198")
>
> + buf.write("\3\2\2\2\u0198\u0199\3\2\2\2\u0199\u019b\7-\2\2\u019a")
>
> + buf.write("\u0195\3\2\2\2\u019a\u019b\3\2\2\2\u019b\65\3\2\2\2\u019c")
>
> + buf.write("\u01a4\58\35\2\u019d\u019f\7\6\2\2\u019e\u01a0\7\37\2")
>
> + buf.write("\2\u019f\u019e\3\2\2\2\u019f\u01a0\3\2\2\2\u01a0\u01a1")
>
> + buf.write("\3\2\2\2\u01a1\u01a3\58\35\2\u01a2\u019d\3\2\2\2\u01a3")
>
> + buf.write("\u01a6\3\2\2\2\u01a4\u01a2\3\2\2\2\u01a4\u01a5\3\2\2\2")
>
> + buf.write("\u01a5\67\3\2\2\2\u01a6\u01a4\3\2\2\2\u01a7\u01ac\5\b")
>
> + buf.write("\5\2\u01a8\u01ab\5,\27\2\u01a9\u01ab\5> \2\u01aa\u01a8")
>
> + buf.write("\3\2\2\2\u01aa\u01a9\3\2\2\2\u01ab\u01ae\3\2\2\2\u01ac")
>
> + buf.write("\u01aa\3\2\2\2\u01ac\u01ad\3\2\2\2\u01ad\u01b0\3\2\2\2")
>
> + buf.write("\u01ae\u01ac\3\2\2\2\u01af\u01b1\7\37\2\2\u01b0\u01af")
>
> + buf.write("\3\2\2\2\u01b0\u01b1\3\2\2\2\u01b1\u01ba\3\2\2\2\u01b2")
>
> + buf.write("\u01b4\5\62\32\2\u01b3\u01b2\3\2\2\2\u01b4\u01b7\3\2\2")
>
> + buf.write("\2\u01b5\u01b3\3\2\2\2\u01b5\u01b6\3\2\2\2\u01b6\u01b8")
>
> + buf.write("\3\2\2\2\u01b7\u01b5\3\2\2\2\u01b8\u01ba\7_\2\2\u01b9")
>
> + buf.write("\u01a7\3\2\2\2\u01b9\u01b5\3\2\2\2\u01ba9\3\2\2\2\u01bb")
>
> + buf.write("\u01c0\7_\2\2\u01bc\u01bd\7\6\2\2\u01bd\u01bf\7_\2\2\u01be")
>
> + buf.write("\u01bc\3\2\2\2\u01bf\u01c2\3\2\2\2\u01c0\u01be\3\2\2\2")
>
> + buf.write("\u01c0\u01c1\3\2\2\2\u01c1;\3\2\2\2\u01c2\u01c0\3\2\2")
>
> + buf.write("\2\u01c3\u01c5\5\36\20\2\u01c4\u01c6\5> \2\u01c5\u01c4")
>
> + buf.write("\3\2\2\2\u01c5\u01c6\3\2\2\2\u01c6\u01c9\3\2\2\2\u01c7")
>
> + buf.write("\u01c9\5\24\13\2\u01c8\u01c3\3\2\2\2\u01c8\u01c7\3\2\2")
>
> + buf.write("\2\u01c9=\3\2\2\2\u01ca\u01cc\5\62\32\2\u01cb\u01cd\5")
>
> + buf.write("@!\2\u01cc\u01cb\3\2\2\2\u01cc\u01cd\3\2\2\2\u01cd\u01d0")
>
> + buf.write("\3\2\2\2\u01ce\u01d0\5@!\2\u01cf\u01ca\3\2\2\2\u01cf\u01ce")
>
> + buf.write("\3\2\2\2\u01d0?\3\2\2\2\u01d1\u01d2\7(\2\2\u01d2\u01d3")
>
> + buf.write("\5> \2\u01d3\u01d4\7)\2\2\u01d4\u01d7\3\2\2\2\u01d5\u01d7")
>
> + buf.write("\5B\"\2\u01d6\u01d1\3\2\2\2\u01d6\u01d5\3\2\2\2\u01d7")
>
> + buf.write("\u01db\3\2\2\2\u01d8\u01da\5B\"\2\u01d9\u01d8\3\2\2\2")
>
> + buf.write("\u01da\u01dd\3\2\2\2\u01db\u01d9\3\2\2\2\u01db\u01dc\3")
>
> + buf.write("\2\2\2\u01dcA\3\2\2\2\u01dd\u01db\3\2\2\2\u01de\u01df")
>
> + buf.write("\7*\2\2\u01df\u01eb\7+\2\2\u01e0\u01e1\7*\2\2\u01e1\u01e2")
>
> + buf.write("\5^\60\2\u01e2\u01e3\7+\2\2\u01e3\u01eb\3\2\2\2\u01e4")
>
> + buf.write("\u01e5\7(\2\2\u01e5\u01eb\7)\2\2\u01e6\u01e7\7(\2\2\u01e7")
>
> + buf.write("\u01e8\5\64\33\2\u01e8\u01e9\7)\2\2\u01e9\u01eb\3\2\2")
>
> + buf.write("\2\u01ea\u01de\3\2\2\2\u01ea\u01e0\3\2\2\2\u01ea\u01e4")
>
> + buf.write("\3\2\2\2\u01ea\u01e6\3\2\2\2\u01ebC\3\2\2\2\u01ec\u01f5")
>
> + buf.write("\5`\61\2\u01ed\u01ee\7\3\2\2\u01ee\u01f0\5F$\2\u01ef\u01f1")
>
> + buf.write("\7\6\2\2\u01f0\u01ef\3\2\2\2\u01f0\u01f1\3\2\2\2\u01f1")
>
> + buf.write("\u01f2\3\2\2\2\u01f2\u01f3\7\26\2\2\u01f3\u01f5\3\2\2")
>
> + buf.write("\2\u01f4\u01ec\3\2\2\2\u01f4\u01ed\3\2\2\2\u01f5E\3\2")
>
> + buf.write("\2\2\u01f6\u01fb\5D#\2\u01f7\u01f8\7\6\2\2\u01f8\u01fa")
>
> + buf.write("\5D#\2\u01f9\u01f7\3\2\2\2\u01fa\u01fd\3\2\2\2\u01fb\u01f9")
>
> + buf.write("\3\2\2\2\u01fb\u01fc\3\2\2\2\u01fcG\3\2\2\2\u01fd\u01fb")
>
> + buf.write("\3\2\2\2\u01fe\u0200\5`\61\2\u01ff\u0201\7\37\2\2\u0200")
>
> + buf.write("\u01ff\3\2\2\2\u0200\u0201\3\2\2\2\u0201\u0209\3\2\2\2")
>
> + buf.write("\u0202\u0203\7\6\2\2\u0203\u0205\5`\61\2\u0204\u0206\7")
>
> + buf.write("\37\2\2\u0205\u0204\3\2\2\2\u0205\u0206\3\2\2\2\u0206")
>
> + buf.write("\u0208\3\2\2\2\u0207\u0202\3\2\2\2\u0208\u020b\3\2\2\2")
>
> + buf.write("\u0209\u0207\3\2\2\2\u0209\u020a\3\2\2\2\u020aI\3\2\2")
>
> + buf.write("\2\u020b\u0209\3\2\2\2\u020c\u0213\5L\'\2\u020d\u020e")
>
> + buf.write("\7.\2\2\u020e\u0212\5L\'\2\u020f\u0210\7/\2\2\u0210\u0212")
>
> + buf.write("\5L\'\2\u0211\u020d\3\2\2\2\u0211\u020f\3\2\2\2\u0212")
>
> + buf.write("\u0215\3\2\2\2\u0213\u0211\3\2\2\2\u0213\u0214\3\2\2\2")
>
> + buf.write("\u0214K\3\2\2\2\u0215\u0213\3\2\2\2\u0216\u021f\5N(\2")
>
> + buf.write("\u0217\u0218\7,\2\2\u0218\u021e\5N(\2\u0219\u021a\7\60")
>
> + buf.write("\2\2\u021a\u021e\5N(\2\u021b\u021c\7\61\2\2\u021c\u021e")
>
> + buf.write("\5N(\2\u021d\u0217\3\2\2\2\u021d\u0219\3\2\2\2\u021d\u021b")
>
> + buf.write("\3\2\2\2\u021e\u0221\3\2\2\2\u021f\u021d\3\2\2\2\u021f")
>
> + buf.write("\u0220\3\2\2\2\u0220M\3\2\2\2\u0221\u021f\3\2\2\2\u0222")
>
> + buf.write("\u0223\7(\2\2\u0223\u0224\5<\37\2\u0224\u0225\7)\2\2\u0225")
>
> + buf.write("\u0226\5N(\2\u0226\u0229\3\2\2\2\u0227\u0229\5P)\2\u0228")
>
> + buf.write("\u0222\3\2\2\2\u0228\u0227\3\2\2\2\u0229O\3\2\2\2\u022a")
>
> + buf.write("\u023a\5R*\2\u022b\u022c\7\62\2\2\u022c\u023a\5P)\2\u022d")
>
> + buf.write("\u022e\7\63\2\2\u022e\u023a\5P)\2\u022f\u0230\5V,\2\u0230")
>
> + buf.write("\u0231\5N(\2\u0231\u023a\3\2\2\2\u0232\u0233\7\64\2\2")
>
> + buf.write("\u0233\u023a\5P)\2\u0234\u0235\7\64\2\2\u0235\u0236\7")
>
> + buf.write("(\2\2\u0236\u0237\5<\37\2\u0237\u0238\7)\2\2\u0238\u023a")
>
> + buf.write("\3\2\2\2\u0239\u022a\3\2\2\2\u0239\u022b\3\2\2\2\u0239")
>
> + buf.write("\u022d\3\2\2\2\u0239\u022f\3\2\2\2\u0239\u0232\3\2\2\2")
>
> + buf.write("\u0239\u0234\3\2\2\2\u023aQ\3\2\2\2\u023b\u023c\5X-\2")
>
> + buf.write("\u023c\u025a\b*\1\2\u023d\u023e\7*\2\2\u023e\u023f\5\\")
>
> + buf.write("/\2\u023f\u0240\7+\2\2\u0240\u0259\3\2\2\2\u0241\u0242")
>
> + buf.write("\7(\2\2\u0242\u0243\7)\2\2\u0243\u0259\b*\1\2\u0244\u0245")
>
> + buf.write("\7(\2\2\u0245\u0246\5H%\2\u0246\u0247\7)\2\2\u0247\u0248")
>
> + buf.write("\b*\1\2\u0248\u0259\3\2\2\2\u0249\u024a\7(\2\2\u024a\u024b")
>
> + buf.write("\5T+\2\u024b\u024c\7)\2\2\u024c\u0259\3\2\2\2\u024d\u024e")
>
> + buf.write("\7\65\2\2\u024e\u024f\7_\2\2\u024f\u0259\b*\1\2\u0250")
>
> + buf.write("\u0251\7,\2\2\u0251\u0252\7_\2\2\u0252\u0259\b*\1\2\u0253")
>
> + buf.write("\u0254\7\66\2\2\u0254\u0255\7_\2\2\u0255\u0259\b*\1\2")
>
> + buf.write("\u0256\u0259\7\62\2\2\u0257\u0259\7\63\2\2\u0258\u023d")
>
> + buf.write("\3\2\2\2\u0258\u0241\3\2\2\2\u0258\u0244\3\2\2\2\u0258")
>
> + buf.write("\u0249\3\2\2\2\u0258\u024d\3\2\2\2\u0258\u0250\3\2\2\2")
>
> + buf.write("\u0258\u0253\3\2\2\2\u0258\u0256\3\2\2\2\u0258\u0257\3")
>
> + buf.write("\2\2\2\u0259\u025c\3\2\2\2\u025a\u0258\3\2\2\2\u025a\u025b")
>
> + buf.write("\3\2\2\2\u025bS\3\2\2\2\u025c\u025a\3\2\2\2\u025d\u0262")
>
> + buf.write("\58\35\2\u025e\u025f\7\6\2\2\u025f\u0261\58\35\2\u0260")
>
> + buf.write("\u025e\3\2\2\2\u0261\u0264\3\2\2\2\u0262\u0260\3\2\2\2")
>
> + buf.write("\u0262\u0263\3\2\2\2\u0263U\3\2\2\2\u0264\u0262\3\2\2")
>
> + buf.write("\2\u0265\u0266\t\5\2\2\u0266W\3\2\2\2\u0267\u026e\7_\2")
>
> + buf.write("\2\u0268\u026e\5Z.\2\u0269\u026a\7(\2\2\u026a\u026b\5")
>
> + buf.write("\\/\2\u026b\u026c\7)\2\2\u026c\u026e\3\2\2\2\u026d\u0267")
>
> + buf.write("\3\2\2\2\u026d\u0268\3\2\2\2\u026d\u0269\3\2\2\2\u026e")
>
> + buf.write("Y\3\2\2\2\u026f\u028a\7b\2\2\u0270\u028a\7d\2\2\u0271")
>
> + buf.write("\u028a\7c\2\2\u0272\u028a\7`\2\2\u0273\u0275\7_\2\2\u0274")
>
> + buf.write("\u0273\3\2\2\2\u0275\u0278\3\2\2\2\u0276\u0274\3\2\2\2")
>
> + buf.write("\u0276\u0277\3\2\2\2\u0277\u027a\3\2\2\2\u0278\u0276\3")
>
> + buf.write("\2\2\2\u0279\u027b\7a\2\2\u027a\u0279\3\2\2\2\u027b\u027c")
>
> + buf.write("\3\2\2\2\u027c\u027a\3\2\2\2\u027c\u027d\3\2\2\2\u027d")
>
> + buf.write("\u027f\3\2\2\2\u027e\u0276\3\2\2\2\u027f\u0280\3\2\2\2")
>
> + buf.write("\u0280\u027e\3\2\2\2\u0280\u0281\3\2\2\2\u0281\u0285\3")
>
> + buf.write("\2\2\2\u0282\u0284\7_\2\2\u0283\u0282\3\2\2\2\u0284\u0287")
>
> + buf.write("\3\2\2\2\u0285\u0283\3\2\2\2\u0285\u0286\3\2\2\2\u0286")
>
> + buf.write("\u028a\3\2\2\2\u0287\u0285\3\2\2\2\u0288\u028a\7e\2\2")
>
> + buf.write("\u0289\u026f\3\2\2\2\u0289\u0270\3\2\2\2\u0289\u0271\3")
>
> + buf.write("\2\2\2\u0289\u0272\3\2\2\2\u0289\u027e\3\2\2\2\u0289\u0288")
>
> + buf.write("\3\2\2\2\u028a[\3\2\2\2\u028b\u0290\5`\61\2\u028c\u028d")
>
> + buf.write("\7\6\2\2\u028d\u028f\5`\61\2\u028e\u028c\3\2\2\2\u028f")
>
> + buf.write("\u0292\3\2\2\2\u0290\u028e\3\2\2\2\u0290\u0291\3\2\2\2")
>
> + buf.write("\u0291]\3\2\2\2\u0292\u0290\3\2\2\2\u0293\u0294\5f\64")
>
> + buf.write("\2\u0294_\3\2\2\2\u0295\u0296\5b\62\2\u0296\u0297\5d\63")
>
> + buf.write("\2\u0297\u0298\5`\61\2\u0298\u029b\3\2\2\2\u0299\u029b")
>
> + buf.write("\5f\64\2\u029a\u0295\3\2\2\2\u029a\u0299\3\2\2\2\u029b")
>
> + buf.write("a\3\2\2\2\u029c\u029d\5P)\2\u029dc\3\2\2\2\u029e\u029f")
>
> + buf.write("\t\6\2\2\u029fe\3\2\2\2\u02a0\u02a7\5h\65\2\u02a1\u02a2")
>
> + buf.write("\7D\2\2\u02a2\u02a3\5\\/\2\u02a3\u02a4\7\31\2\2\u02a4")
>
> + buf.write("\u02a5\5f\64\2\u02a5\u02a6\b\64\1\2\u02a6\u02a8\3\2\2")
>
> + buf.write("\2\u02a7\u02a1\3\2\2\2\u02a7\u02a8\3\2\2\2\u02a8g\3\2")
>
> + buf.write("\2\2\u02a9\u02ae\5j\66\2\u02aa\u02ab\7E\2\2\u02ab\u02ad")
>
> + buf.write("\5j\66\2\u02ac\u02aa\3\2\2\2\u02ad\u02b0\3\2\2\2\u02ae")
>
> + buf.write("\u02ac\3\2\2\2\u02ae\u02af\3\2\2\2\u02afi\3\2\2\2\u02b0")
>
> + buf.write("\u02ae\3\2\2\2\u02b1\u02b6\5l\67\2\u02b2\u02b3\7F\2\2")
>
> + buf.write("\u02b3\u02b5\5l\67\2\u02b4\u02b2\3\2\2\2\u02b5\u02b8\3")
>
> + buf.write("\2\2\2\u02b6\u02b4\3\2\2\2\u02b6\u02b7\3\2\2\2\u02b7k")
>
> + buf.write("\3\2\2\2\u02b8\u02b6\3\2\2\2\u02b9\u02be\5n8\2\u02ba\u02bb")
>
> + buf.write("\7G\2\2\u02bb\u02bd\5n8\2\u02bc\u02ba\3\2\2\2\u02bd\u02c0")
>
> + buf.write("\3\2\2\2\u02be\u02bc\3\2\2\2\u02be\u02bf\3\2\2\2\u02bf")
>
> + buf.write("m\3\2\2\2\u02c0\u02be\3\2\2\2\u02c1\u02c6\5p9\2\u02c2")
>
> + buf.write("\u02c3\7H\2\2\u02c3\u02c5\5p9\2\u02c4\u02c2\3\2\2\2\u02c5")
>
> + buf.write("\u02c8\3\2\2\2\u02c6\u02c4\3\2\2\2\u02c6\u02c7\3\2\2\2")
>
> + buf.write("\u02c7o\3\2\2\2\u02c8\u02c6\3\2\2\2\u02c9\u02ce\5r:\2")
>
> + buf.write("\u02ca\u02cb\7\67\2\2\u02cb\u02cd\5r:\2\u02cc\u02ca\3")
>
> + buf.write("\2\2\2\u02cd\u02d0\3\2\2\2\u02ce\u02cc\3\2\2\2\u02ce\u02cf")
>
> + buf.write("\3\2\2\2\u02cfq\3\2\2\2\u02d0\u02ce\3\2\2\2\u02d1\u02d6")
>
> + buf.write("\5t;\2\u02d2\u02d3\t\7\2\2\u02d3\u02d5\5t;\2\u02d4\u02d2")
>
> + buf.write("\3\2\2\2\u02d5\u02d8\3\2\2\2\u02d6\u02d4\3\2\2\2\u02d6")
>
> + buf.write("\u02d7\3\2\2\2\u02d7s\3\2\2\2\u02d8\u02d6\3\2\2\2\u02d9")
>
> + buf.write("\u02de\5v<\2\u02da\u02db\t\b\2\2\u02db\u02dd\5v<\2\u02dc")
>
> + buf.write("\u02da\3\2\2\2\u02dd\u02e0\3\2\2\2\u02de\u02dc\3\2\2\2")
>
> + buf.write("\u02de\u02df\3\2\2\2\u02dfu\3\2\2\2\u02e0\u02de\3\2\2")
>
> + buf.write("\2\u02e1\u02e6\5J&\2\u02e2\u02e3\t\t\2\2\u02e3\u02e5\5")
>
> + buf.write("J&\2\u02e4\u02e2\3\2\2\2\u02e5\u02e8\3\2\2\2\u02e6\u02e4")
>
> + buf.write("\3\2\2\2\u02e6\u02e7\3\2\2\2\u02e7w\3\2\2\2\u02e8\u02e6")
>
> + buf.write("\3\2\2\2\u02e9\u02f5\5\u0082B\2\u02ea\u02f5\5\u0084C\2")
>
> + buf.write("\u02eb\u02f5\5\u0088E\2\u02ec\u02f5\5\u008aF\2\u02ed\u02f5")
>
> + buf.write("\5\u008cG\2\u02ee\u02f5\5\u008eH\2\u02ef\u02f5\5\u0080")
>
> + buf.write("A\2\u02f0\u02f5\5z>\2\u02f1\u02f5\5|?\2\u02f2\u02f5\5")
>
> + buf.write("~@\2\u02f3\u02f5\5\n\6\2\u02f4\u02e9\3\2\2\2\u02f4\u02ea")
>
> + buf.write("\3\2\2\2\u02f4\u02eb\3\2\2\2\u02f4\u02ec\3\2\2\2\u02f4")
>
> + buf.write("\u02ed\3\2\2\2\u02f4\u02ee\3\2\2\2\u02f4\u02ef\3\2\2\2")
>
> + buf.write("\u02f4\u02f0\3\2\2\2\u02f4\u02f1\3\2\2\2\u02f4\u02f2\3")
>
> + buf.write("\2\2\2\u02f4\u02f3\3\2\2\2\u02f5y\3\2\2\2\u02f6\u02f8")
>
> + buf.write("\7Q\2\2\u02f7\u02f6\3\2\2\2\u02f7\u02f8\3\2\2\2\u02f8")
>
> + buf.write("\u02f9\3\2\2\2\u02f9\u02fa\7_\2\2\u02fa\u02fe\7(\2\2\u02fb")
>
> + buf.write("\u02fd\n\n\2\2\u02fc\u02fb\3\2\2\2\u02fd\u0300\3\2\2\2")
>
> + buf.write("\u02fe\u02fc\3\2\2\2\u02fe\u02ff\3\2\2\2\u02ff\u0301\3")
>
> + buf.write("\2\2\2\u0300\u02fe\3\2\2\2\u0301\u0302\7)\2\2\u0302\u0303")
>
> + buf.write("\7\4\2\2\u0303{\3\2\2\2\u0304\u0305\7R\2\2\u0305\u0309")
>
> + buf.write("\7\3\2\2\u0306\u0308\n\13\2\2\u0307\u0306\3\2\2\2\u0308")
>
> + buf.write("\u030b\3\2\2\2\u0309\u0307\3\2\2\2\u0309\u030a\3\2\2\2")
>
> + buf.write("\u030a\u030c\3\2\2\2\u030b\u0309\3\2\2\2\u030c\u030d\7")
>
> + buf.write("\26\2\2\u030d}\3\2\2\2\u030e\u030f\7S\2\2\u030f\u0313")
>
> + buf.write("\7\3\2\2\u0310\u0312\n\13\2\2\u0311\u0310\3\2\2\2\u0312")
>
> + buf.write("\u0315\3\2\2\2\u0313\u0311\3\2\2\2\u0313\u0314\3\2\2\2")
>
> + buf.write("\u0314\u0316\3\2\2\2\u0315\u0313\3\2\2\2\u0316\u0317\7")
>
> + buf.write("\26\2\2\u0317\177\3\2\2\2\u0318\u0319\7_\2\2\u0319\u031d")
>
> + buf.write("\7(\2\2\u031a\u031c\5\n\6\2\u031b\u031a\3\2\2\2\u031c")
>
> + buf.write("\u031f\3\2\2\2\u031d\u031b\3\2\2\2\u031d\u031e\3\2\2\2")
>
> + buf.write("\u031e\u0321\3\2\2\2\u031f\u031d\3\2\2\2\u0320\u0322\5")
>
> + buf.write("\u0086D\2\u0321\u0320\3\2\2\2\u0321\u0322\3\2\2\2\u0322")
>
> + buf.write("\u0324\3\2\2\2\u0323\u0325\5\\/\2\u0324\u0323\3\2\2\2")
>
> + buf.write("\u0324\u0325\3\2\2\2\u0325\u0326\3\2\2\2\u0326\u0327\7")
>
> + buf.write(")\2\2\u0327\u0081\3\2\2\2\u0328\u0329\7_\2\2\u0329\u032a")
>
> + buf.write("\7\31\2\2\u032a\u0334\5x=\2\u032b\u032c\7T\2\2\u032c\u032d")
>
> + buf.write("\5^\60\2\u032d\u032e\7\31\2\2\u032e\u032f\5x=\2\u032f")
>
> + buf.write("\u0334\3\2\2\2\u0330\u0331\7U\2\2\u0331\u0332\7\31\2\2")
>
> + buf.write("\u0332\u0334\5x=\2\u0333\u0328\3\2\2\2\u0333\u032b\3\2")
>
> + buf.write("\2\2\u0333\u0330\3\2\2\2\u0334\u0083\3\2\2\2\u0335\u0339")
>
> + buf.write("\7\3\2\2\u0336\u0338\5\n\6\2\u0337\u0336\3\2\2\2\u0338")
>
> + buf.write("\u033b\3\2\2\2\u0339\u0337\3\2\2\2\u0339\u033a\3\2\2\2")
>
> + buf.write("\u033a\u033d\3\2\2\2\u033b\u0339\3\2\2\2\u033c\u033e\5")
>
> + buf.write("\u0086D\2\u033d\u033c\3\2\2\2\u033d\u033e\3\2\2\2\u033e")
>
> + buf.write("\u033f\3\2\2\2\u033f\u0340\7\26\2\2\u0340\u0085\3\2\2")
>
> + buf.write("\2\u0341\u0343\5x=\2\u0342\u0341\3\2\2\2\u0343\u0344\3")
>
> + buf.write("\2\2\2\u0344\u0342\3\2\2\2\u0344\u0345\3\2\2\2\u0345\u0087")
>
> + buf.write("\3\2\2\2\u0346\u034b\7\4\2\2\u0347\u0348\5\\/\2\u0348")
>
> + buf.write("\u0349\7\4\2\2\u0349\u034b\3\2\2\2\u034a\u0346\3\2\2\2")
>
> + buf.write("\u034a\u0347\3\2\2\2\u034b\u0089\3\2\2\2\u034c\u034d\7")
>
> + buf.write("V\2\2\u034d\u034e\7(\2\2\u034e\u034f\5\\/\2\u034f\u0350")
>
> + buf.write("\7)\2\2\u0350\u0351\bF\1\2\u0351\u0354\5x=\2\u0352\u0353")
>
> + buf.write("\7W\2\2\u0353\u0355\5x=\2\u0354\u0352\3\2\2\2\u0354\u0355")
>
> + buf.write("\3\2\2\2\u0355\u035d\3\2\2\2\u0356\u0357\7X\2\2\u0357")
>
> + buf.write("\u0358\7(\2\2\u0358\u0359\5\\/\2\u0359\u035a\7)\2\2\u035a")
>
> + buf.write("\u035b\5x=\2\u035b\u035d\3\2\2\2\u035c\u034c\3\2\2\2\u035c")
>
> + buf.write("\u0356\3\2\2\2\u035d\u008b\3\2\2\2\u035e\u035f\7Y\2\2")
>
> + buf.write("\u035f\u0360\7(\2\2\u0360\u0361\5\\/\2\u0361\u0362\7)")
>
> + buf.write("\2\2\u0362\u0363\5x=\2\u0363\u0364\bG\1\2\u0364\u036f")
>
> + buf.write("\3\2\2\2\u0365\u0366\7Z\2\2\u0366\u0367\5x=\2\u0367\u0368")
>
> + buf.write("\7Y\2\2\u0368\u0369\7(\2\2\u0369\u036a\5\\/\2\u036a\u036b")
>
> + buf.write("\7)\2\2\u036b\u036c\7\4\2\2\u036c\u036d\bG\1\2\u036d\u036f")
>
> + buf.write("\3\2\2\2\u036e\u035e\3\2\2\2\u036e\u0365\3\2\2\2\u036f")
>
> + buf.write("\u008d\3\2\2\2\u0370\u0371\7[\2\2\u0371\u0372\7_\2\2\u0372")
>
> + buf.write("\u037e\7\4\2\2\u0373\u0374\7\\\2\2\u0374\u037e\7\4\2\2")
>
> + buf.write("\u0375\u0376\7]\2\2\u0376\u037e\7\4\2\2\u0377\u0378\7")
>
> + buf.write("^\2\2\u0378\u037e\7\4\2\2\u0379\u037a\7^\2\2\u037a\u037b")
>
> + buf.write("\5\\/\2\u037b\u037c\7\4\2\2\u037c\u037e\3\2\2\2\u037d")
>
> + buf.write("\u0370\3\2\2\2\u037d\u0373\3\2\2\2\u037d\u0375\3\2\2\2")
>
> + buf.write("\u037d\u0377\3\2\2\2\u037d\u0379\3\2\2\2\u037e\u008f\3")
>
> + buf.write("\2\2\2o\u0093\u0097\u009d\u00a6\u00a8\u00ab\u00b1\u00b6")
>
> + buf.write("\u00bd\u00bf\u00c3\u00cb\u00d0\u00d7\u00dd\u00f4\u00f9")
>
> + buf.write("\u00ff\u0108\u010f\u0117\u0119\u0120\u0126\u012a\u0130")
>
> + buf.write("\u0139\u013f\u0146\u014c\u0151\u0154\u0157\u015a\u015e")
>
> + buf.write("\u0164\u0169\u0170\u0172\u0184\u018a\u018d\u0192\u0197")
>
> + buf.write("\u019a\u019f\u01a4\u01aa\u01ac\u01b0\u01b5\u01b9\u01c0")
>
> + buf.write("\u01c5\u01c8\u01cc\u01cf\u01d6\u01db\u01ea\u01f0\u01f4")
>
> + buf.write("\u01fb\u0200\u0205\u0209\u0211\u0213\u021d\u021f\u0228")
>
> + buf.write("\u0239\u0258\u025a\u0262\u026d\u0276\u027c\u0280\u0285")
>
> + buf.write("\u0289\u0290\u029a\u02a7\u02ae\u02b6\u02be\u02c6\u02ce")
>
> + buf.write("\u02d6\u02de\u02e6\u02f4\u02f7\u02fe\u0309\u0313\u031d")
>
> + buf.write("\u0321\u0324\u0333\u0339\u033d\u0344\u034a\u0354\u035c")
>
> + buf.write("\u036e\u037d")
>
> + return buf.getvalue()
>
> +
>
> +
>
> +class CParser ( Parser ):
>
> +
>
> + grammarFileName = "C.g4"
>
> +
>
> + atn = ATNDeserializer().deserialize(serializedATN())
>
> +
>
> + decisionsToDFA = [ DFA(ds, i) for i, ds in enumerate(atn.decisionToState) ]
>
> +
>
> + sharedContextCache = PredictionContextCache()
>
> +
>
> + literalNames = [ "<INVALID>", "'{'", "';'", "'typedef'", "','", "'='",
>
> + "'extern'", "'static'", "'auto'", "'register'", "'STATIC'",
>
> + "'void'", "'char'", "'short'", "'int'", "'long'", "'float'",
>
> + "'double'", "'signed'", "'unsigned'", "'}'", "'struct'",
>
> + "'union'", "':'", "'enum'", "'const'", "'volatile'",
>
> + "'IN'", "'OUT'", "'OPTIONAL'", "'CONST'", "'UNALIGNED'",
>
> + "'VOLATILE'", "'GLOBAL_REMOVE_IF_UNREFERENCED'", "'EFIAPI'",
>
> + "'EFI_BOOTSERVICE'", "'EFI_RUNTIMESERVICE'", "'PACKED'",
>
> + "'('", "')'", "'['", "']'", "'*'", "'...'", "'+'",
>
> + "'-'", "'/'", "'%'", "'++'", "'--'", "'sizeof'", "'.'",
>
> + "'->'", "'&'", "'~'", "'!'", "'*='", "'/='", "'%='",
>
> + "'+='", "'-='", "'<<='", "'>>='", "'&='", "'^='", "'|='",
>
> + "'?'", "'||'", "'&&'", "'|'", "'^'", "'=='", "'!='",
>
> + "'<'", "'>'", "'<='", "'>='", "'<<'", "'>>'", "'__asm__'",
>
> + "'_asm'", "'__asm'", "'case'", "'default'", "'if'",
>
> + "'else'", "'switch'", "'while'", "'do'", "'goto'",
>
> + "'continue'", "'break'", "'return'" ]
>
> +
>
> + symbolicNames = [ "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
>
> + "<INVALID>", "IDENTIFIER", "CHARACTER_LITERAL", "STRING_LITERAL",
>
> + "HEX_LITERAL", "DECIMAL_LITERAL", "OCTAL_LITERAL",
>
> + "FLOATING_POINT_LITERAL", "WS", "BS", "UnicodeVocabulary",
>
> + "COMMENT", "LINE_COMMENT", "LINE_COMMAND" ]
>
> +
>
> + RULE_translation_unit = 0
>
> + RULE_external_declaration = 1
>
> + RULE_function_definition = 2
>
> + RULE_declaration_specifiers = 3
>
> + RULE_declaration = 4
>
> + RULE_init_declarator_list = 5
>
> + RULE_init_declarator = 6
>
> + RULE_storage_class_specifier = 7
>
> + RULE_type_specifier = 8
>
> + RULE_type_id = 9
>
> + RULE_struct_or_union_specifier = 10
>
> + RULE_struct_or_union = 11
>
> + RULE_struct_declaration_list = 12
>
> + RULE_struct_declaration = 13
>
> + RULE_specifier_qualifier_list = 14
>
> + RULE_struct_declarator_list = 15
>
> + RULE_struct_declarator = 16
>
> + RULE_enum_specifier = 17
>
> + RULE_enumerator_list = 18
>
> + RULE_enumerator = 19
>
> + RULE_type_qualifier = 20
>
> + RULE_declarator = 21
>
> + RULE_direct_declarator = 22
>
> + RULE_declarator_suffix = 23
>
> + RULE_pointer = 24
>
> + RULE_parameter_type_list = 25
>
> + RULE_parameter_list = 26
>
> + RULE_parameter_declaration = 27
>
> + RULE_identifier_list = 28
>
> + RULE_type_name = 29
>
> + RULE_abstract_declarator = 30
>
> + RULE_direct_abstract_declarator = 31
>
> + RULE_abstract_declarator_suffix = 32
>
> + RULE_initializer = 33
>
> + RULE_initializer_list = 34
>
> + RULE_argument_expression_list = 35
>
> + RULE_additive_expression = 36
>
> + RULE_multiplicative_expression = 37
>
> + RULE_cast_expression = 38
>
> + RULE_unary_expression = 39
>
> + RULE_postfix_expression = 40
>
> + RULE_macro_parameter_list = 41
>
> + RULE_unary_operator = 42
>
> + RULE_primary_expression = 43
>
> + RULE_constant = 44
>
> + RULE_expression = 45
>
> + RULE_constant_expression = 46
>
> + RULE_assignment_expression = 47
>
> + RULE_lvalue = 48
>
> + RULE_assignment_operator = 49
>
> + RULE_conditional_expression = 50
>
> + RULE_logical_or_expression = 51
>
> + RULE_logical_and_expression = 52
>
> + RULE_inclusive_or_expression = 53
>
> + RULE_exclusive_or_expression = 54
>
> + RULE_and_expression = 55
>
> + RULE_equality_expression = 56
>
> + RULE_relational_expression = 57
>
> + RULE_shift_expression = 58
>
> + RULE_statement = 59
>
> + RULE_asm2_statement = 60
>
> + RULE_asm1_statement = 61
>
> + RULE_asm_statement = 62
>
> + RULE_macro_statement = 63
>
> + RULE_labeled_statement = 64
>
> + RULE_compound_statement = 65
>
> + RULE_statement_list = 66
>
> + RULE_expression_statement = 67
>
> + RULE_selection_statement = 68
>
> + RULE_iteration_statement = 69
>
> + RULE_jump_statement = 70
>
> +
>
> + ruleNames = [ "translation_unit", "external_declaration", "function_definition",
>
> + "declaration_specifiers", "declaration", "init_declarator_list",
>
> + "init_declarator", "storage_class_specifier", "type_specifier",
>
> + "type_id", "struct_or_union_specifier", "struct_or_union",
>
> + "struct_declaration_list", "struct_declaration", "specifier_qualifier_list",
>
> + "struct_declarator_list", "struct_declarator", "enum_specifier",
>
> + "enumerator_list", "enumerator", "type_qualifier", "declarator",
>
> + "direct_declarator", "declarator_suffix", "pointer",
>
> + "parameter_type_list", "parameter_list", "parameter_declaration",
>
> + "identifier_list", "type_name", "abstract_declarator",
>
> + "direct_abstract_declarator", "abstract_declarator_suffix",
>
> + "initializer", "initializer_list", "argument_expression_list",
>
> + "additive_expression", "multiplicative_expression", "cast_expression",
>
> + "unary_expression", "postfix_expression", "macro_parameter_list",
>
> + "unary_operator", "primary_expression", "constant", "expression",
>
> + "constant_expression", "assignment_expression", "lvalue",
>
> + "assignment_operator", "conditional_expression", "logical_or_expression",
>
> + "logical_and_expression", "inclusive_or_expression",
>
> + "exclusive_or_expression", "and_expression", "equality_expression",
>
> + "relational_expression", "shift_expression", "statement",
>
> + "asm2_statement", "asm1_statement", "asm_statement",
>
> + "macro_statement", "labeled_statement", "compound_statement",
>
> + "statement_list", "expression_statement", "selection_statement",
>
> + "iteration_statement", "jump_statement" ]
>
> +
>
> + EOF = Token.EOF
>
> + T__0=1
>
> + T__1=2
>
> + T__2=3
>
> + T__3=4
>
> + T__4=5
>
> + T__5=6
>
> + T__6=7
>
> + T__7=8
>
> + T__8=9
>
> + T__9=10
>
> + T__10=11
>
> + T__11=12
>
> + T__12=13
>
> + T__13=14
>
> + T__14=15
>
> + T__15=16
>
> + T__16=17
>
> + T__17=18
>
> + T__18=19
>
> + T__19=20
>
> + T__20=21
>
> + T__21=22
>
> + T__22=23
>
> + T__23=24
>
> + T__24=25
>
> + T__25=26
>
> + T__26=27
>
> + T__27=28
>
> + T__28=29
>
> + T__29=30
>
> + T__30=31
>
> + T__31=32
>
> + T__32=33
>
> + T__33=34
>
> + T__34=35
>
> + T__35=36
>
> + T__36=37
>
> + T__37=38
>
> + T__38=39
>
> + T__39=40
>
> + T__40=41
>
> + T__41=42
>
> + T__42=43
>
> + T__43=44
>
> + T__44=45
>
> + T__45=46
>
> + T__46=47
>
> + T__47=48
>
> + T__48=49
>
> + T__49=50
>
> + T__50=51
>
> + T__51=52
>
> + T__52=53
>
> + T__53=54
>
> + T__54=55
>
> + T__55=56
>
> + T__56=57
>
> + T__57=58
>
> + T__58=59
>
> + T__59=60
>
> + T__60=61
>
> + T__61=62
>
> + T__62=63
>
> + T__63=64
>
> + T__64=65
>
> + T__65=66
>
> + T__66=67
>
> + T__67=68
>
> + T__68=69
>
> + T__69=70
>
> + T__70=71
>
> + T__71=72
>
> + T__72=73
>
> + T__73=74
>
> + T__74=75
>
> + T__75=76
>
> + T__76=77
>
> + T__77=78
>
> + T__78=79
>
> + T__79=80
>
> + T__80=81
>
> + T__81=82
>
> + T__82=83
>
> + T__83=84
>
> + T__84=85
>
> + T__85=86
>
> + T__86=87
>
> + T__87=88
>
> + T__88=89
>
> + T__89=90
>
> + T__90=91
>
> + T__91=92
>
> + IDENTIFIER=93
>
> + CHARACTER_LITERAL=94
>
> + STRING_LITERAL=95
>
> + HEX_LITERAL=96
>
> + DECIMAL_LITERAL=97
>
> + OCTAL_LITERAL=98
>
> + FLOATING_POINT_LITERAL=99
>
> + WS=100
>
> + BS=101
>
> + UnicodeVocabulary=102
>
> + COMMENT=103
>
> + LINE_COMMENT=104
>
> + LINE_COMMAND=105
>
> +
>
> + # @param input Type: TokenStream
>
> + # @param output= sys.stdout Type: TextIO
>
> + def __init__(self,input,output= sys.stdout):
>
> + super().__init__(input, output)
>
> + self.checkVersion("4.7.1")
>
> + self._interp = ParserATNSimulator(self, self.atn, self.decisionsToDFA, self.sharedContextCache)
>
> + self._predicates = None
>
> +
>
> +
>
> +
>
> +
>
> + def printTokenInfo(self,line,offset,tokenText):
>
> + print(str(line)+ ',' + str(offset) + ':' + str(tokenText))
>
> +
>
> + def StorePredicateExpression(self,StartLine,StartOffset,EndLine,EndOffset,Text):
>
> + PredExp = CodeFragment.PredicateExpression(Text, (StartLine, StartOffset), (EndLine, EndOffset))
>
> + FileProfile.PredicateExpressionList.append(PredExp)
>
> +
>
> + def StoreEnumerationDefinition(self,StartLine,StartOffset,EndLine,EndOffset,Text):
>
> + EnumDef = CodeFragment.EnumerationDefinition(Text, (StartLine, StartOffset), (EndLine, EndOffset))
>
> + FileProfile.EnumerationDefinitionList.append(EnumDef)
>
> +
>
> + def StoreStructUnionDefinition(self,StartLine,StartOffset,EndLine,EndOffset,Text):
>
> + SUDef = CodeFragment.StructUnionDefinition(Text, (StartLine, StartOffset), (EndLine, EndOffset))
>
> + FileProfile.StructUnionDefinitionList.append(SUDef)
>
> +
>
> + def StoreTypedefDefinition(self,StartLine,StartOffset,EndLine,EndOffset,FromText,ToText):
>
> + Tdef = CodeFragment.TypedefDefinition(FromText, ToText, (StartLine, StartOffset), (EndLine, EndOffset))
>
> + FileProfile.TypedefDefinitionList.append(Tdef)
>
> +
>
> + def
> StoreFunctionDefinition(self,StartLine,StartOffset,EndLine,EndOffset,ModifierText,DeclText,LeftBraceLine,LeftBraceOffset,DeclLine,DeclOffse
> t):
>
> + FuncDef = CodeFragment.FunctionDefinition(ModifierText, DeclText, (StartLine, StartOffset), (EndLine, EndOffset), (LeftBraceLine,
> LeftBraceOffset), (DeclLine, DeclOffset))
>
> + FileProfile.FunctionDefinitionList.append(FuncDef)
>
> +
>
> + def StoreVariableDeclaration(self,StartLine,StartOffset,EndLine,EndOffset,ModifierText,DeclText):
>
> + VarDecl = CodeFragment.VariableDeclaration(ModifierText, DeclText, (StartLine, StartOffset), (EndLine, EndOffset))
>
> + FileProfile.VariableDeclarationList.append(VarDecl)
>
> +
>
> + def StoreFunctionCalling(self,StartLine,StartOffset,EndLine,EndOffset,FuncName,ParamList):
>
> + FuncCall = CodeFragment.FunctionCalling(FuncName, ParamList, (StartLine, StartOffset), (EndLine, EndOffset))
>
> + FileProfile.FunctionCallingList.append(FuncCall)
>
> +
>
> +
>
> +
>
> + class Translation_unitContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def external_declaration(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.External_declarationContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.External_declarationContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_translation_unit
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterTranslation_unit" ):
>
> + listener.enterTranslation_unit(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitTranslation_unit" ):
>
> + listener.exitTranslation_unit(self)
>
> +
>
> +
>
> +
>
> +
>
> + def translation_unit(self):
>
> +
>
> + localctx = CParser.Translation_unitContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 0, self.RULE_translation_unit)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 145
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__2) | (1 << CParser.T__5) | (1 << CParser.T__6) | (1 <<
> CParser.T__7) | (1 << CParser.T__8) | (1 << CParser.T__9) | (1 << CParser.T__10) | (1 << CParser.T__11) | (1 << CParser.T__12) | (1 <<
> CParser.T__13) | (1 << CParser.T__14) | (1 << CParser.T__15) | (1 << CParser.T__16) | (1 << CParser.T__17) | (1 << CParser.T__18) | (1 <<
> CParser.T__20) | (1 << CParser.T__21) | (1 << CParser.T__23) | (1 << CParser.T__24) | (1 << CParser.T__25) | (1 << CParser.T__26) | (1 <<
> CParser.T__27) | (1 << CParser.T__28) | (1 << CParser.T__29) | (1 << CParser.T__30) | (1 << CParser.T__31) | (1 << CParser.T__32) | (1 <<
> CParser.T__33) | (1 << CParser.T__34) | (1 << CParser.T__35) | (1 << CParser.T__36) | (1 << CParser.T__37) | (1 << CParser.T__41))) != 0) or
> _la==CParser.IDENTIFIER:
>
> + self.state = 142
>
> + self.external_declaration()
>
> + self.state = 147
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class External_declarationContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def declarator(self):
>
> + return self.getTypedRuleContext(CParser.DeclaratorContext,0)
>
> +
>
> +
>
> + def declaration_specifiers(self):
>
> + return self.getTypedRuleContext(CParser.Declaration_specifiersContext,0)
>
> +
>
> +
>
> + # @param i=None Type: int
>
> + def declaration(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.DeclarationContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.DeclarationContext,i)
>
> +
>
> +
>
> + def function_definition(self):
>
> + return self.getTypedRuleContext(CParser.Function_definitionContext,0)
>
> +
>
> +
>
> + def macro_statement(self):
>
> + return self.getTypedRuleContext(CParser.Macro_statementContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_external_declaration
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterExternal_declaration" ):
>
> + listener.enterExternal_declaration(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitExternal_declaration" ):
>
> + listener.exitExternal_declaration(self)
>
> +
>
> +
>
> +
>
> +
>
> + def external_declaration(self):
>
> +
>
> + localctx = CParser.External_declarationContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 2, self.RULE_external_declaration)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.state = 166
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,4,self._ctx)
>
> + if la_ == 1:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 149
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,1,self._ctx)
>
> + if la_ == 1:
>
> + self.state = 148
>
> + self.declaration_specifiers()
>
> +
>
> +
>
> + self.state = 151
>
> + self.declarator()
>
> + self.state = 155
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__2) | (1 << CParser.T__5) | (1 << CParser.T__6) | (1 <<
> CParser.T__7) | (1 << CParser.T__8) | (1 << CParser.T__9) | (1 << CParser.T__10) | (1 << CParser.T__11) | (1 << CParser.T__12) | (1 <<
> CParser.T__13) | (1 << CParser.T__14) | (1 << CParser.T__15) | (1 << CParser.T__16) | (1 << CParser.T__17) | (1 << CParser.T__18) | (1 <<
> CParser.T__20) | (1 << CParser.T__21) | (1 << CParser.T__23) | (1 << CParser.T__24) | (1 << CParser.T__25) | (1 << CParser.T__26) | (1 <<
> CParser.T__27) | (1 << CParser.T__28) | (1 << CParser.T__29) | (1 << CParser.T__30) | (1 << CParser.T__31) | (1 << CParser.T__32) | (1 <<
> CParser.T__33) | (1 << CParser.T__34) | (1 << CParser.T__35) | (1 << CParser.T__36))) != 0) or _la==CParser.IDENTIFIER:
>
> + self.state = 152
>
> + self.declaration()
>
> + self.state = 157
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + self.state = 158
>
> + self.match(CParser.T__0)
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 160
>
> + self.function_definition()
>
> + pass
>
> +
>
> + elif la_ == 3:
>
> + self.enterOuterAlt(localctx, 3)
>
> + self.state = 161
>
> + self.declaration()
>
> + pass
>
> +
>
> + elif la_ == 4:
>
> + self.enterOuterAlt(localctx, 4)
>
> + self.state = 162
>
> + self.macro_statement()
>
> + self.state = 164
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__1:
>
> + self.state = 163
>
> + self.match(CParser.T__1)
>
> +
>
> +
>
> + pass
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Function_definitionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> + self.ModifierText = ''
>
> + self.DeclText = ''
>
> + self.LBLine = 0
>
> + self.LBOffset = 0
>
> + self.DeclLine = 0
>
> + self.DeclOffset = 0
>
> + self.d = None # Declaration_specifiersContext
>
> + self._declaration_specifiers = None # Declaration_specifiersContext
>
> + self._declarator = None # DeclaratorContext
>
> + self.a = None # Compound_statementContext
>
> + self.b = None # Compound_statementContext
>
> +
>
> + def declarator(self):
>
> + return self.getTypedRuleContext(CParser.DeclaratorContext,0)
>
> +
>
> +
>
> + def compound_statement(self):
>
> + return self.getTypedRuleContext(CParser.Compound_statementContext,0)
>
> +
>
> +
>
> + def declaration_specifiers(self):
>
> + return self.getTypedRuleContext(CParser.Declaration_specifiersContext,0)
>
> +
>
> +
>
> + # @param i=None Type: int
>
> + def declaration(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.DeclarationContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.DeclarationContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_function_definition
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterFunction_definition" ):
>
> + listener.enterFunction_definition(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitFunction_definition" ):
>
> + listener.exitFunction_definition(self)
>
> +
>
> +
>
> +
>
> +
>
> + def function_definition(self):
>
> +
>
> + localctx = CParser.Function_definitionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 4, self.RULE_function_definition)
>
> +
>
> + ModifierText = '';
>
> + DeclText = '';
>
> + LBLine = 0;
>
> + LBOffset = 0;
>
> + DeclLine = 0;
>
> + DeclOffset = 0;
>
> +
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 169
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,5,self._ctx)
>
> + if la_ == 1:
>
> + self.state = 168
>
> + localctx.d = localctx._declaration_specifiers = self.declaration_specifiers()
>
> +
>
> +
>
> + self.state = 171
>
> + localctx._declarator = self.declarator()
>
> + self.state = 180
>
> + self._errHandler.sync(self)
>
> + token = self._input.LA(1)
>
> + if token in [CParser.T__2, CParser.T__5, CParser.T__6, CParser.T__7, CParser.T__8, CParser.T__9, CParser.T__10, CParser.T__11,
> CParser.T__12, CParser.T__13, CParser.T__14, CParser.T__15, CParser.T__16, CParser.T__17, CParser.T__18, CParser.T__20, CParser.T__21,
> CParser.T__23, CParser.T__24, CParser.T__25, CParser.T__26, CParser.T__27, CParser.T__28, CParser.T__29, CParser.T__30, CParser.T__31,
> CParser.T__32, CParser.T__33, CParser.T__34, CParser.T__35, CParser.T__36, CParser.IDENTIFIER]:
>
> + self.state = 173
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while True:
>
> + self.state = 172
>
> + self.declaration()
>
> + self.state = 175
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if not ((((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__2) | (1 << CParser.T__5) | (1 << CParser.T__6) | (1 <<
> CParser.T__7) | (1 << CParser.T__8) | (1 << CParser.T__9) | (1 << CParser.T__10) | (1 << CParser.T__11) | (1 << CParser.T__12) | (1 <<
> CParser.T__13) | (1 << CParser.T__14) | (1 << CParser.T__15) | (1 << CParser.T__16) | (1 << CParser.T__17) | (1 << CParser.T__18) | (1 <<
> CParser.T__20) | (1 << CParser.T__21) | (1 << CParser.T__23) | (1 << CParser.T__24) | (1 << CParser.T__25) | (1 << CParser.T__26) | (1 <<
> CParser.T__27) | (1 << CParser.T__28) | (1 << CParser.T__29) | (1 << CParser.T__30) | (1 << CParser.T__31) | (1 << CParser.T__32) | (1 <<
> CParser.T__33) | (1 << CParser.T__34) | (1 << CParser.T__35) | (1 << CParser.T__36))) != 0) or _la==CParser.IDENTIFIER):
>
> + break
>
> +
>
> + self.state = 177
>
> + localctx.a = self.compound_statement()
>
> + pass
>
> + elif token in [CParser.T__0]:
>
> + self.state = 179
>
> + localctx.b = self.compound_statement()
>
> + pass
>
> + else:
>
> + raise NoViableAltException(self)
>
> +
>
> +
>
> + if localctx.d != None:
>
> + ModifierText = (None if localctx._declaration_specifiers is None else
> self._input.getText((localctx._declaration_specifiers.start,localctx._declaration_specifiers.stop)))
>
> + else:
>
> + ModifierText = ''
>
> + DeclText = (None if localctx._declarator is None else self._input.getText((localctx._declarator.start,localctx._declarator.stop)))
>
> + DeclLine = (None if localctx._declarator is None else localctx._declarator.start).line
>
> + DeclOffset = (None if localctx._declarator is None else localctx._declarator.start).column
>
> + if localctx.a != None:
>
> + LBLine = (None if localctx.a is None else localctx.a.start).line
>
> + LBOffset = (None if localctx.a is None else localctx.a.start).column
>
> + else:
>
> + LBLine = (None if localctx.b is None else localctx.b.start).line
>
> + LBOffset = (None if localctx.b is None else localctx.b.start).column
>
> +
>
> + self._ctx.stop = self._input.LT(-1)
>
> +
>
> + self.StoreFunctionDefinition(localctx.start.line, localctx.start.column, localctx.stop.line, localctx.stop.column, ModifierText,
> DeclText, LBLine, LBOffset, DeclLine, DeclOffset)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Declaration_specifiersContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def storage_class_specifier(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Storage_class_specifierContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Storage_class_specifierContext,i)
>
> +
>
> +
>
> + # @param i=None Type: int
>
> + def type_specifier(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Type_specifierContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Type_specifierContext,i)
>
> +
>
> +
>
> + # @param i=None Type: int
>
> + def type_qualifier(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Type_qualifierContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Type_qualifierContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_declaration_specifiers
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterDeclaration_specifiers" ):
>
> + listener.enterDeclaration_specifiers(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitDeclaration_specifiers" ):
>
> + listener.exitDeclaration_specifiers(self)
>
> +
>
> +
>
> +
>
> +
>
> + def declaration_specifiers(self):
>
> +
>
> + localctx = CParser.Declaration_specifiersContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 6, self.RULE_declaration_specifiers)
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 187
>
> + self._errHandler.sync(self)
>
> + _alt = 1
>
> + while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
>
> + if _alt == 1:
>
> + self.state = 187
>
> + self._errHandler.sync(self)
>
> + token = self._input.LA(1)
>
> + if token in [CParser.T__5, CParser.T__6, CParser.T__7, CParser.T__8, CParser.T__9]:
>
> + self.state = 184
>
> + self.storage_class_specifier()
>
> + pass
>
> + elif token in [CParser.T__10, CParser.T__11, CParser.T__12, CParser.T__13, CParser.T__14, CParser.T__15,
> CParser.T__16, CParser.T__17, CParser.T__18, CParser.T__20, CParser.T__21, CParser.T__23, CParser.IDENTIFIER]:
>
> + self.state = 185
>
> + self.type_specifier()
>
> + pass
>
> + elif token in [CParser.T__24, CParser.T__25, CParser.T__26, CParser.T__27, CParser.T__28, CParser.T__29,
> CParser.T__30, CParser.T__31, CParser.T__32, CParser.T__33, CParser.T__34, CParser.T__35, CParser.T__36]:
>
> + self.state = 186
>
> + self.type_qualifier()
>
> + pass
>
> + else:
>
> + raise NoViableAltException(self)
>
> +
>
> +
>
> + else:
>
> + raise NoViableAltException(self)
>
> + self.state = 189
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,9,self._ctx)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class DeclarationContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> + self.a = None # Token
>
> + self.b = None # Declaration_specifiersContext
>
> + self.c = None # Init_declarator_listContext
>
> + self.d = None # Token
>
> + self.s = None # Declaration_specifiersContext
>
> + self.t = None # Init_declarator_listContext
>
> + self.e = None # Token
>
> +
>
> + def init_declarator_list(self):
>
> + return self.getTypedRuleContext(CParser.Init_declarator_listContext,0)
>
> +
>
> +
>
> + def declaration_specifiers(self):
>
> + return self.getTypedRuleContext(CParser.Declaration_specifiersContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_declaration
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterDeclaration" ):
>
> + listener.enterDeclaration(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitDeclaration" ):
>
> + listener.exitDeclaration(self)
>
> +
>
> +
>
> +
>
> +
>
> + def declaration(self):
>
> +
>
> + localctx = CParser.DeclarationContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 8, self.RULE_declaration)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.state = 206
>
> + self._errHandler.sync(self)
>
> + token = self._input.LA(1)
>
> + if token in [CParser.T__2]:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 191
>
> + localctx.a = self.match(CParser.T__2)
>
> + self.state = 193
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,10,self._ctx)
>
> + if la_ == 1:
>
> + self.state = 192
>
> + localctx.b = self.declaration_specifiers()
>
> +
>
> +
>
> + self.state = 195
>
> + localctx.c = self.init_declarator_list()
>
> + self.state = 196
>
> + localctx.d = self.match(CParser.T__1)
>
> +
>
> + if localctx.b is not None:
>
> + self.StoreTypedefDefinition(localctx.a.line, localctx.a.column, (0 if localctx.d is None else localctx.d.line),
> localctx.d.column, (None if localctx.b is None else self._input.getText((localctx.b.start,localctx.b.stop))), (None if localctx.c is None else
> self._input.getText((localctx.c.start,localctx.c.stop))))
>
> + else:
>
> + self.StoreTypedefDefinition(localctx.a.line, localctx.a.column, (0 if localctx.d is None else localctx.d.line),
> localctx.d.column, '', (None if localctx.c is None else self._input.getText((localctx.c.start,localctx.c.stop))))
>
> +
>
> + pass
>
> + elif token in [CParser.T__5, CParser.T__6, CParser.T__7, CParser.T__8, CParser.T__9, CParser.T__10, CParser.T__11,
> CParser.T__12, CParser.T__13, CParser.T__14, CParser.T__15, CParser.T__16, CParser.T__17, CParser.T__18, CParser.T__20, CParser.T__21,
> CParser.T__23, CParser.T__24, CParser.T__25, CParser.T__26, CParser.T__27, CParser.T__28, CParser.T__29, CParser.T__30, CParser.T__31,
> CParser.T__32, CParser.T__33, CParser.T__34, CParser.T__35, CParser.T__36, CParser.IDENTIFIER]:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 199
>
> + localctx.s = self.declaration_specifiers()
>
> + self.state = 201
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if ((((_la - 34)) & ~0x3f) == 0 and ((1 << (_la - 34)) & ((1 << (CParser.T__33 - 34)) | (1 << (CParser.T__34 - 34)) | (1 <<
> (CParser.T__35 - 34)) | (1 << (CParser.T__37 - 34)) | (1 << (CParser.T__41 - 34)) | (1 << (CParser.IDENTIFIER - 34)))) != 0):
>
> + self.state = 200
>
> + localctx.t = self.init_declarator_list()
>
> +
>
> +
>
> + self.state = 203
>
> + localctx.e = self.match(CParser.T__1)
>
> +
>
> + if localctx.t is not None:
>
> + self.StoreVariableDeclaration((None if localctx.s is None else localctx.s.start).line, (None if localctx.s is None else
> localctx.s.start).column, (None if localctx.t is None else localctx.t.start).line, (None if localctx.t is None else localctx.t.start).column, (None if
> localctx.s is None else self._input.getText((localctx.s.start,localctx.s.stop))), (None if localctx.t is None else
> self._input.getText((localctx.t.start,localctx.t.stop))))
>
> +
>
> + pass
>
> + else:
>
> + raise NoViableAltException(self)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Init_declarator_listContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def init_declarator(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Init_declaratorContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Init_declaratorContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_init_declarator_list
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterInit_declarator_list" ):
>
> + listener.enterInit_declarator_list(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitInit_declarator_list" ):
>
> + listener.exitInit_declarator_list(self)
>
> +
>
> +
>
> +
>
> +
>
> + def init_declarator_list(self):
>
> +
>
> + localctx = CParser.Init_declarator_listContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 10, self.RULE_init_declarator_list)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 208
>
> + self.init_declarator()
>
> + self.state = 213
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while _la==CParser.T__3:
>
> + self.state = 209
>
> + self.match(CParser.T__3)
>
> + self.state = 210
>
> + self.init_declarator()
>
> + self.state = 215
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Init_declaratorContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def declarator(self):
>
> + return self.getTypedRuleContext(CParser.DeclaratorContext,0)
>
> +
>
> +
>
> + def initializer(self):
>
> + return self.getTypedRuleContext(CParser.InitializerContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_init_declarator
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterInit_declarator" ):
>
> + listener.enterInit_declarator(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitInit_declarator" ):
>
> + listener.exitInit_declarator(self)
>
> +
>
> +
>
> +
>
> +
>
> + def init_declarator(self):
>
> +
>
> + localctx = CParser.Init_declaratorContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 12, self.RULE_init_declarator)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 216
>
> + self.declarator()
>
> + self.state = 219
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__4:
>
> + self.state = 217
>
> + self.match(CParser.T__4)
>
> + self.state = 218
>
> + self.initializer()
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Storage_class_specifierContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_storage_class_specifier
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterStorage_class_specifier" ):
>
> + listener.enterStorage_class_specifier(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitStorage_class_specifier" ):
>
> + listener.exitStorage_class_specifier(self)
>
> +
>
> +
>
> +
>
> +
>
> + def storage_class_specifier(self):
>
> +
>
> + localctx = CParser.Storage_class_specifierContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 14, self.RULE_storage_class_specifier)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 221
>
> + _la = self._input.LA(1)
>
> + if not((((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__5) | (1 << CParser.T__6) | (1 << CParser.T__7) | (1 <<
> CParser.T__8) | (1 << CParser.T__9))) != 0)):
>
> + self._errHandler.recoverInline(self)
>
> + else:
>
> + self._errHandler.reportMatch(self)
>
> + self.consume()
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Type_specifierContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> + self.s = None # Struct_or_union_specifierContext
>
> + self.e = None # Enum_specifierContext
>
> +
>
> + def struct_or_union_specifier(self):
>
> + return self.getTypedRuleContext(CParser.Struct_or_union_specifierContext,0)
>
> +
>
> +
>
> + def enum_specifier(self):
>
> + return self.getTypedRuleContext(CParser.Enum_specifierContext,0)
>
> +
>
> +
>
> + def IDENTIFIER(self):
>
> + return self.getToken(CParser.IDENTIFIER, 0)
>
> +
>
> + def declarator(self):
>
> + return self.getTypedRuleContext(CParser.DeclaratorContext,0)
>
> +
>
> +
>
> + # @param i=None Type: int
>
> + def type_qualifier(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Type_qualifierContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Type_qualifierContext,i)
>
> +
>
> +
>
> + def type_id(self):
>
> + return self.getTypedRuleContext(CParser.Type_idContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_type_specifier
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterType_specifier" ):
>
> + listener.enterType_specifier(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitType_specifier" ):
>
> + listener.exitType_specifier(self)
>
> +
>
> +
>
> +
>
> +
>
> + def type_specifier(self):
>
> +
>
> + localctx = CParser.Type_specifierContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 16, self.RULE_type_specifier)
>
> + try:
>
> + self.state = 247
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,16,self._ctx)
>
> + if la_ == 1:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 223
>
> + self.match(CParser.T__10)
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 224
>
> + self.match(CParser.T__11)
>
> + pass
>
> +
>
> + elif la_ == 3:
>
> + self.enterOuterAlt(localctx, 3)
>
> + self.state = 225
>
> + self.match(CParser.T__12)
>
> + pass
>
> +
>
> + elif la_ == 4:
>
> + self.enterOuterAlt(localctx, 4)
>
> + self.state = 226
>
> + self.match(CParser.T__13)
>
> + pass
>
> +
>
> + elif la_ == 5:
>
> + self.enterOuterAlt(localctx, 5)
>
> + self.state = 227
>
> + self.match(CParser.T__14)
>
> + pass
>
> +
>
> + elif la_ == 6:
>
> + self.enterOuterAlt(localctx, 6)
>
> + self.state = 228
>
> + self.match(CParser.T__15)
>
> + pass
>
> +
>
> + elif la_ == 7:
>
> + self.enterOuterAlt(localctx, 7)
>
> + self.state = 229
>
> + self.match(CParser.T__16)
>
> + pass
>
> +
>
> + elif la_ == 8:
>
> + self.enterOuterAlt(localctx, 8)
>
> + self.state = 230
>
> + self.match(CParser.T__17)
>
> + pass
>
> +
>
> + elif la_ == 9:
>
> + self.enterOuterAlt(localctx, 9)
>
> + self.state = 231
>
> + self.match(CParser.T__18)
>
> + pass
>
> +
>
> + elif la_ == 10:
>
> + self.enterOuterAlt(localctx, 10)
>
> + self.state = 232
>
> + localctx.s = self.struct_or_union_specifier()
>
> +
>
> + if localctx.s.stop is not None:
>
> + self.StoreStructUnionDefinition((None if localctx.s is None else localctx.s.start).line, (None if localctx.s is None else
> localctx.s.start).column, (None if localctx.s is None else localctx.s.stop).line, (None if localctx.s is None else localctx.s.stop).column, (None if
> localctx.s is None else self._input.getText((localctx.s.start,localctx.s.stop))))
>
> +
>
> + pass
>
> +
>
> + elif la_ == 11:
>
> + self.enterOuterAlt(localctx, 11)
>
> + self.state = 235
>
> + localctx.e = self.enum_specifier()
>
> +
>
> + if localctx.e.stop is not None:
>
> + self.StoreEnumerationDefinition((None if localctx.e is None else localctx.e.start).line, (None if localctx.e is None
> else localctx.e.start).column, (None if localctx.e is None else localctx.e.stop).line, (None if localctx.e is None else localctx.e.stop).column,
> (None if localctx.e is None else self._input.getText((localctx.e.start,localctx.e.stop))))
>
> +
>
> + pass
>
> +
>
> + elif la_ == 12:
>
> + self.enterOuterAlt(localctx, 12)
>
> + self.state = 238
>
> + self.match(CParser.IDENTIFIER)
>
> + self.state = 242
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,15,self._ctx)
>
> + while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
>
> + if _alt==1:
>
> + self.state = 239
>
> + self.type_qualifier()
>
> + self.state = 244
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,15,self._ctx)
>
> +
>
> + self.state = 245
>
> + self.declarator()
>
> + pass
>
> +
>
> + elif la_ == 13:
>
> + self.enterOuterAlt(localctx, 13)
>
> + self.state = 246
>
> + self.type_id()
>
> + pass
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Type_idContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def IDENTIFIER(self):
>
> + return self.getToken(CParser.IDENTIFIER, 0)
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_type_id
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterType_id" ):
>
> + listener.enterType_id(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitType_id" ):
>
> + listener.exitType_id(self)
>
> +
>
> +
>
> +
>
> +
>
> + def type_id(self):
>
> +
>
> + localctx = CParser.Type_idContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 18, self.RULE_type_id)
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 249
>
> + self.match(CParser.IDENTIFIER)
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Struct_or_union_specifierContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def struct_or_union(self):
>
> + return self.getTypedRuleContext(CParser.Struct_or_unionContext,0)
>
> +
>
> +
>
> + def struct_declaration_list(self):
>
> + return self.getTypedRuleContext(CParser.Struct_declaration_listContext,0)
>
> +
>
> +
>
> + def IDENTIFIER(self):
>
> + return self.getToken(CParser.IDENTIFIER, 0)
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_struct_or_union_specifier
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterStruct_or_union_specifier" ):
>
> + listener.enterStruct_or_union_specifier(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitStruct_or_union_specifier" ):
>
> + listener.exitStruct_or_union_specifier(self)
>
> +
>
> +
>
> +
>
> +
>
> + def struct_or_union_specifier(self):
>
> +
>
> + localctx = CParser.Struct_or_union_specifierContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 20, self.RULE_struct_or_union_specifier)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.state = 262
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,18,self._ctx)
>
> + if la_ == 1:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 251
>
> + self.struct_or_union()
>
> + self.state = 253
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.IDENTIFIER:
>
> + self.state = 252
>
> + self.match(CParser.IDENTIFIER)
>
> +
>
> +
>
> + self.state = 255
>
> + self.match(CParser.T__0)
>
> + self.state = 256
>
> + self.struct_declaration_list()
>
> + self.state = 257
>
> + self.match(CParser.T__19)
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 259
>
> + self.struct_or_union()
>
> + self.state = 260
>
> + self.match(CParser.IDENTIFIER)
>
> + pass
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Struct_or_unionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_struct_or_union
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterStruct_or_union" ):
>
> + listener.enterStruct_or_union(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitStruct_or_union" ):
>
> + listener.exitStruct_or_union(self)
>
> +
>
> +
>
> +
>
> +
>
> + def struct_or_union(self):
>
> +
>
> + localctx = CParser.Struct_or_unionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 22, self.RULE_struct_or_union)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 264
>
> + _la = self._input.LA(1)
>
> + if not(_la==CParser.T__20 or _la==CParser.T__21):
>
> + self._errHandler.recoverInline(self)
>
> + else:
>
> + self._errHandler.reportMatch(self)
>
> + self.consume()
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Struct_declaration_listContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def struct_declaration(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Struct_declarationContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Struct_declarationContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_struct_declaration_list
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterStruct_declaration_list" ):
>
> + listener.enterStruct_declaration_list(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitStruct_declaration_list" ):
>
> + listener.exitStruct_declaration_list(self)
>
> +
>
> +
>
> +
>
> +
>
> + def struct_declaration_list(self):
>
> +
>
> + localctx = CParser.Struct_declaration_listContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 24, self.RULE_struct_declaration_list)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 267
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while True:
>
> + self.state = 266
>
> + self.struct_declaration()
>
> + self.state = 269
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if not ((((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__10) | (1 << CParser.T__11) | (1 << CParser.T__12) | (1 <<
> CParser.T__13) | (1 << CParser.T__14) | (1 << CParser.T__15) | (1 << CParser.T__16) | (1 << CParser.T__17) | (1 << CParser.T__18) | (1 <<
> CParser.T__20) | (1 << CParser.T__21) | (1 << CParser.T__23) | (1 << CParser.T__24) | (1 << CParser.T__25) | (1 << CParser.T__26) | (1 <<
> CParser.T__27) | (1 << CParser.T__28) | (1 << CParser.T__29) | (1 << CParser.T__30) | (1 << CParser.T__31) | (1 << CParser.T__32) | (1 <<
> CParser.T__33) | (1 << CParser.T__34) | (1 << CParser.T__35) | (1 << CParser.T__36))) != 0) or _la==CParser.IDENTIFIER):
>
> + break
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Struct_declarationContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def specifier_qualifier_list(self):
>
> + return self.getTypedRuleContext(CParser.Specifier_qualifier_listContext,0)
>
> +
>
> +
>
> + def struct_declarator_list(self):
>
> + return self.getTypedRuleContext(CParser.Struct_declarator_listContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_struct_declaration
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterStruct_declaration" ):
>
> + listener.enterStruct_declaration(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitStruct_declaration" ):
>
> + listener.exitStruct_declaration(self)
>
> +
>
> +
>
> +
>
> +
>
> + def struct_declaration(self):
>
> +
>
> + localctx = CParser.Struct_declarationContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 26, self.RULE_struct_declaration)
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 271
>
> + self.specifier_qualifier_list()
>
> + self.state = 272
>
> + self.struct_declarator_list()
>
> + self.state = 273
>
> + self.match(CParser.T__1)
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Specifier_qualifier_listContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def type_qualifier(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Type_qualifierContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Type_qualifierContext,i)
>
> +
>
> +
>
> + # @param i=None Type: int
>
> + def type_specifier(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Type_specifierContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Type_specifierContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_specifier_qualifier_list
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterSpecifier_qualifier_list" ):
>
> + listener.enterSpecifier_qualifier_list(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitSpecifier_qualifier_list" ):
>
> + listener.exitSpecifier_qualifier_list(self)
>
> +
>
> +
>
> +
>
> +
>
> + def specifier_qualifier_list(self):
>
> +
>
> + localctx = CParser.Specifier_qualifier_listContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 28, self.RULE_specifier_qualifier_list)
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 277
>
> + self._errHandler.sync(self)
>
> + _alt = 1
>
> + while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
>
> + if _alt == 1:
>
> + self.state = 277
>
> + self._errHandler.sync(self)
>
> + token = self._input.LA(1)
>
> + if token in [CParser.T__24, CParser.T__25, CParser.T__26, CParser.T__27, CParser.T__28, CParser.T__29,
> CParser.T__30, CParser.T__31, CParser.T__32, CParser.T__33, CParser.T__34, CParser.T__35, CParser.T__36]:
>
> + self.state = 275
>
> + self.type_qualifier()
>
> + pass
>
> + elif token in [CParser.T__10, CParser.T__11, CParser.T__12, CParser.T__13, CParser.T__14, CParser.T__15,
> CParser.T__16, CParser.T__17, CParser.T__18, CParser.T__20, CParser.T__21, CParser.T__23, CParser.IDENTIFIER]:
>
> + self.state = 276
>
> + self.type_specifier()
>
> + pass
>
> + else:
>
> + raise NoViableAltException(self)
>
> +
>
> +
>
> + else:
>
> + raise NoViableAltException(self)
>
> + self.state = 279
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,21,self._ctx)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Struct_declarator_listContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def struct_declarator(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Struct_declaratorContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Struct_declaratorContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_struct_declarator_list
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterStruct_declarator_list" ):
>
> + listener.enterStruct_declarator_list(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitStruct_declarator_list" ):
>
> + listener.exitStruct_declarator_list(self)
>
> +
>
> +
>
> +
>
> +
>
> + def struct_declarator_list(self):
>
> +
>
> + localctx = CParser.Struct_declarator_listContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 30, self.RULE_struct_declarator_list)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 281
>
> + self.struct_declarator()
>
> + self.state = 286
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while _la==CParser.T__3:
>
> + self.state = 282
>
> + self.match(CParser.T__3)
>
> + self.state = 283
>
> + self.struct_declarator()
>
> + self.state = 288
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Struct_declaratorContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def declarator(self):
>
> + return self.getTypedRuleContext(CParser.DeclaratorContext,0)
>
> +
>
> +
>
> + def constant_expression(self):
>
> + return self.getTypedRuleContext(CParser.Constant_expressionContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_struct_declarator
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterStruct_declarator" ):
>
> + listener.enterStruct_declarator(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitStruct_declarator" ):
>
> + listener.exitStruct_declarator(self)
>
> +
>
> +
>
> +
>
> +
>
> + def struct_declarator(self):
>
> +
>
> + localctx = CParser.Struct_declaratorContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 32, self.RULE_struct_declarator)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.state = 296
>
> + self._errHandler.sync(self)
>
> + token = self._input.LA(1)
>
> + if token in [CParser.T__33, CParser.T__34, CParser.T__35, CParser.T__37, CParser.T__41, CParser.IDENTIFIER]:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 289
>
> + self.declarator()
>
> + self.state = 292
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__22:
>
> + self.state = 290
>
> + self.match(CParser.T__22)
>
> + self.state = 291
>
> + self.constant_expression()
>
> +
>
> +
>
> + pass
>
> + elif token in [CParser.T__22]:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 294
>
> + self.match(CParser.T__22)
>
> + self.state = 295
>
> + self.constant_expression()
>
> + pass
>
> + else:
>
> + raise NoViableAltException(self)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Enum_specifierContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def enumerator_list(self):
>
> + return self.getTypedRuleContext(CParser.Enumerator_listContext,0)
>
> +
>
> +
>
> + def IDENTIFIER(self):
>
> + return self.getToken(CParser.IDENTIFIER, 0)
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_enum_specifier
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterEnum_specifier" ):
>
> + listener.enterEnum_specifier(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitEnum_specifier" ):
>
> + listener.exitEnum_specifier(self)
>
> +
>
> +
>
> +
>
> +
>
> + def enum_specifier(self):
>
> +
>
> + localctx = CParser.Enum_specifierContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 34, self.RULE_enum_specifier)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.state = 317
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,27,self._ctx)
>
> + if la_ == 1:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 298
>
> + self.match(CParser.T__23)
>
> + self.state = 299
>
> + self.match(CParser.T__0)
>
> + self.state = 300
>
> + self.enumerator_list()
>
> + self.state = 302
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__3:
>
> + self.state = 301
>
> + self.match(CParser.T__3)
>
> +
>
> +
>
> + self.state = 304
>
> + self.match(CParser.T__19)
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 306
>
> + self.match(CParser.T__23)
>
> + self.state = 307
>
> + self.match(CParser.IDENTIFIER)
>
> + self.state = 308
>
> + self.match(CParser.T__0)
>
> + self.state = 309
>
> + self.enumerator_list()
>
> + self.state = 311
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__3:
>
> + self.state = 310
>
> + self.match(CParser.T__3)
>
> +
>
> +
>
> + self.state = 313
>
> + self.match(CParser.T__19)
>
> + pass
>
> +
>
> + elif la_ == 3:
>
> + self.enterOuterAlt(localctx, 3)
>
> + self.state = 315
>
> + self.match(CParser.T__23)
>
> + self.state = 316
>
> + self.match(CParser.IDENTIFIER)
>
> + pass
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Enumerator_listContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def enumerator(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.EnumeratorContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.EnumeratorContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_enumerator_list
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterEnumerator_list" ):
>
> + listener.enterEnumerator_list(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitEnumerator_list" ):
>
> + listener.exitEnumerator_list(self)
>
> +
>
> +
>
> +
>
> +
>
> + def enumerator_list(self):
>
> +
>
> + localctx = CParser.Enumerator_listContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 36, self.RULE_enumerator_list)
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 319
>
> + self.enumerator()
>
> + self.state = 324
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,28,self._ctx)
>
> + while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
>
> + if _alt==1:
>
> + self.state = 320
>
> + self.match(CParser.T__3)
>
> + self.state = 321
>
> + self.enumerator()
>
> + self.state = 326
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,28,self._ctx)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class EnumeratorContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def IDENTIFIER(self):
>
> + return self.getToken(CParser.IDENTIFIER, 0)
>
> +
>
> + def constant_expression(self):
>
> + return self.getTypedRuleContext(CParser.Constant_expressionContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_enumerator
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterEnumerator" ):
>
> + listener.enterEnumerator(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitEnumerator" ):
>
> + listener.exitEnumerator(self)
>
> +
>
> +
>
> +
>
> +
>
> + def enumerator(self):
>
> +
>
> + localctx = CParser.EnumeratorContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 38, self.RULE_enumerator)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 327
>
> + self.match(CParser.IDENTIFIER)
>
> + self.state = 330
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__4:
>
> + self.state = 328
>
> + self.match(CParser.T__4)
>
> + self.state = 329
>
> + self.constant_expression()
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Type_qualifierContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_type_qualifier
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterType_qualifier" ):
>
> + listener.enterType_qualifier(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitType_qualifier" ):
>
> + listener.exitType_qualifier(self)
>
> +
>
> +
>
> +
>
> +
>
> + def type_qualifier(self):
>
> +
>
> + localctx = CParser.Type_qualifierContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 40, self.RULE_type_qualifier)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 332
>
> + _la = self._input.LA(1)
>
> + if not((((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__24) | (1 << CParser.T__25) | (1 << CParser.T__26) | (1 <<
> CParser.T__27) | (1 << CParser.T__28) | (1 << CParser.T__29) | (1 << CParser.T__30) | (1 << CParser.T__31) | (1 << CParser.T__32) | (1 <<
> CParser.T__33) | (1 << CParser.T__34) | (1 << CParser.T__35) | (1 << CParser.T__36))) != 0)):
>
> + self._errHandler.recoverInline(self)
>
> + else:
>
> + self._errHandler.reportMatch(self)
>
> + self.consume()
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class DeclaratorContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def direct_declarator(self):
>
> + return self.getTypedRuleContext(CParser.Direct_declaratorContext,0)
>
> +
>
> +
>
> + def pointer(self):
>
> + return self.getTypedRuleContext(CParser.PointerContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_declarator
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterDeclarator" ):
>
> + listener.enterDeclarator(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitDeclarator" ):
>
> + listener.exitDeclarator(self)
>
> +
>
> +
>
> +
>
> +
>
> + def declarator(self):
>
> +
>
> + localctx = CParser.DeclaratorContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 42, self.RULE_declarator)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.state = 348
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,34,self._ctx)
>
> + if la_ == 1:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 335
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__41:
>
> + self.state = 334
>
> + self.pointer()
>
> +
>
> +
>
> + self.state = 338
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__33:
>
> + self.state = 337
>
> + self.match(CParser.T__33)
>
> +
>
> +
>
> + self.state = 341
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__34:
>
> + self.state = 340
>
> + self.match(CParser.T__34)
>
> +
>
> +
>
> + self.state = 344
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__35:
>
> + self.state = 343
>
> + self.match(CParser.T__35)
>
> +
>
> +
>
> + self.state = 346
>
> + self.direct_declarator()
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 347
>
> + self.pointer()
>
> + pass
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Direct_declaratorContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def IDENTIFIER(self):
>
> + return self.getToken(CParser.IDENTIFIER, 0)
>
> +
>
> + # @param i=None Type: int
>
> + def declarator_suffix(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Declarator_suffixContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Declarator_suffixContext,i)
>
> +
>
> +
>
> + def declarator(self):
>
> + return self.getTypedRuleContext(CParser.DeclaratorContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_direct_declarator
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterDirect_declarator" ):
>
> + listener.enterDirect_declarator(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitDirect_declarator" ):
>
> + listener.exitDirect_declarator(self)
>
> +
>
> +
>
> +
>
> +
>
> + def direct_declarator(self):
>
> +
>
> + localctx = CParser.Direct_declaratorContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 44, self.RULE_direct_declarator)
>
> + try:
>
> + self.state = 368
>
> + self._errHandler.sync(self)
>
> + token = self._input.LA(1)
>
> + if token in [CParser.IDENTIFIER]:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 350
>
> + self.match(CParser.IDENTIFIER)
>
> + self.state = 354
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,35,self._ctx)
>
> + while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
>
> + if _alt==1:
>
> + self.state = 351
>
> + self.declarator_suffix()
>
> + self.state = 356
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,35,self._ctx)
>
> +
>
> + pass
>
> + elif token in [CParser.T__37]:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 357
>
> + self.match(CParser.T__37)
>
> + self.state = 359
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,36,self._ctx)
>
> + if la_ == 1:
>
> + self.state = 358
>
> + self.match(CParser.T__33)
>
> +
>
> +
>
> + self.state = 361
>
> + self.declarator()
>
> + self.state = 362
>
> + self.match(CParser.T__38)
>
> + self.state = 364
>
> + self._errHandler.sync(self)
>
> + _alt = 1
>
> + while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
>
> + if _alt == 1:
>
> + self.state = 363
>
> + self.declarator_suffix()
>
> +
>
> + else:
>
> + raise NoViableAltException(self)
>
> + self.state = 366
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,37,self._ctx)
>
> +
>
> + pass
>
> + else:
>
> + raise NoViableAltException(self)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Declarator_suffixContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def constant_expression(self):
>
> + return self.getTypedRuleContext(CParser.Constant_expressionContext,0)
>
> +
>
> +
>
> + def parameter_type_list(self):
>
> + return self.getTypedRuleContext(CParser.Parameter_type_listContext,0)
>
> +
>
> +
>
> + def identifier_list(self):
>
> + return self.getTypedRuleContext(CParser.Identifier_listContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_declarator_suffix
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterDeclarator_suffix" ):
>
> + listener.enterDeclarator_suffix(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitDeclarator_suffix" ):
>
> + listener.exitDeclarator_suffix(self)
>
> +
>
> +
>
> +
>
> +
>
> + def declarator_suffix(self):
>
> +
>
> + localctx = CParser.Declarator_suffixContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 46, self.RULE_declarator_suffix)
>
> + try:
>
> + self.state = 386
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,39,self._ctx)
>
> + if la_ == 1:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 370
>
> + self.match(CParser.T__39)
>
> + self.state = 371
>
> + self.constant_expression()
>
> + self.state = 372
>
> + self.match(CParser.T__40)
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 374
>
> + self.match(CParser.T__39)
>
> + self.state = 375
>
> + self.match(CParser.T__40)
>
> + pass
>
> +
>
> + elif la_ == 3:
>
> + self.enterOuterAlt(localctx, 3)
>
> + self.state = 376
>
> + self.match(CParser.T__37)
>
> + self.state = 377
>
> + self.parameter_type_list()
>
> + self.state = 378
>
> + self.match(CParser.T__38)
>
> + pass
>
> +
>
> + elif la_ == 4:
>
> + self.enterOuterAlt(localctx, 4)
>
> + self.state = 380
>
> + self.match(CParser.T__37)
>
> + self.state = 381
>
> + self.identifier_list()
>
> + self.state = 382
>
> + self.match(CParser.T__38)
>
> + pass
>
> +
>
> + elif la_ == 5:
>
> + self.enterOuterAlt(localctx, 5)
>
> + self.state = 384
>
> + self.match(CParser.T__37)
>
> + self.state = 385
>
> + self.match(CParser.T__38)
>
> + pass
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class PointerContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def type_qualifier(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Type_qualifierContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Type_qualifierContext,i)
>
> +
>
> +
>
> + def pointer(self):
>
> + return self.getTypedRuleContext(CParser.PointerContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_pointer
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterPointer" ):
>
> + listener.enterPointer(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitPointer" ):
>
> + listener.exitPointer(self)
>
> +
>
> +
>
> +
>
> +
>
> + def pointer(self):
>
> +
>
> + localctx = CParser.PointerContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 48, self.RULE_pointer)
>
> + try:
>
> + self.state = 400
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,42,self._ctx)
>
> + if la_ == 1:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 388
>
> + self.match(CParser.T__41)
>
> + self.state = 390
>
> + self._errHandler.sync(self)
>
> + _alt = 1
>
> + while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
>
> + if _alt == 1:
>
> + self.state = 389
>
> + self.type_qualifier()
>
> +
>
> + else:
>
> + raise NoViableAltException(self)
>
> + self.state = 392
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,40,self._ctx)
>
> +
>
> + self.state = 395
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,41,self._ctx)
>
> + if la_ == 1:
>
> + self.state = 394
>
> + self.pointer()
>
> +
>
> +
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 397
>
> + self.match(CParser.T__41)
>
> + self.state = 398
>
> + self.pointer()
>
> + pass
>
> +
>
> + elif la_ == 3:
>
> + self.enterOuterAlt(localctx, 3)
>
> + self.state = 399
>
> + self.match(CParser.T__41)
>
> + pass
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Parameter_type_listContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def parameter_list(self):
>
> + return self.getTypedRuleContext(CParser.Parameter_listContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_parameter_type_list
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterParameter_type_list" ):
>
> + listener.enterParameter_type_list(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitParameter_type_list" ):
>
> + listener.exitParameter_type_list(self)
>
> +
>
> +
>
> +
>
> +
>
> + def parameter_type_list(self):
>
> +
>
> + localctx = CParser.Parameter_type_listContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 50, self.RULE_parameter_type_list)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 402
>
> + self.parameter_list()
>
> + self.state = 408
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__3:
>
> + self.state = 403
>
> + self.match(CParser.T__3)
>
> + self.state = 405
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__28:
>
> + self.state = 404
>
> + self.match(CParser.T__28)
>
> +
>
> +
>
> + self.state = 407
>
> + self.match(CParser.T__42)
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Parameter_listContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def parameter_declaration(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Parameter_declarationContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Parameter_declarationContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_parameter_list
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterParameter_list" ):
>
> + listener.enterParameter_list(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitParameter_list" ):
>
> + listener.exitParameter_list(self)
>
> +
>
> +
>
> +
>
> +
>
> + def parameter_list(self):
>
> +
>
> + localctx = CParser.Parameter_listContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 52, self.RULE_parameter_list)
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 410
>
> + self.parameter_declaration()
>
> + self.state = 418
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,46,self._ctx)
>
> + while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
>
> + if _alt==1:
>
> + self.state = 411
>
> + self.match(CParser.T__3)
>
> + self.state = 413
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,45,self._ctx)
>
> + if la_ == 1:
>
> + self.state = 412
>
> + self.match(CParser.T__28)
>
> +
>
> +
>
> + self.state = 415
>
> + self.parameter_declaration()
>
> + self.state = 420
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,46,self._ctx)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Parameter_declarationContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def declaration_specifiers(self):
>
> + return self.getTypedRuleContext(CParser.Declaration_specifiersContext,0)
>
> +
>
> +
>
> + # @param i=None Type: int
>
> + def declarator(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.DeclaratorContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.DeclaratorContext,i)
>
> +
>
> +
>
> + # @param i=None Type: int
>
> + def abstract_declarator(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Abstract_declaratorContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Abstract_declaratorContext,i)
>
> +
>
> +
>
> + def IDENTIFIER(self):
>
> + return self.getToken(CParser.IDENTIFIER, 0)
>
> +
>
> + # @param i=None Type: int
>
> + def pointer(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.PointerContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.PointerContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_parameter_declaration
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterParameter_declaration" ):
>
> + listener.enterParameter_declaration(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitParameter_declaration" ):
>
> + listener.exitParameter_declaration(self)
>
> +
>
> +
>
> +
>
> +
>
> + def parameter_declaration(self):
>
> +
>
> + localctx = CParser.Parameter_declarationContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 54, self.RULE_parameter_declaration)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.state = 439
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,51,self._ctx)
>
> + if la_ == 1:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 421
>
> + self.declaration_specifiers()
>
> + self.state = 426
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while ((((_la - 34)) & ~0x3f) == 0 and ((1 << (_la - 34)) & ((1 << (CParser.T__33 - 34)) | (1 << (CParser.T__34 - 34)) | (1 <<
> (CParser.T__35 - 34)) | (1 << (CParser.T__37 - 34)) | (1 << (CParser.T__39 - 34)) | (1 << (CParser.T__41 - 34)) | (1 << (CParser.IDENTIFIER -
> 34)))) != 0):
>
> + self.state = 424
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,47,self._ctx)
>
> + if la_ == 1:
>
> + self.state = 422
>
> + self.declarator()
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.state = 423
>
> + self.abstract_declarator()
>
> + pass
>
> +
>
> +
>
> + self.state = 428
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + self.state = 430
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__28:
>
> + self.state = 429
>
> + self.match(CParser.T__28)
>
> +
>
> +
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 435
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while _la==CParser.T__41:
>
> + self.state = 432
>
> + self.pointer()
>
> + self.state = 437
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + self.state = 438
>
> + self.match(CParser.IDENTIFIER)
>
> + pass
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Identifier_listContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def IDENTIFIER(self,i=None):
>
> + if i is None:
>
> + return self.getTokens(CParser.IDENTIFIER)
>
> + else:
>
> + return self.getToken(CParser.IDENTIFIER, i)
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_identifier_list
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterIdentifier_list" ):
>
> + listener.enterIdentifier_list(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitIdentifier_list" ):
>
> + listener.exitIdentifier_list(self)
>
> +
>
> +
>
> +
>
> +
>
> + def identifier_list(self):
>
> +
>
> + localctx = CParser.Identifier_listContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 56, self.RULE_identifier_list)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 441
>
> + self.match(CParser.IDENTIFIER)
>
> + self.state = 446
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while _la==CParser.T__3:
>
> + self.state = 442
>
> + self.match(CParser.T__3)
>
> + self.state = 443
>
> + self.match(CParser.IDENTIFIER)
>
> + self.state = 448
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Type_nameContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def specifier_qualifier_list(self):
>
> + return self.getTypedRuleContext(CParser.Specifier_qualifier_listContext,0)
>
> +
>
> +
>
> + def abstract_declarator(self):
>
> + return self.getTypedRuleContext(CParser.Abstract_declaratorContext,0)
>
> +
>
> +
>
> + def type_id(self):
>
> + return self.getTypedRuleContext(CParser.Type_idContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_type_name
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterType_name" ):
>
> + listener.enterType_name(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitType_name" ):
>
> + listener.exitType_name(self)
>
> +
>
> +
>
> +
>
> +
>
> + def type_name(self):
>
> +
>
> + localctx = CParser.Type_nameContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 58, self.RULE_type_name)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.state = 454
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,54,self._ctx)
>
> + if la_ == 1:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 449
>
> + self.specifier_qualifier_list()
>
> + self.state = 451
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__37) | (1 << CParser.T__39) | (1 << CParser.T__41))) != 0):
>
> + self.state = 450
>
> + self.abstract_declarator()
>
> +
>
> +
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 453
>
> + self.type_id()
>
> + pass
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Abstract_declaratorContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def pointer(self):
>
> + return self.getTypedRuleContext(CParser.PointerContext,0)
>
> +
>
> +
>
> + def direct_abstract_declarator(self):
>
> + return self.getTypedRuleContext(CParser.Direct_abstract_declaratorContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_abstract_declarator
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterAbstract_declarator" ):
>
> + listener.enterAbstract_declarator(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitAbstract_declarator" ):
>
> + listener.exitAbstract_declarator(self)
>
> +
>
> +
>
> +
>
> +
>
> + def abstract_declarator(self):
>
> +
>
> + localctx = CParser.Abstract_declaratorContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 60, self.RULE_abstract_declarator)
>
> + try:
>
> + self.state = 461
>
> + self._errHandler.sync(self)
>
> + token = self._input.LA(1)
>
> + if token in [CParser.T__41]:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 456
>
> + self.pointer()
>
> + self.state = 458
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,55,self._ctx)
>
> + if la_ == 1:
>
> + self.state = 457
>
> + self.direct_abstract_declarator()
>
> +
>
> +
>
> + pass
>
> + elif token in [CParser.T__37, CParser.T__39]:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 460
>
> + self.direct_abstract_declarator()
>
> + pass
>
> + else:
>
> + raise NoViableAltException(self)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Direct_abstract_declaratorContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def abstract_declarator(self):
>
> + return self.getTypedRuleContext(CParser.Abstract_declaratorContext,0)
>
> +
>
> +
>
> + # @param i=None Type: int
>
> + def abstract_declarator_suffix(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Abstract_declarator_suffixContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Abstract_declarator_suffixContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_direct_abstract_declarator
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterDirect_abstract_declarator" ):
>
> + listener.enterDirect_abstract_declarator(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitDirect_abstract_declarator" ):
>
> + listener.exitDirect_abstract_declarator(self)
>
> +
>
> +
>
> +
>
> + def direct_abstract_declarator(self):
>
> +
>
> + localctx = CParser.Direct_abstract_declaratorContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 62, self.RULE_direct_abstract_declarator)
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 468
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,57,self._ctx)
>
> + if la_ == 1:
>
> + self.state = 463
>
> + self.match(CParser.T__37)
>
> + self.state = 464
>
> + self.abstract_declarator()
>
> + self.state = 465
>
> + self.match(CParser.T__38)
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.state = 467
>
> + self.abstract_declarator_suffix()
>
> + pass
>
> +
>
> +
>
> + self.state = 473
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,58,self._ctx)
>
> + while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
>
> + if _alt==1:
>
> + self.state = 470
>
> + self.abstract_declarator_suffix()
>
> + self.state = 475
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,58,self._ctx)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Abstract_declarator_suffixContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def constant_expression(self):
>
> + return self.getTypedRuleContext(CParser.Constant_expressionContext,0)
>
> +
>
> +
>
> + def parameter_type_list(self):
>
> + return self.getTypedRuleContext(CParser.Parameter_type_listContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_abstract_declarator_suffix
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterAbstract_declarator_suffix" ):
>
> + listener.enterAbstract_declarator_suffix(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitAbstract_declarator_suffix" ):
>
> + listener.exitAbstract_declarator_suffix(self)
>
> +
>
> +
>
> +
>
> +
>
> + def abstract_declarator_suffix(self):
>
> +
>
> + localctx = CParser.Abstract_declarator_suffixContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 64, self.RULE_abstract_declarator_suffix)
>
> + try:
>
> + self.state = 488
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,59,self._ctx)
>
> + if la_ == 1:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 476
>
> + self.match(CParser.T__39)
>
> + self.state = 477
>
> + self.match(CParser.T__40)
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 478
>
> + self.match(CParser.T__39)
>
> + self.state = 479
>
> + self.constant_expression()
>
> + self.state = 480
>
> + self.match(CParser.T__40)
>
> + pass
>
> +
>
> + elif la_ == 3:
>
> + self.enterOuterAlt(localctx, 3)
>
> + self.state = 482
>
> + self.match(CParser.T__37)
>
> + self.state = 483
>
> + self.match(CParser.T__38)
>
> + pass
>
> +
>
> + elif la_ == 4:
>
> + self.enterOuterAlt(localctx, 4)
>
> + self.state = 484
>
> + self.match(CParser.T__37)
>
> + self.state = 485
>
> + self.parameter_type_list()
>
> + self.state = 486
>
> + self.match(CParser.T__38)
>
> + pass
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class InitializerContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def assignment_expression(self):
>
> + return self.getTypedRuleContext(CParser.Assignment_expressionContext,0)
>
> +
>
> +
>
> + def initializer_list(self):
>
> + return self.getTypedRuleContext(CParser.Initializer_listContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_initializer
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterInitializer" ):
>
> + listener.enterInitializer(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitInitializer" ):
>
> + listener.exitInitializer(self)
>
> +
>
> +
>
> +
>
> +
>
> + def initializer(self):
>
> +
>
> + localctx = CParser.InitializerContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 66, self.RULE_initializer)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.state = 498
>
> + self._errHandler.sync(self)
>
> + token = self._input.LA(1)
>
> + if token in [CParser.T__37, CParser.T__41, CParser.T__43, CParser.T__44, CParser.T__47, CParser.T__48, CParser.T__49,
> CParser.T__52, CParser.T__53, CParser.T__54, CParser.IDENTIFIER, CParser.CHARACTER_LITERAL, CParser.STRING_LITERAL,
> CParser.HEX_LITERAL, CParser.DECIMAL_LITERAL, CParser.OCTAL_LITERAL, CParser.FLOATING_POINT_LITERAL]:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 490
>
> + self.assignment_expression()
>
> + pass
>
> + elif token in [CParser.T__0]:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 491
>
> + self.match(CParser.T__0)
>
> + self.state = 492
>
> + self.initializer_list()
>
> + self.state = 494
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__3:
>
> + self.state = 493
>
> + self.match(CParser.T__3)
>
> +
>
> +
>
> + self.state = 496
>
> + self.match(CParser.T__19)
>
> + pass
>
> + else:
>
> + raise NoViableAltException(self)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Initializer_listContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def initializer(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.InitializerContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.InitializerContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_initializer_list
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterInitializer_list" ):
>
> + listener.enterInitializer_list(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitInitializer_list" ):
>
> + listener.exitInitializer_list(self)
>
> +
>
> +
>
> +
>
> +
>
> + def initializer_list(self):
>
> +
>
> + localctx = CParser.Initializer_listContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 68, self.RULE_initializer_list)
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 500
>
> + self.initializer()
>
> + self.state = 505
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,62,self._ctx)
>
> + while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
>
> + if _alt==1:
>
> + self.state = 501
>
> + self.match(CParser.T__3)
>
> + self.state = 502
>
> + self.initializer()
>
> + self.state = 507
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,62,self._ctx)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Argument_expression_listContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def assignment_expression(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Assignment_expressionContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Assignment_expressionContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_argument_expression_list
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterArgument_expression_list" ):
>
> + listener.enterArgument_expression_list(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitArgument_expression_list" ):
>
> + listener.exitArgument_expression_list(self)
>
> +
>
> +
>
> +
>
> +
>
> + def argument_expression_list(self):
>
> +
>
> + localctx = CParser.Argument_expression_listContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 70, self.RULE_argument_expression_list)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 508
>
> + self.assignment_expression()
>
> + self.state = 510
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__28:
>
> + self.state = 509
>
> + self.match(CParser.T__28)
>
> +
>
> +
>
> + self.state = 519
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while _la==CParser.T__3:
>
> + self.state = 512
>
> + self.match(CParser.T__3)
>
> + self.state = 513
>
> + self.assignment_expression()
>
> + self.state = 515
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__28:
>
> + self.state = 514
>
> + self.match(CParser.T__28)
>
> +
>
> +
>
> + self.state = 521
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Additive_expressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def multiplicative_expression(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Multiplicative_expressionContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Multiplicative_expressionContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_additive_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterAdditive_expression" ):
>
> + listener.enterAdditive_expression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitAdditive_expression" ):
>
> + listener.exitAdditive_expression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def additive_expression(self):
>
> +
>
> + localctx = CParser.Additive_expressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 72, self.RULE_additive_expression)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 522
>
> + self.multiplicative_expression()
>
> + self.state = 529
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while _la==CParser.T__43 or _la==CParser.T__44:
>
> + self.state = 527
>
> + self._errHandler.sync(self)
>
> + token = self._input.LA(1)
>
> + if token in [CParser.T__43]:
>
> + self.state = 523
>
> + self.match(CParser.T__43)
>
> + self.state = 524
>
> + self.multiplicative_expression()
>
> + pass
>
> + elif token in [CParser.T__44]:
>
> + self.state = 525
>
> + self.match(CParser.T__44)
>
> + self.state = 526
>
> + self.multiplicative_expression()
>
> + pass
>
> + else:
>
> + raise NoViableAltException(self)
>
> +
>
> + self.state = 531
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Multiplicative_expressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def cast_expression(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Cast_expressionContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Cast_expressionContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_multiplicative_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterMultiplicative_expression" ):
>
> + listener.enterMultiplicative_expression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitMultiplicative_expression" ):
>
> + listener.exitMultiplicative_expression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def multiplicative_expression(self):
>
> +
>
> + localctx = CParser.Multiplicative_expressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 74, self.RULE_multiplicative_expression)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 532
>
> + self.cast_expression()
>
> + self.state = 541
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__41) | (1 << CParser.T__45) | (1 << CParser.T__46))) != 0):
>
> + self.state = 539
>
> + self._errHandler.sync(self)
>
> + token = self._input.LA(1)
>
> + if token in [CParser.T__41]:
>
> + self.state = 533
>
> + self.match(CParser.T__41)
>
> + self.state = 534
>
> + self.cast_expression()
>
> + pass
>
> + elif token in [CParser.T__45]:
>
> + self.state = 535
>
> + self.match(CParser.T__45)
>
> + self.state = 536
>
> + self.cast_expression()
>
> + pass
>
> + elif token in [CParser.T__46]:
>
> + self.state = 537
>
> + self.match(CParser.T__46)
>
> + self.state = 538
>
> + self.cast_expression()
>
> + pass
>
> + else:
>
> + raise NoViableAltException(self)
>
> +
>
> + self.state = 543
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Cast_expressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def type_name(self):
>
> + return self.getTypedRuleContext(CParser.Type_nameContext,0)
>
> +
>
> +
>
> + def cast_expression(self):
>
> + return self.getTypedRuleContext(CParser.Cast_expressionContext,0)
>
> +
>
> +
>
> + def unary_expression(self):
>
> + return self.getTypedRuleContext(CParser.Unary_expressionContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_cast_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterCast_expression" ):
>
> + listener.enterCast_expression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitCast_expression" ):
>
> + listener.exitCast_expression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def cast_expression(self):
>
> +
>
> + localctx = CParser.Cast_expressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 76, self.RULE_cast_expression)
>
> + try:
>
> + self.state = 550
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,70,self._ctx)
>
> + if la_ == 1:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 544
>
> + self.match(CParser.T__37)
>
> + self.state = 545
>
> + self.type_name()
>
> + self.state = 546
>
> + self.match(CParser.T__38)
>
> + self.state = 547
>
> + self.cast_expression()
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 549
>
> + self.unary_expression()
>
> + pass
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Unary_expressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def postfix_expression(self):
>
> + return self.getTypedRuleContext(CParser.Postfix_expressionContext,0)
>
> +
>
> +
>
> + def unary_expression(self):
>
> + return self.getTypedRuleContext(CParser.Unary_expressionContext,0)
>
> +
>
> +
>
> + def unary_operator(self):
>
> + return self.getTypedRuleContext(CParser.Unary_operatorContext,0)
>
> +
>
> +
>
> + def cast_expression(self):
>
> + return self.getTypedRuleContext(CParser.Cast_expressionContext,0)
>
> +
>
> +
>
> + def type_name(self):
>
> + return self.getTypedRuleContext(CParser.Type_nameContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_unary_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterUnary_expression" ):
>
> + listener.enterUnary_expression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitUnary_expression" ):
>
> + listener.exitUnary_expression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def unary_expression(self):
>
> +
>
> + localctx = CParser.Unary_expressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 78, self.RULE_unary_expression)
>
> + try:
>
> + self.state = 567
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,71,self._ctx)
>
> + if la_ == 1:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 552
>
> + self.postfix_expression()
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 553
>
> + self.match(CParser.T__47)
>
> + self.state = 554
>
> + self.unary_expression()
>
> + pass
>
> +
>
> + elif la_ == 3:
>
> + self.enterOuterAlt(localctx, 3)
>
> + self.state = 555
>
> + self.match(CParser.T__48)
>
> + self.state = 556
>
> + self.unary_expression()
>
> + pass
>
> +
>
> + elif la_ == 4:
>
> + self.enterOuterAlt(localctx, 4)
>
> + self.state = 557
>
> + self.unary_operator()
>
> + self.state = 558
>
> + self.cast_expression()
>
> + pass
>
> +
>
> + elif la_ == 5:
>
> + self.enterOuterAlt(localctx, 5)
>
> + self.state = 560
>
> + self.match(CParser.T__49)
>
> + self.state = 561
>
> + self.unary_expression()
>
> + pass
>
> +
>
> + elif la_ == 6:
>
> + self.enterOuterAlt(localctx, 6)
>
> + self.state = 562
>
> + self.match(CParser.T__49)
>
> + self.state = 563
>
> + self.match(CParser.T__37)
>
> + self.state = 564
>
> + self.type_name()
>
> + self.state = 565
>
> + self.match(CParser.T__38)
>
> + pass
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Postfix_expressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> + self.FuncCallText = ''
>
> + self.p = None # Primary_expressionContext
>
> + self.a = None # Token
>
> + self.c = None # Argument_expression_listContext
>
> + self.b = None # Token
>
> + self.x = None # Token
>
> + self.y = None # Token
>
> + self.z = None # Token
>
> +
>
> + def primary_expression(self):
>
> + return self.getTypedRuleContext(CParser.Primary_expressionContext,0)
>
> +
>
> +
>
> + # @param i=None Type: int
>
> + def expression(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.ExpressionContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.ExpressionContext,i)
>
> +
>
> +
>
> + # @param i=None Type: int
>
> + def macro_parameter_list(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Macro_parameter_listContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Macro_parameter_listContext,i)
>
> +
>
> +
>
> + # @param i=None Type: int
>
> + def argument_expression_list(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Argument_expression_listContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Argument_expression_listContext,i)
>
> +
>
> +
>
> + # @param i=None Type: int
>
> + def IDENTIFIER(self,i=None):
>
> + if i is None:
>
> + return self.getTokens(CParser.IDENTIFIER)
>
> + else:
>
> + return self.getToken(CParser.IDENTIFIER, i)
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_postfix_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterPostfix_expression" ):
>
> + listener.enterPostfix_expression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitPostfix_expression" ):
>
> + listener.exitPostfix_expression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def postfix_expression(self):
>
> +
>
> + localctx = CParser.Postfix_expressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 80, self.RULE_postfix_expression)
>
> +
>
> + self.FuncCallText=''
>
> +
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 569
>
> + localctx.p = self.primary_expression()
>
> + self.FuncCallText += (None if localctx.p is None else self._input.getText((localctx.p.start,localctx.p.stop)))
>
> + self.state = 600
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,73,self._ctx)
>
> + while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
>
> + if _alt==1:
>
> + self.state = 598
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,72,self._ctx)
>
> + if la_ == 1:
>
> + self.state = 571
>
> + self.match(CParser.T__39)
>
> + self.state = 572
>
> + self.expression()
>
> + self.state = 573
>
> + self.match(CParser.T__40)
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.state = 575
>
> + self.match(CParser.T__37)
>
> + self.state = 576
>
> + localctx.a = self.match(CParser.T__38)
>
> + self.StoreFunctionCalling((None if localctx.p is None else localctx.p.start).line, (None if localctx.p is None else
> localctx.p.start).column, (0 if localctx.a is None else localctx.a.line), localctx.a.column, self.FuncCallText, '')
>
> + pass
>
> +
>
> + elif la_ == 3:
>
> + self.state = 578
>
> + self.match(CParser.T__37)
>
> + self.state = 579
>
> + localctx.c = self.argument_expression_list()
>
> + self.state = 580
>
> + localctx.b = self.match(CParser.T__38)
>
> + self.StoreFunctionCalling((None if localctx.p is None else localctx.p.start).line, (None if localctx.p is None else
> localctx.p.start).column, (0 if localctx.b is None else localctx.b.line), localctx.b.column, self.FuncCallText, (None if localctx.c is None else
> self._input.getText((localctx.c.start,localctx.c.stop))))
>
> + pass
>
> +
>
> + elif la_ == 4:
>
> + self.state = 583
>
> + self.match(CParser.T__37)
>
> + self.state = 584
>
> + self.macro_parameter_list()
>
> + self.state = 585
>
> + self.match(CParser.T__38)
>
> + pass
>
> +
>
> + elif la_ == 5:
>
> + self.state = 587
>
> + self.match(CParser.T__50)
>
> + self.state = 588
>
> + localctx.x = self.match(CParser.IDENTIFIER)
>
> + self.FuncCallText += '.' + (None if localctx.x is None else localctx.x.text)
>
> + pass
>
> +
>
> + elif la_ == 6:
>
> + self.state = 590
>
> + self.match(CParser.T__41)
>
> + self.state = 591
>
> + localctx.y = self.match(CParser.IDENTIFIER)
>
> + self.FuncCallText = (None if localctx.y is None else localctx.y.text)
>
> + pass
>
> +
>
> + elif la_ == 7:
>
> + self.state = 593
>
> + self.match(CParser.T__51)
>
> + self.state = 594
>
> + localctx.z = self.match(CParser.IDENTIFIER)
>
> + self.FuncCallText += '->' + (None if localctx.z is None else localctx.z.text)
>
> + pass
>
> +
>
> + elif la_ == 8:
>
> + self.state = 596
>
> + self.match(CParser.T__47)
>
> + pass
>
> +
>
> + elif la_ == 9:
>
> + self.state = 597
>
> + self.match(CParser.T__48)
>
> + pass
>
> +
>
> +
>
> + self.state = 602
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,73,self._ctx)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Macro_parameter_listContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def parameter_declaration(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Parameter_declarationContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Parameter_declarationContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_macro_parameter_list
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterMacro_parameter_list" ):
>
> + listener.enterMacro_parameter_list(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitMacro_parameter_list" ):
>
> + listener.exitMacro_parameter_list(self)
>
> +
>
> +
>
> +
>
> +
>
> + def macro_parameter_list(self):
>
> +
>
> + localctx = CParser.Macro_parameter_listContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 82, self.RULE_macro_parameter_list)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 603
>
> + self.parameter_declaration()
>
> + self.state = 608
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while _la==CParser.T__3:
>
> + self.state = 604
>
> + self.match(CParser.T__3)
>
> + self.state = 605
>
> + self.parameter_declaration()
>
> + self.state = 610
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Unary_operatorContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_unary_operator
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterUnary_operator" ):
>
> + listener.enterUnary_operator(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitUnary_operator" ):
>
> + listener.exitUnary_operator(self)
>
> +
>
> +
>
> +
>
> +
>
> + def unary_operator(self):
>
> +
>
> + localctx = CParser.Unary_operatorContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 84, self.RULE_unary_operator)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 611
>
> + _la = self._input.LA(1)
>
> + if not((((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__41) | (1 << CParser.T__43) | (1 << CParser.T__44) | (1 <<
> CParser.T__52) | (1 << CParser.T__53) | (1 << CParser.T__54))) != 0)):
>
> + self._errHandler.recoverInline(self)
>
> + else:
>
> + self._errHandler.reportMatch(self)
>
> + self.consume()
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Primary_expressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def IDENTIFIER(self):
>
> + return self.getToken(CParser.IDENTIFIER, 0)
>
> +
>
> + def constant(self):
>
> + return self.getTypedRuleContext(CParser.ConstantContext,0)
>
> +
>
> +
>
> + def expression(self):
>
> + return self.getTypedRuleContext(CParser.ExpressionContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_primary_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterPrimary_expression" ):
>
> + listener.enterPrimary_expression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitPrimary_expression" ):
>
> + listener.exitPrimary_expression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def primary_expression(self):
>
> +
>
> + localctx = CParser.Primary_expressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 86, self.RULE_primary_expression)
>
> + try:
>
> + self.state = 619
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,75,self._ctx)
>
> + if la_ == 1:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 613
>
> + self.match(CParser.IDENTIFIER)
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 614
>
> + self.constant()
>
> + pass
>
> +
>
> + elif la_ == 3:
>
> + self.enterOuterAlt(localctx, 3)
>
> + self.state = 615
>
> + self.match(CParser.T__37)
>
> + self.state = 616
>
> + self.expression()
>
> + self.state = 617
>
> + self.match(CParser.T__38)
>
> + pass
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class ConstantContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def HEX_LITERAL(self):
>
> + return self.getToken(CParser.HEX_LITERAL, 0)
>
> +
>
> + def OCTAL_LITERAL(self):
>
> + return self.getToken(CParser.OCTAL_LITERAL, 0)
>
> +
>
> + def DECIMAL_LITERAL(self):
>
> + return self.getToken(CParser.DECIMAL_LITERAL, 0)
>
> +
>
> + def CHARACTER_LITERAL(self):
>
> + return self.getToken(CParser.CHARACTER_LITERAL, 0)
>
> +
>
> + # @param i=None Type: int
>
> + def IDENTIFIER(self,i=None):
>
> + if i is None:
>
> + return self.getTokens(CParser.IDENTIFIER)
>
> + else:
>
> + return self.getToken(CParser.IDENTIFIER, i)
>
> +
>
> + # @param i=None Type: int
>
> + def STRING_LITERAL(self,i=None):
>
> + if i is None:
>
> + return self.getTokens(CParser.STRING_LITERAL)
>
> + else:
>
> + return self.getToken(CParser.STRING_LITERAL, i)
>
> +
>
> + def FLOATING_POINT_LITERAL(self):
>
> + return self.getToken(CParser.FLOATING_POINT_LITERAL, 0)
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_constant
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterConstant" ):
>
> + listener.enterConstant(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitConstant" ):
>
> + listener.exitConstant(self)
>
> +
>
> +
>
> +
>
> +
>
> + def constant(self):
>
> +
>
> + localctx = CParser.ConstantContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 88, self.RULE_constant)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.state = 647
>
> + self._errHandler.sync(self)
>
> + token = self._input.LA(1)
>
> + if token in [CParser.HEX_LITERAL]:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 621
>
> + self.match(CParser.HEX_LITERAL)
>
> + pass
>
> + elif token in [CParser.OCTAL_LITERAL]:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 622
>
> + self.match(CParser.OCTAL_LITERAL)
>
> + pass
>
> + elif token in [CParser.DECIMAL_LITERAL]:
>
> + self.enterOuterAlt(localctx, 3)
>
> + self.state = 623
>
> + self.match(CParser.DECIMAL_LITERAL)
>
> + pass
>
> + elif token in [CParser.CHARACTER_LITERAL]:
>
> + self.enterOuterAlt(localctx, 4)
>
> + self.state = 624
>
> + self.match(CParser.CHARACTER_LITERAL)
>
> + pass
>
> + elif token in [CParser.IDENTIFIER, CParser.STRING_LITERAL]:
>
> + self.enterOuterAlt(localctx, 5)
>
> + self.state = 636
>
> + self._errHandler.sync(self)
>
> + _alt = 1
>
> + while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
>
> + if _alt == 1:
>
> + self.state = 628
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while _la==CParser.IDENTIFIER:
>
> + self.state = 625
>
> + self.match(CParser.IDENTIFIER)
>
> + self.state = 630
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + self.state = 632
>
> + self._errHandler.sync(self)
>
> + _alt = 1
>
> + while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
>
> + if _alt == 1:
>
> + self.state = 631
>
> + self.match(CParser.STRING_LITERAL)
>
> +
>
> + else:
>
> + raise NoViableAltException(self)
>
> + self.state = 634
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,77,self._ctx)
>
> +
>
> +
>
> + else:
>
> + raise NoViableAltException(self)
>
> + self.state = 638
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,78,self._ctx)
>
> +
>
> + self.state = 643
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while _la==CParser.IDENTIFIER:
>
> + self.state = 640
>
> + self.match(CParser.IDENTIFIER)
>
> + self.state = 645
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + pass
>
> + elif token in [CParser.FLOATING_POINT_LITERAL]:
>
> + self.enterOuterAlt(localctx, 6)
>
> + self.state = 646
>
> + self.match(CParser.FLOATING_POINT_LITERAL)
>
> + pass
>
> + else:
>
> + raise NoViableAltException(self)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class ExpressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def assignment_expression(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Assignment_expressionContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Assignment_expressionContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterExpression" ):
>
> + listener.enterExpression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitExpression" ):
>
> + listener.exitExpression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def expression(self):
>
> +
>
> + localctx = CParser.ExpressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 90, self.RULE_expression)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 649
>
> + self.assignment_expression()
>
> + self.state = 654
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while _la==CParser.T__3:
>
> + self.state = 650
>
> + self.match(CParser.T__3)
>
> + self.state = 651
>
> + self.assignment_expression()
>
> + self.state = 656
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Constant_expressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def conditional_expression(self):
>
> + return self.getTypedRuleContext(CParser.Conditional_expressionContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_constant_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterConstant_expression" ):
>
> + listener.enterConstant_expression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitConstant_expression" ):
>
> + listener.exitConstant_expression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def constant_expression(self):
>
> +
>
> + localctx = CParser.Constant_expressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 92, self.RULE_constant_expression)
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 657
>
> + self.conditional_expression()
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Assignment_expressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def lvalue(self):
>
> + return self.getTypedRuleContext(CParser.LvalueContext,0)
>
> +
>
> +
>
> + def assignment_operator(self):
>
> + return self.getTypedRuleContext(CParser.Assignment_operatorContext,0)
>
> +
>
> +
>
> + def assignment_expression(self):
>
> + return self.getTypedRuleContext(CParser.Assignment_expressionContext,0)
>
> +
>
> +
>
> + def conditional_expression(self):
>
> + return self.getTypedRuleContext(CParser.Conditional_expressionContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_assignment_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterAssignment_expression" ):
>
> + listener.enterAssignment_expression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitAssignment_expression" ):
>
> + listener.exitAssignment_expression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def assignment_expression(self):
>
> +
>
> + localctx = CParser.Assignment_expressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 94, self.RULE_assignment_expression)
>
> + try:
>
> + self.state = 664
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,82,self._ctx)
>
> + if la_ == 1:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 659
>
> + self.lvalue()
>
> + self.state = 660
>
> + self.assignment_operator()
>
> + self.state = 661
>
> + self.assignment_expression()
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 663
>
> + self.conditional_expression()
>
> + pass
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class LvalueContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def unary_expression(self):
>
> + return self.getTypedRuleContext(CParser.Unary_expressionContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_lvalue
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterLvalue" ):
>
> + listener.enterLvalue(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitLvalue" ):
>
> + listener.exitLvalue(self)
>
> +
>
> +
>
> +
>
> +
>
> + def lvalue(self):
>
> +
>
> + localctx = CParser.LvalueContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 96, self.RULE_lvalue)
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 666
>
> + self.unary_expression()
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Assignment_operatorContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_assignment_operator
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterAssignment_operator" ):
>
> + listener.enterAssignment_operator(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitAssignment_operator" ):
>
> + listener.exitAssignment_operator(self)
>
> +
>
> +
>
> +
>
> +
>
> + def assignment_operator(self):
>
> +
>
> + localctx = CParser.Assignment_operatorContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 98, self.RULE_assignment_operator)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 668
>
> + _la = self._input.LA(1)
>
> + if not(((((_la - 5)) & ~0x3f) == 0 and ((1 << (_la - 5)) & ((1 << (CParser.T__4 - 5)) | (1 << (CParser.T__55 - 5)) | (1 <<
> (CParser.T__56 - 5)) | (1 << (CParser.T__57 - 5)) | (1 << (CParser.T__58 - 5)) | (1 << (CParser.T__59 - 5)) | (1 << (CParser.T__60 - 5)) | (1 <<
> (CParser.T__61 - 5)) | (1 << (CParser.T__62 - 5)) | (1 << (CParser.T__63 - 5)) | (1 << (CParser.T__64 - 5)))) != 0)):
>
> + self._errHandler.recoverInline(self)
>
> + else:
>
> + self._errHandler.reportMatch(self)
>
> + self.consume()
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Conditional_expressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> + self.e = None # Logical_or_expressionContext
>
> +
>
> + def logical_or_expression(self):
>
> + return self.getTypedRuleContext(CParser.Logical_or_expressionContext,0)
>
> +
>
> +
>
> + def expression(self):
>
> + return self.getTypedRuleContext(CParser.ExpressionContext,0)
>
> +
>
> +
>
> + def conditional_expression(self):
>
> + return self.getTypedRuleContext(CParser.Conditional_expressionContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_conditional_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterConditional_expression" ):
>
> + listener.enterConditional_expression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitConditional_expression" ):
>
> + listener.exitConditional_expression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def conditional_expression(self):
>
> +
>
> + localctx = CParser.Conditional_expressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 100, self.RULE_conditional_expression)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 670
>
> + localctx.e = self.logical_or_expression()
>
> + self.state = 677
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__65:
>
> + self.state = 671
>
> + self.match(CParser.T__65)
>
> + self.state = 672
>
> + self.expression()
>
> + self.state = 673
>
> + self.match(CParser.T__22)
>
> + self.state = 674
>
> + self.conditional_expression()
>
> + self.StorePredicateExpression((None if localctx.e is None else localctx.e.start).line, (None if localctx.e is None else
> localctx.e.start).column, (None if localctx.e is None else localctx.e.stop).line, (None if localctx.e is None else localctx.e.stop).column, (None
> if localctx.e is None else self._input.getText((localctx.e.start,localctx.e.stop))))
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Logical_or_expressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def logical_and_expression(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Logical_and_expressionContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Logical_and_expressionContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_logical_or_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterLogical_or_expression" ):
>
> + listener.enterLogical_or_expression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitLogical_or_expression" ):
>
> + listener.exitLogical_or_expression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def logical_or_expression(self):
>
> +
>
> + localctx = CParser.Logical_or_expressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 102, self.RULE_logical_or_expression)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 679
>
> + self.logical_and_expression()
>
> + self.state = 684
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while _la==CParser.T__66:
>
> + self.state = 680
>
> + self.match(CParser.T__66)
>
> + self.state = 681
>
> + self.logical_and_expression()
>
> + self.state = 686
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Logical_and_expressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def inclusive_or_expression(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Inclusive_or_expressionContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Inclusive_or_expressionContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_logical_and_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterLogical_and_expression" ):
>
> + listener.enterLogical_and_expression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitLogical_and_expression" ):
>
> + listener.exitLogical_and_expression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def logical_and_expression(self):
>
> +
>
> + localctx = CParser.Logical_and_expressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 104, self.RULE_logical_and_expression)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 687
>
> + self.inclusive_or_expression()
>
> + self.state = 692
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while _la==CParser.T__67:
>
> + self.state = 688
>
> + self.match(CParser.T__67)
>
> + self.state = 689
>
> + self.inclusive_or_expression()
>
> + self.state = 694
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Inclusive_or_expressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def exclusive_or_expression(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Exclusive_or_expressionContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Exclusive_or_expressionContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_inclusive_or_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterInclusive_or_expression" ):
>
> + listener.enterInclusive_or_expression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitInclusive_or_expression" ):
>
> + listener.exitInclusive_or_expression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def inclusive_or_expression(self):
>
> +
>
> + localctx = CParser.Inclusive_or_expressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 106, self.RULE_inclusive_or_expression)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 695
>
> + self.exclusive_or_expression()
>
> + self.state = 700
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while _la==CParser.T__68:
>
> + self.state = 696
>
> + self.match(CParser.T__68)
>
> + self.state = 697
>
> + self.exclusive_or_expression()
>
> + self.state = 702
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Exclusive_or_expressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def and_expression(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.And_expressionContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.And_expressionContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_exclusive_or_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterExclusive_or_expression" ):
>
> + listener.enterExclusive_or_expression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitExclusive_or_expression" ):
>
> + listener.exitExclusive_or_expression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def exclusive_or_expression(self):
>
> +
>
> + localctx = CParser.Exclusive_or_expressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 108, self.RULE_exclusive_or_expression)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 703
>
> + self.and_expression()
>
> + self.state = 708
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while _la==CParser.T__69:
>
> + self.state = 704
>
> + self.match(CParser.T__69)
>
> + self.state = 705
>
> + self.and_expression()
>
> + self.state = 710
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class And_expressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def equality_expression(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Equality_expressionContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Equality_expressionContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_and_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterAnd_expression" ):
>
> + listener.enterAnd_expression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitAnd_expression" ):
>
> + listener.exitAnd_expression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def and_expression(self):
>
> +
>
> + localctx = CParser.And_expressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 110, self.RULE_and_expression)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 711
>
> + self.equality_expression()
>
> + self.state = 716
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while _la==CParser.T__52:
>
> + self.state = 712
>
> + self.match(CParser.T__52)
>
> + self.state = 713
>
> + self.equality_expression()
>
> + self.state = 718
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Equality_expressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def relational_expression(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Relational_expressionContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Relational_expressionContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_equality_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterEquality_expression" ):
>
> + listener.enterEquality_expression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitEquality_expression" ):
>
> + listener.exitEquality_expression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def equality_expression(self):
>
> +
>
> + localctx = CParser.Equality_expressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 112, self.RULE_equality_expression)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 719
>
> + self.relational_expression()
>
> + self.state = 724
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while _la==CParser.T__70 or _la==CParser.T__71:
>
> + self.state = 720
>
> + _la = self._input.LA(1)
>
> + if not(_la==CParser.T__70 or _la==CParser.T__71):
>
> + self._errHandler.recoverInline(self)
>
> + else:
>
> + self._errHandler.reportMatch(self)
>
> + self.consume()
>
> + self.state = 721
>
> + self.relational_expression()
>
> + self.state = 726
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Relational_expressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def shift_expression(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Shift_expressionContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Shift_expressionContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_relational_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterRelational_expression" ):
>
> + listener.enterRelational_expression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitRelational_expression" ):
>
> + listener.exitRelational_expression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def relational_expression(self):
>
> +
>
> + localctx = CParser.Relational_expressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 114, self.RULE_relational_expression)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 727
>
> + self.shift_expression()
>
> + self.state = 732
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while ((((_la - 73)) & ~0x3f) == 0 and ((1 << (_la - 73)) & ((1 << (CParser.T__72 - 73)) | (1 << (CParser.T__73 - 73)) | (1 <<
> (CParser.T__74 - 73)) | (1 << (CParser.T__75 - 73)))) != 0):
>
> + self.state = 728
>
> + _la = self._input.LA(1)
>
> + if not(((((_la - 73)) & ~0x3f) == 0 and ((1 << (_la - 73)) & ((1 << (CParser.T__72 - 73)) | (1 << (CParser.T__73 - 73)) | (1 <<
> (CParser.T__74 - 73)) | (1 << (CParser.T__75 - 73)))) != 0)):
>
> + self._errHandler.recoverInline(self)
>
> + else:
>
> + self._errHandler.reportMatch(self)
>
> + self.consume()
>
> + self.state = 729
>
> + self.shift_expression()
>
> + self.state = 734
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Shift_expressionContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def additive_expression(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.Additive_expressionContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.Additive_expressionContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_shift_expression
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterShift_expression" ):
>
> + listener.enterShift_expression(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitShift_expression" ):
>
> + listener.exitShift_expression(self)
>
> +
>
> +
>
> +
>
> +
>
> + def shift_expression(self):
>
> +
>
> + localctx = CParser.Shift_expressionContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 116, self.RULE_shift_expression)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 735
>
> + self.additive_expression()
>
> + self.state = 740
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while _la==CParser.T__76 or _la==CParser.T__77:
>
> + self.state = 736
>
> + _la = self._input.LA(1)
>
> + if not(_la==CParser.T__76 or _la==CParser.T__77):
>
> + self._errHandler.recoverInline(self)
>
> + else:
>
> + self._errHandler.reportMatch(self)
>
> + self.consume()
>
> + self.state = 737
>
> + self.additive_expression()
>
> + self.state = 742
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class StatementContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def labeled_statement(self):
>
> + return self.getTypedRuleContext(CParser.Labeled_statementContext,0)
>
> +
>
> +
>
> + def compound_statement(self):
>
> + return self.getTypedRuleContext(CParser.Compound_statementContext,0)
>
> +
>
> +
>
> + def expression_statement(self):
>
> + return self.getTypedRuleContext(CParser.Expression_statementContext,0)
>
> +
>
> +
>
> + def selection_statement(self):
>
> + return self.getTypedRuleContext(CParser.Selection_statementContext,0)
>
> +
>
> +
>
> + def iteration_statement(self):
>
> + return self.getTypedRuleContext(CParser.Iteration_statementContext,0)
>
> +
>
> +
>
> + def jump_statement(self):
>
> + return self.getTypedRuleContext(CParser.Jump_statementContext,0)
>
> +
>
> +
>
> + def macro_statement(self):
>
> + return self.getTypedRuleContext(CParser.Macro_statementContext,0)
>
> +
>
> +
>
> + def asm2_statement(self):
>
> + return self.getTypedRuleContext(CParser.Asm2_statementContext,0)
>
> +
>
> +
>
> + def asm1_statement(self):
>
> + return self.getTypedRuleContext(CParser.Asm1_statementContext,0)
>
> +
>
> +
>
> + def asm_statement(self):
>
> + return self.getTypedRuleContext(CParser.Asm_statementContext,0)
>
> +
>
> +
>
> + def declaration(self):
>
> + return self.getTypedRuleContext(CParser.DeclarationContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_statement
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterStatement" ):
>
> + listener.enterStatement(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitStatement" ):
>
> + listener.exitStatement(self)
>
> +
>
> +
>
> +
>
> +
>
> + def statement(self):
>
> +
>
> + localctx = CParser.StatementContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 118, self.RULE_statement)
>
> + try:
>
> + self.state = 754
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,92,self._ctx)
>
> + if la_ == 1:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 743
>
> + self.labeled_statement()
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 744
>
> + self.compound_statement()
>
> + pass
>
> +
>
> + elif la_ == 3:
>
> + self.enterOuterAlt(localctx, 3)
>
> + self.state = 745
>
> + self.expression_statement()
>
> + pass
>
> +
>
> + elif la_ == 4:
>
> + self.enterOuterAlt(localctx, 4)
>
> + self.state = 746
>
> + self.selection_statement()
>
> + pass
>
> +
>
> + elif la_ == 5:
>
> + self.enterOuterAlt(localctx, 5)
>
> + self.state = 747
>
> + self.iteration_statement()
>
> + pass
>
> +
>
> + elif la_ == 6:
>
> + self.enterOuterAlt(localctx, 6)
>
> + self.state = 748
>
> + self.jump_statement()
>
> + pass
>
> +
>
> + elif la_ == 7:
>
> + self.enterOuterAlt(localctx, 7)
>
> + self.state = 749
>
> + self.macro_statement()
>
> + pass
>
> +
>
> + elif la_ == 8:
>
> + self.enterOuterAlt(localctx, 8)
>
> + self.state = 750
>
> + self.asm2_statement()
>
> + pass
>
> +
>
> + elif la_ == 9:
>
> + self.enterOuterAlt(localctx, 9)
>
> + self.state = 751
>
> + self.asm1_statement()
>
> + pass
>
> +
>
> + elif la_ == 10:
>
> + self.enterOuterAlt(localctx, 10)
>
> + self.state = 752
>
> + self.asm_statement()
>
> + pass
>
> +
>
> + elif la_ == 11:
>
> + self.enterOuterAlt(localctx, 11)
>
> + self.state = 753
>
> + self.declaration()
>
> + pass
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Asm2_statementContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def IDENTIFIER(self):
>
> + return self.getToken(CParser.IDENTIFIER, 0)
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_asm2_statement
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterAsm2_statement" ):
>
> + listener.enterAsm2_statement(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitAsm2_statement" ):
>
> + listener.exitAsm2_statement(self)
>
> +
>
> +
>
> +
>
> +
>
> + def asm2_statement(self):
>
> +
>
> + localctx = CParser.Asm2_statementContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 120, self.RULE_asm2_statement)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 757
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if _la==CParser.T__78:
>
> + self.state = 756
>
> + self.match(CParser.T__78)
>
> +
>
> +
>
> + self.state = 759
>
> + self.match(CParser.IDENTIFIER)
>
> + self.state = 760
>
> + self.match(CParser.T__37)
>
> + self.state = 764
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,94,self._ctx)
>
> + while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
>
> + if _alt==1:
>
> + self.state = 761
>
> + _la = self._input.LA(1)
>
> + if _la <= 0 or _la==CParser.T__1:
>
> + self._errHandler.recoverInline(self)
>
> + else:
>
> + self._errHandler.reportMatch(self)
>
> + self.consume()
>
> + self.state = 766
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,94,self._ctx)
>
> +
>
> + self.state = 767
>
> + self.match(CParser.T__38)
>
> + self.state = 768
>
> + self.match(CParser.T__1)
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Asm1_statementContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_asm1_statement
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterAsm1_statement" ):
>
> + listener.enterAsm1_statement(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitAsm1_statement" ):
>
> + listener.exitAsm1_statement(self)
>
> +
>
> +
>
> +
>
> +
>
> + def asm1_statement(self):
>
> +
>
> + localctx = CParser.Asm1_statementContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 122, self.RULE_asm1_statement)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 770
>
> + self.match(CParser.T__79)
>
> + self.state = 771
>
> + self.match(CParser.T__0)
>
> + self.state = 775
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 <<
> CParser.T__3) | (1 << CParser.T__4) | (1 << CParser.T__5) | (1 << CParser.T__6) | (1 << CParser.T__7) | (1 << CParser.T__8) | (1 << CParser.T__9)
> | (1 << CParser.T__10) | (1 << CParser.T__11) | (1 << CParser.T__12) | (1 << CParser.T__13) | (1 << CParser.T__14) | (1 << CParser.T__15) | (1
> << CParser.T__16) | (1 << CParser.T__17) | (1 << CParser.T__18) | (1 << CParser.T__20) | (1 << CParser.T__21) | (1 << CParser.T__22) | (1 <<
> CParser.T__23) | (1 << CParser.T__24) | (1 << CParser.T__25) | (1 << CParser.T__26) | (1 << CParser.T__27) | (1 << CParser.T__28) | (1 <<
> CParser.T__29) | (1 << CParser.T__30) | (1 << CParser.T__31) | (1 << CParser.T__32) | (1 << CParser.T__33) | (1 << CParser.T__34) | (1 <<
> CParser.T__35) | (1 << CParser.T__36) | (1 << CParser.T__37) | (1 << CParser.T__38) | (1 << CParser.T__39) | (1 << CParser.T__40) | (1 <<
> CParser.T__41) | (1 << CParser.T__42) | (1 << CParser.T__43) | (1 << CParser.T__44) | (1 << CParser.T__45) | (1 << CParser.T__46) | (1 <<
> CParser.T__47) | (1 << CParser.T__48) | (1 << CParser.T__49) | (1 << CParser.T__50) | (1 << CParser.T__51) | (1 << CParser.T__52) | (1 <<
> CParser.T__53) | (1 << CParser.T__54) | (1 << CParser.T__55) | (1 << CParser.T__56) | (1 << CParser.T__57) | (1 << CParser.T__58) | (1 <<
> CParser.T__59) | (1 << CParser.T__60) | (1 << CParser.T__61) | (1 << CParser.T__62))) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64))
> & ((1 << (CParser.T__63 - 64)) | (1 << (CParser.T__64 - 64)) | (1 << (CParser.T__65 - 64)) | (1 << (CParser.T__66 - 64)) | (1 << (CParser.T__67 -
> 64)) | (1 << (CParser.T__68 - 64)) | (1 << (CParser.T__69 - 64)) | (1 << (CParser.T__70 - 64)) | (1 << (CParser.T__71 - 64)) | (1 <<
> (CParser.T__72 - 64)) | (1 << (CParser.T__73 - 64)) | (1 << (CParser.T__74 - 64)) | (1 << (CParser.T__75 - 64)) | (1 << (CParser.T__76 - 64)) | (1
> << (CParser.T__77 - 64)) | (1 << (CParser.T__78 - 64)) | (1 << (CParser.T__79 - 64)) | (1 << (CParser.T__80 - 64)) | (1 << (CParser.T__81 - 64)) |
> (1 << (CParser.T__82 - 64)) | (1 << (CParser.T__83 - 64)) | (1 << (CParser.T__84 - 64)) | (1 << (CParser.T__85 - 64)) | (1 << (CParser.T__86 - 64))
> | (1 << (CParser.T__87 - 64)) | (1 << (CParser.T__88 - 64)) | (1 << (CParser.T__89 - 64)) | (1 << (CParser.T__90 - 64)) | (1 << (CParser.T__91 -
> 64)) | (1 << (CParser.IDENTIFIER - 64)) | (1 << (CParser.CHARACTER_LITERAL - 64)) | (1 << (CParser.STRING_LITERAL - 64)) | (1 <<
> (CParser.HEX_LITERAL - 64)) | (1 << (CParser.DECIMAL_LITERAL - 64)) | (1 << (CParser.OCTAL_LITERAL - 64)) | (1 <<
> (CParser.FLOATING_POINT_LITERAL - 64)) | (1 << (CParser.WS - 64)) | (1 << (CParser.BS - 64)) | (1 << (CParser.UnicodeVocabulary - 64)) | (1
> << (CParser.COMMENT - 64)) | (1 << (CParser.LINE_COMMENT - 64)) | (1 << (CParser.LINE_COMMAND - 64)))) != 0):
>
> + self.state = 772
>
> + _la = self._input.LA(1)
>
> + if _la <= 0 or _la==CParser.T__19:
>
> + self._errHandler.recoverInline(self)
>
> + else:
>
> + self._errHandler.reportMatch(self)
>
> + self.consume()
>
> + self.state = 777
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + self.state = 778
>
> + self.match(CParser.T__19)
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Asm_statementContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_asm_statement
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterAsm_statement" ):
>
> + listener.enterAsm_statement(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitAsm_statement" ):
>
> + listener.exitAsm_statement(self)
>
> +
>
> +
>
> +
>
> +
>
> + def asm_statement(self):
>
> +
>
> + localctx = CParser.Asm_statementContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 124, self.RULE_asm_statement)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 780
>
> + self.match(CParser.T__80)
>
> + self.state = 781
>
> + self.match(CParser.T__0)
>
> + self.state = 785
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + while (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 <<
> CParser.T__3) | (1 << CParser.T__4) | (1 << CParser.T__5) | (1 << CParser.T__6) | (1 << CParser.T__7) | (1 << CParser.T__8) | (1 << CParser.T__9)
> | (1 << CParser.T__10) | (1 << CParser.T__11) | (1 << CParser.T__12) | (1 << CParser.T__13) | (1 << CParser.T__14) | (1 << CParser.T__15) | (1
> << CParser.T__16) | (1 << CParser.T__17) | (1 << CParser.T__18) | (1 << CParser.T__20) | (1 << CParser.T__21) | (1 << CParser.T__22) | (1 <<
> CParser.T__23) | (1 << CParser.T__24) | (1 << CParser.T__25) | (1 << CParser.T__26) | (1 << CParser.T__27) | (1 << CParser.T__28) | (1 <<
> CParser.T__29) | (1 << CParser.T__30) | (1 << CParser.T__31) | (1 << CParser.T__32) | (1 << CParser.T__33) | (1 << CParser.T__34) | (1 <<
> CParser.T__35) | (1 << CParser.T__36) | (1 << CParser.T__37) | (1 << CParser.T__38) | (1 << CParser.T__39) | (1 << CParser.T__40) | (1 <<
> CParser.T__41) | (1 << CParser.T__42) | (1 << CParser.T__43) | (1 << CParser.T__44) | (1 << CParser.T__45) | (1 << CParser.T__46) | (1 <<
> CParser.T__47) | (1 << CParser.T__48) | (1 << CParser.T__49) | (1 << CParser.T__50) | (1 << CParser.T__51) | (1 << CParser.T__52) | (1 <<
> CParser.T__53) | (1 << CParser.T__54) | (1 << CParser.T__55) | (1 << CParser.T__56) | (1 << CParser.T__57) | (1 << CParser.T__58) | (1 <<
> CParser.T__59) | (1 << CParser.T__60) | (1 << CParser.T__61) | (1 << CParser.T__62))) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64))
> & ((1 << (CParser.T__63 - 64)) | (1 << (CParser.T__64 - 64)) | (1 << (CParser.T__65 - 64)) | (1 << (CParser.T__66 - 64)) | (1 << (CParser.T__67 -
> 64)) | (1 << (CParser.T__68 - 64)) | (1 << (CParser.T__69 - 64)) | (1 << (CParser.T__70 - 64)) | (1 << (CParser.T__71 - 64)) | (1 <<
> (CParser.T__72 - 64)) | (1 << (CParser.T__73 - 64)) | (1 << (CParser.T__74 - 64)) | (1 << (CParser.T__75 - 64)) | (1 << (CParser.T__76 - 64)) | (1
> << (CParser.T__77 - 64)) | (1 << (CParser.T__78 - 64)) | (1 << (CParser.T__79 - 64)) | (1 << (CParser.T__80 - 64)) | (1 << (CParser.T__81 - 64)) |
> (1 << (CParser.T__82 - 64)) | (1 << (CParser.T__83 - 64)) | (1 << (CParser.T__84 - 64)) | (1 << (CParser.T__85 - 64)) | (1 << (CParser.T__86 - 64))
> | (1 << (CParser.T__87 - 64)) | (1 << (CParser.T__88 - 64)) | (1 << (CParser.T__89 - 64)) | (1 << (CParser.T__90 - 64)) | (1 << (CParser.T__91 -
> 64)) | (1 << (CParser.IDENTIFIER - 64)) | (1 << (CParser.CHARACTER_LITERAL - 64)) | (1 << (CParser.STRING_LITERAL - 64)) | (1 <<
> (CParser.HEX_LITERAL - 64)) | (1 << (CParser.DECIMAL_LITERAL - 64)) | (1 << (CParser.OCTAL_LITERAL - 64)) | (1 <<
> (CParser.FLOATING_POINT_LITERAL - 64)) | (1 << (CParser.WS - 64)) | (1 << (CParser.BS - 64)) | (1 << (CParser.UnicodeVocabulary - 64)) | (1
> << (CParser.COMMENT - 64)) | (1 << (CParser.LINE_COMMENT - 64)) | (1 << (CParser.LINE_COMMAND - 64)))) != 0):
>
> + self.state = 782
>
> + _la = self._input.LA(1)
>
> + if _la <= 0 or _la==CParser.T__19:
>
> + self._errHandler.recoverInline(self)
>
> + else:
>
> + self._errHandler.reportMatch(self)
>
> + self.consume()
>
> + self.state = 787
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> +
>
> + self.state = 788
>
> + self.match(CParser.T__19)
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Macro_statementContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def IDENTIFIER(self):
>
> + return self.getToken(CParser.IDENTIFIER, 0)
>
> +
>
> + # @param i=None Type: int
>
> + def declaration(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.DeclarationContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.DeclarationContext,i)
>
> +
>
> +
>
> + def statement_list(self):
>
> + return self.getTypedRuleContext(CParser.Statement_listContext,0)
>
> +
>
> +
>
> + def expression(self):
>
> + return self.getTypedRuleContext(CParser.ExpressionContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_macro_statement
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterMacro_statement" ):
>
> + listener.enterMacro_statement(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitMacro_statement" ):
>
> + listener.exitMacro_statement(self)
>
> +
>
> +
>
> +
>
> +
>
> + def macro_statement(self):
>
> +
>
> + localctx = CParser.Macro_statementContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 126, self.RULE_macro_statement)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 790
>
> + self.match(CParser.IDENTIFIER)
>
> + self.state = 791
>
> + self.match(CParser.T__37)
>
> + self.state = 795
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,97,self._ctx)
>
> + while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
>
> + if _alt==1:
>
> + self.state = 792
>
> + self.declaration()
>
> + self.state = 797
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,97,self._ctx)
>
> +
>
> + self.state = 799
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,98,self._ctx)
>
> + if la_ == 1:
>
> + self.state = 798
>
> + self.statement_list()
>
> +
>
> +
>
> + self.state = 802
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if ((((_la - 38)) & ~0x3f) == 0 and ((1 << (_la - 38)) & ((1 << (CParser.T__37 - 38)) | (1 << (CParser.T__41 - 38)) | (1 <<
> (CParser.T__43 - 38)) | (1 << (CParser.T__44 - 38)) | (1 << (CParser.T__47 - 38)) | (1 << (CParser.T__48 - 38)) | (1 << (CParser.T__49 - 38)) | (1
> << (CParser.T__52 - 38)) | (1 << (CParser.T__53 - 38)) | (1 << (CParser.T__54 - 38)) | (1 << (CParser.IDENTIFIER - 38)) | (1 <<
> (CParser.CHARACTER_LITERAL - 38)) | (1 << (CParser.STRING_LITERAL - 38)) | (1 << (CParser.HEX_LITERAL - 38)) | (1 <<
> (CParser.DECIMAL_LITERAL - 38)) | (1 << (CParser.OCTAL_LITERAL - 38)) | (1 << (CParser.FLOATING_POINT_LITERAL - 38)))) != 0):
>
> + self.state = 801
>
> + self.expression()
>
> +
>
> +
>
> + self.state = 804
>
> + self.match(CParser.T__38)
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Labeled_statementContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def IDENTIFIER(self):
>
> + return self.getToken(CParser.IDENTIFIER, 0)
>
> +
>
> + def statement(self):
>
> + return self.getTypedRuleContext(CParser.StatementContext,0)
>
> +
>
> +
>
> + def constant_expression(self):
>
> + return self.getTypedRuleContext(CParser.Constant_expressionContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_labeled_statement
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterLabeled_statement" ):
>
> + listener.enterLabeled_statement(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitLabeled_statement" ):
>
> + listener.exitLabeled_statement(self)
>
> +
>
> +
>
> +
>
> +
>
> + def labeled_statement(self):
>
> +
>
> + localctx = CParser.Labeled_statementContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 128, self.RULE_labeled_statement)
>
> + try:
>
> + self.state = 817
>
> + self._errHandler.sync(self)
>
> + token = self._input.LA(1)
>
> + if token in [CParser.IDENTIFIER]:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 806
>
> + self.match(CParser.IDENTIFIER)
>
> + self.state = 807
>
> + self.match(CParser.T__22)
>
> + self.state = 808
>
> + self.statement()
>
> + pass
>
> + elif token in [CParser.T__81]:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 809
>
> + self.match(CParser.T__81)
>
> + self.state = 810
>
> + self.constant_expression()
>
> + self.state = 811
>
> + self.match(CParser.T__22)
>
> + self.state = 812
>
> + self.statement()
>
> + pass
>
> + elif token in [CParser.T__82]:
>
> + self.enterOuterAlt(localctx, 3)
>
> + self.state = 814
>
> + self.match(CParser.T__82)
>
> + self.state = 815
>
> + self.match(CParser.T__22)
>
> + self.state = 816
>
> + self.statement()
>
> + pass
>
> + else:
>
> + raise NoViableAltException(self)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Compound_statementContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def declaration(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.DeclarationContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.DeclarationContext,i)
>
> +
>
> +
>
> + def statement_list(self):
>
> + return self.getTypedRuleContext(CParser.Statement_listContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_compound_statement
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterCompound_statement" ):
>
> + listener.enterCompound_statement(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitCompound_statement" ):
>
> + listener.exitCompound_statement(self)
>
> +
>
> +
>
> +
>
> +
>
> + def compound_statement(self):
>
> +
>
> + localctx = CParser.Compound_statementContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 130, self.RULE_compound_statement)
>
> + self._la = 0 # Token type
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 819
>
> + self.match(CParser.T__0)
>
> + self.state = 823
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,101,self._ctx)
>
> + while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
>
> + if _alt==1:
>
> + self.state = 820
>
> + self.declaration()
>
> + self.state = 825
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,101,self._ctx)
>
> +
>
> + self.state = 827
>
> + self._errHandler.sync(self)
>
> + _la = self._input.LA(1)
>
> + if (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << CParser.T__0) | (1 << CParser.T__1) | (1 << CParser.T__2) | (1 << CParser.T__5) |
> (1 << CParser.T__6) | (1 << CParser.T__7) | (1 << CParser.T__8) | (1 << CParser.T__9) | (1 << CParser.T__10) | (1 << CParser.T__11) | (1 <<
> CParser.T__12) | (1 << CParser.T__13) | (1 << CParser.T__14) | (1 << CParser.T__15) | (1 << CParser.T__16) | (1 << CParser.T__17) | (1 <<
> CParser.T__18) | (1 << CParser.T__20) | (1 << CParser.T__21) | (1 << CParser.T__23) | (1 << CParser.T__24) | (1 << CParser.T__25) | (1 <<
> CParser.T__26) | (1 << CParser.T__27) | (1 << CParser.T__28) | (1 << CParser.T__29) | (1 << CParser.T__30) | (1 << CParser.T__31) | (1 <<
> CParser.T__32) | (1 << CParser.T__33) | (1 << CParser.T__34) | (1 << CParser.T__35) | (1 << CParser.T__36) | (1 << CParser.T__37) | (1 <<
> CParser.T__41) | (1 << CParser.T__43) | (1 << CParser.T__44) | (1 << CParser.T__47) | (1 << CParser.T__48) | (1 << CParser.T__49) | (1 <<
> CParser.T__52) | (1 << CParser.T__53) | (1 << CParser.T__54))) != 0) or ((((_la - 79)) & ~0x3f) == 0 and ((1 << (_la - 79)) & ((1 << (CParser.T__78
> - 79)) | (1 << (CParser.T__79 - 79)) | (1 << (CParser.T__80 - 79)) | (1 << (CParser.T__81 - 79)) | (1 << (CParser.T__82 - 79)) | (1 <<
> (CParser.T__83 - 79)) | (1 << (CParser.T__85 - 79)) | (1 << (CParser.T__86 - 79)) | (1 << (CParser.T__87 - 79)) | (1 << (CParser.T__88 - 79)) | (1
> << (CParser.T__89 - 79)) | (1 << (CParser.T__90 - 79)) | (1 << (CParser.T__91 - 79)) | (1 << (CParser.IDENTIFIER - 79)) | (1 <<
> (CParser.CHARACTER_LITERAL - 79)) | (1 << (CParser.STRING_LITERAL - 79)) | (1 << (CParser.HEX_LITERAL - 79)) | (1 <<
> (CParser.DECIMAL_LITERAL - 79)) | (1 << (CParser.OCTAL_LITERAL - 79)) | (1 << (CParser.FLOATING_POINT_LITERAL - 79)))) != 0):
>
> + self.state = 826
>
> + self.statement_list()
>
> +
>
> +
>
> + self.state = 829
>
> + self.match(CParser.T__19)
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Statement_listContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + # @param i=None Type: int
>
> + def statement(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.StatementContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.StatementContext,i)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_statement_list
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterStatement_list" ):
>
> + listener.enterStatement_list(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitStatement_list" ):
>
> + listener.exitStatement_list(self)
>
> +
>
> +
>
> +
>
> +
>
> + def statement_list(self):
>
> +
>
> + localctx = CParser.Statement_listContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 132, self.RULE_statement_list)
>
> + try:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 832
>
> + self._errHandler.sync(self)
>
> + _alt = 1
>
> + while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER:
>
> + if _alt == 1:
>
> + self.state = 831
>
> + self.statement()
>
> +
>
> + else:
>
> + raise NoViableAltException(self)
>
> + self.state = 834
>
> + self._errHandler.sync(self)
>
> + _alt = self._interp.adaptivePredict(self._input,103,self._ctx)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Expression_statementContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def expression(self):
>
> + return self.getTypedRuleContext(CParser.ExpressionContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_expression_statement
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterExpression_statement" ):
>
> + listener.enterExpression_statement(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitExpression_statement" ):
>
> + listener.exitExpression_statement(self)
>
> +
>
> +
>
> +
>
> +
>
> + def expression_statement(self):
>
> +
>
> + localctx = CParser.Expression_statementContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 134, self.RULE_expression_statement)
>
> + try:
>
> + self.state = 840
>
> + self._errHandler.sync(self)
>
> + token = self._input.LA(1)
>
> + if token in [CParser.T__1]:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 836
>
> + self.match(CParser.T__1)
>
> + pass
>
> + elif token in [CParser.T__37, CParser.T__41, CParser.T__43, CParser.T__44, CParser.T__47, CParser.T__48, CParser.T__49,
> CParser.T__52, CParser.T__53, CParser.T__54, CParser.IDENTIFIER, CParser.CHARACTER_LITERAL, CParser.STRING_LITERAL,
> CParser.HEX_LITERAL, CParser.DECIMAL_LITERAL, CParser.OCTAL_LITERAL, CParser.FLOATING_POINT_LITERAL]:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 837
>
> + self.expression()
>
> + self.state = 838
>
> + self.match(CParser.T__1)
>
> + pass
>
> + else:
>
> + raise NoViableAltException(self)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Selection_statementContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> + self.e = None # ExpressionContext
>
> +
>
> + # @param i=None Type: int
>
> + def statement(self,i=None):
>
> + if i is None:
>
> + return self.getTypedRuleContexts(CParser.StatementContext)
>
> + else:
>
> + return self.getTypedRuleContext(CParser.StatementContext,i)
>
> +
>
> +
>
> + def expression(self):
>
> + return self.getTypedRuleContext(CParser.ExpressionContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_selection_statement
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterSelection_statement" ):
>
> + listener.enterSelection_statement(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitSelection_statement" ):
>
> + listener.exitSelection_statement(self)
>
> +
>
> +
>
> +
>
> +
>
> + def selection_statement(self):
>
> +
>
> + localctx = CParser.Selection_statementContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 136, self.RULE_selection_statement)
>
> + try:
>
> + self.state = 858
>
> + self._errHandler.sync(self)
>
> + token = self._input.LA(1)
>
> + if token in [CParser.T__83]:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 842
>
> + self.match(CParser.T__83)
>
> + self.state = 843
>
> + self.match(CParser.T__37)
>
> + self.state = 844
>
> + localctx.e = self.expression()
>
> + self.state = 845
>
> + self.match(CParser.T__38)
>
> + self.StorePredicateExpression((None if localctx.e is None else localctx.e.start).line, (None if localctx.e is None else
> localctx.e.start).column, (None if localctx.e is None else localctx.e.stop).line, (None if localctx.e is None else localctx.e.stop).column, (None
> if localctx.e is None else self._input.getText((localctx.e.start,localctx.e.stop))))
>
> + self.state = 847
>
> + self.statement()
>
> + self.state = 850
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,105,self._ctx)
>
> + if la_ == 1:
>
> + self.state = 848
>
> + self.match(CParser.T__84)
>
> + self.state = 849
>
> + self.statement()
>
> +
>
> +
>
> + pass
>
> + elif token in [CParser.T__85]:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 852
>
> + self.match(CParser.T__85)
>
> + self.state = 853
>
> + self.match(CParser.T__37)
>
> + self.state = 854
>
> + self.expression()
>
> + self.state = 855
>
> + self.match(CParser.T__38)
>
> + self.state = 856
>
> + self.statement()
>
> + pass
>
> + else:
>
> + raise NoViableAltException(self)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Iteration_statementContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> + self.e = None # ExpressionContext
>
> +
>
> + def statement(self):
>
> + return self.getTypedRuleContext(CParser.StatementContext,0)
>
> +
>
> +
>
> + def expression(self):
>
> + return self.getTypedRuleContext(CParser.ExpressionContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_iteration_statement
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterIteration_statement" ):
>
> + listener.enterIteration_statement(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitIteration_statement" ):
>
> + listener.exitIteration_statement(self)
>
> +
>
> +
>
> +
>
> +
>
> + def iteration_statement(self):
>
> +
>
> + localctx = CParser.Iteration_statementContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 138, self.RULE_iteration_statement)
>
> + try:
>
> + self.state = 876
>
> + self._errHandler.sync(self)
>
> + token = self._input.LA(1)
>
> + if token in [CParser.T__86]:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 860
>
> + self.match(CParser.T__86)
>
> + self.state = 861
>
> + self.match(CParser.T__37)
>
> + self.state = 862
>
> + localctx.e = self.expression()
>
> + self.state = 863
>
> + self.match(CParser.T__38)
>
> + self.state = 864
>
> + self.statement()
>
> + self.StorePredicateExpression((None if localctx.e is None else localctx.e.start).line, (None if localctx.e is None else
> localctx.e.start).column, (None if localctx.e is None else localctx.e.stop).line, (None if localctx.e is None else localctx.e.stop).column, (None
> if localctx.e is None else self._input.getText((localctx.e.start,localctx.e.stop))))
>
> + pass
>
> + elif token in [CParser.T__87]:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 867
>
> + self.match(CParser.T__87)
>
> + self.state = 868
>
> + self.statement()
>
> + self.state = 869
>
> + self.match(CParser.T__86)
>
> + self.state = 870
>
> + self.match(CParser.T__37)
>
> + self.state = 871
>
> + localctx.e = self.expression()
>
> + self.state = 872
>
> + self.match(CParser.T__38)
>
> + self.state = 873
>
> + self.match(CParser.T__1)
>
> + self.StorePredicateExpression((None if localctx.e is None else localctx.e.start).line, (None if localctx.e is None else
> localctx.e.start).column, (None if localctx.e is None else localctx.e.stop).line, (None if localctx.e is None else localctx.e.stop).column, (None
> if localctx.e is None else self._input.getText((localctx.e.start,localctx.e.stop))))
>
> + pass
>
> + else:
>
> + raise NoViableAltException(self)
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> + class Jump_statementContext(ParserRuleContext):
>
> +
>
> + # @param parent=None Type: ParserRuleContext
>
> + # @param invokingState=-1 Type: int
>
> + def __init__(self,parser,parent=None,invokingState=-1):
>
> + super().__init__(parent, invokingState)
>
> + self.parser = parser
>
> +
>
> + def IDENTIFIER(self):
>
> + return self.getToken(CParser.IDENTIFIER, 0)
>
> +
>
> + def expression(self):
>
> + return self.getTypedRuleContext(CParser.ExpressionContext,0)
>
> +
>
> +
>
> + def getRuleIndex(self):
>
> + return CParser.RULE_jump_statement
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def enterRule(self,listener):
>
> + if hasattr( listener, "enterJump_statement" ):
>
> + listener.enterJump_statement(self)
>
> +
>
> + # @param listener Type: ParseTreeListener
>
> + def exitRule(self,listener):
>
> + if hasattr( listener, "exitJump_statement" ):
>
> + listener.exitJump_statement(self)
>
> +
>
> +
>
> +
>
> +
>
> + def jump_statement(self):
>
> +
>
> + localctx = CParser.Jump_statementContext(self, self._ctx, self.state)
>
> + self.enterRule(localctx, 140, self.RULE_jump_statement)
>
> + try:
>
> + self.state = 891
>
> + self._errHandler.sync(self)
>
> + la_ = self._interp.adaptivePredict(self._input,108,self._ctx)
>
> + if la_ == 1:
>
> + self.enterOuterAlt(localctx, 1)
>
> + self.state = 878
>
> + self.match(CParser.T__88)
>
> + self.state = 879
>
> + self.match(CParser.IDENTIFIER)
>
> + self.state = 880
>
> + self.match(CParser.T__1)
>
> + pass
>
> +
>
> + elif la_ == 2:
>
> + self.enterOuterAlt(localctx, 2)
>
> + self.state = 881
>
> + self.match(CParser.T__89)
>
> + self.state = 882
>
> + self.match(CParser.T__1)
>
> + pass
>
> +
>
> + elif la_ == 3:
>
> + self.enterOuterAlt(localctx, 3)
>
> + self.state = 883
>
> + self.match(CParser.T__90)
>
> + self.state = 884
>
> + self.match(CParser.T__1)
>
> + pass
>
> +
>
> + elif la_ == 4:
>
> + self.enterOuterAlt(localctx, 4)
>
> + self.state = 885
>
> + self.match(CParser.T__91)
>
> + self.state = 886
>
> + self.match(CParser.T__1)
>
> + pass
>
> +
>
> + elif la_ == 5:
>
> + self.enterOuterAlt(localctx, 5)
>
> + self.state = 887
>
> + self.match(CParser.T__91)
>
> + self.state = 888
>
> + self.expression()
>
> + self.state = 889
>
> + self.match(CParser.T__1)
>
> + pass
>
> +
>
> +
>
> + except RecognitionException as re:
>
> + localctx.exception = re
>
> + self._errHandler.reportError(self, re)
>
> + self._errHandler.recover(self, re)
>
> + finally:
>
> + self.exitRule()
>
> + return localctx
>
> +
>
> +
>
> +
>
> +
>
> +
>
> diff --git a/BaseTools/Source/Python/Eot/CParser4/__init__.py b/BaseTools/Source/Python/Eot/CParser4/__init__.py
> new file mode 100644
> index 0000000000..e69de29bb2
> diff --git a/BaseTools/Source/Python/Eot/CodeFragmentCollector.py b/BaseTools/Source/Python/Eot/CodeFragmentCollector.py
> index 8a5e5df17e..b1e77a690a 100644
> --- a/BaseTools/Source/Python/Eot/CodeFragmentCollector.py
> +++ b/BaseTools/Source/Python/Eot/CodeFragmentCollector.py
> @@ -19,17 +19,23 @@ from __future__ import print_function
> from __future__ import absolute_import
>
> import re
>
> import Common.LongFilePathOs as os
>
> import sys
>
>
>
> -import antlr3
>
> -from .CLexer import CLexer
>
> -from .CParser import CParser
>
> +if sys.version_info.major == 3:
>
> + import antlr4 as antlr
>
> + from Eot.CParser4.CLexer import CLexer
>
> + from Eot.CParser4.CParser import CParser
>
> +else:
>
> + import antlr3 as antlr
>
> + antlr.InputStream = antlr.StringStream
>
> + from Eot.CParser3.CLexer import CLexer
>
> + from Eot.CParser3.CParser import CParser
>
>
>
> -from . import FileProfile
>
> -from .CodeFragment import PP_Directive
>
> -from .ParserWarning import Warning
>
> +from Eot import FileProfile
>
> +from Eot.CodeFragment import PP_Directive
>
> +from Eot.ParserWarning import Warning
>
>
>
>
>
> ##define T_CHAR_SPACE ' '
>
> ##define T_CHAR_NULL '\0'
>
> ##define T_CHAR_CR '\r'
>
> @@ -352,13 +358,13 @@ class CodeFragmentCollector:
> # restore from ListOfList to ListOfString
>
> self.Profile.FileLinesList = ["".join(list) for list in self.Profile.FileLinesList]
>
> FileStringContents = ''
>
> for fileLine in self.Profile.FileLinesList:
>
> FileStringContents += fileLine
>
> - cStream = antlr3.StringStream(FileStringContents)
>
> + cStream = antlr.InputStream(FileStringContents)
>
> lexer = CLexer(cStream)
>
> - tStream = antlr3.CommonTokenStream(lexer)
>
> + tStream = antlr.CommonTokenStream(lexer)
>
> parser = CParser(tStream)
>
> parser.translation_unit()
>
>
>
> ## CleanFileProfileBuffer() method
>
> #
>
> --
> 2.20.1.windows.1
next prev parent reply other threads:[~2019-01-28 11:36 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-01-28 10:31 [Patch v2 33/33] BaseTools: Eot tool Python3 adaption Feng, Bob C
2019-01-28 11:36 ` Gao, Liming [this message]
-- strict thread matches above, loose matches on Subject: below --
2019-01-29 2:05 [Patch v2 00/33] BaseTools python3 migration patch set Feng, Bob C
2019-01-29 2:06 ` [Patch v2 33/33] BaseTools: Eot tool Python3 adaption Feng, Bob C
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-list from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4A89E2EF3DFEDB4C8BFDE51014F606A14E3D166B@SHSMSX104.ccr.corp.intel.com \
--to=devel@edk2.groups.io \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox