From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received-SPF: Pass (sender SPF authorized) identity=mailfrom; client-ip=192.55.52.115; helo=mga14.intel.com; envelope-from=liming.gao@intel.com; receiver=edk2-devel@lists.01.org Received: from mga14.intel.com (mga14.intel.com [192.55.52.115]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ml01.01.org (Postfix) with ESMTPS id 2BAB2211AEA71 for ; Mon, 28 Jan 2019 03:36:54 -0800 (PST) X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga008.jf.intel.com ([10.7.209.65]) by fmsmga103.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 28 Jan 2019 03:36:53 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.56,534,1539673200"; d="scan'208";a="113245536" Received: from fmsmsx104.amr.corp.intel.com ([10.18.124.202]) by orsmga008.jf.intel.com with ESMTP; 28 Jan 2019 03:36:52 -0800 Received: from FMSMSX109.amr.corp.intel.com (10.18.116.9) by fmsmsx104.amr.corp.intel.com (10.18.124.202) with Microsoft SMTP Server (TLS) id 14.3.408.0; Mon, 28 Jan 2019 03:36:52 -0800 Received: from shsmsx108.ccr.corp.intel.com (10.239.4.97) by fmsmsx109.amr.corp.intel.com (10.18.116.9) with Microsoft SMTP Server (TLS) id 14.3.408.0; Mon, 28 Jan 2019 03:36:50 -0800 Received: from shsmsx104.ccr.corp.intel.com ([169.254.5.102]) by SHSMSX108.ccr.corp.intel.com ([169.254.8.36]) with mapi id 14.03.0415.000; Mon, 28 Jan 2019 19:36:48 +0800 From: "Gao, Liming" To: "Feng, Bob C" , "edk2-devel@lists.01.org" Thread-Topic: [Patch v2 33/33] BaseTools: Eot tool Python3 adaption Thread-Index: AQHUtvTI9bEv7sDpzU2gK+r+RMpy7aXEjVgw Date: Mon, 28 Jan 2019 11:36:47 +0000 Message-ID: <4A89E2EF3DFEDB4C8BFDE51014F606A14E3D166B@SHSMSX104.ccr.corp.intel.com> References: <20190128103152.18436-1-bob.c.feng@intel.com> In-Reply-To: <20190128103152.18436-1-bob.c.feng@intel.com> Accept-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-ctpclassification: CTP_NT x-titus-metadata-40: eyJDYXRlZ29yeUxhYmVscyI6IiIsIk1ldGFkYXRhIjp7Im5zIjoiaHR0cDpcL1wvd3d3LnRpdHVzLmNvbVwvbnNcL0ludGVsMyIsImlkIjoiMzI5ZmZmZTAtMDhjNS00NTE2LWFmOTMtOTE5NTM1Zjg1ZTY4IiwicHJvcHMiOlt7Im4iOiJDVFBDbGFzc2lmaWNhdGlvbiIsInZhbHMiOlt7InZhbHVlIjoiQ1RQX05UIn1dfV19LCJTdWJqZWN0TGFiZWxzIjpbXSwiVE1DVmVyc2lvbiI6IjE3LjEwLjE4MDQuNDkiLCJUcnVzdGVkTGFiZWxIYXNoIjoiQ2g3cGRzZTNLeCtzU0FYRnhlTHFOejdpdEJ5MENadzM5Tk8zQjI4cTd1WWQ1NVhmZno5UlZUNkRmell1YWZ4dyJ9 dlp-product: dlpe-windows dlp-version: 11.0.400.15 dlp-reaction: no-action x-originating-ip: [10.239.127.40] MIME-Version: 1.0 Subject: Re: [Patch v2 33/33] BaseTools: Eot tool Python3 adaption X-BeenThere: edk2-devel@lists.01.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: EDK II Development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 28 Jan 2019 11:36:55 -0000 Content-Language: en-US Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: quoted-printable 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 ; Gao, Liming > Subject: [Patch v2 33/33] BaseTools: Eot tool Python3 adaption >=20 > Eot tool Python3 adaption. >=20 > Contributed-under: TianoCore Contribution Agreement 1.1 > Signed-off-by: Bob Feng > Cc: Liming Gao > --- > BaseTools/Source/Python/Eot/{ =3D> CParser3}/CLexer.py | 0 > BaseTools/Source/Python/Eot/{ =3D> 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(-) >=20 > diff --git a/BaseTools/Source/Python/Eot/CLexer.py b/BaseTools/Source/Pyt= hon/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/Py= thon/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/S= ource/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 >=20 > +from antlr4 import * >=20 > +from io import StringIO >=20 > +from typing.io import TextIO >=20 > +import sys >=20 > + >=20 > + >=20 > +## @file >=20 > +# The file defines the parser for C source files. >=20 > +# >=20 > +# THIS FILE IS AUTO-GENENERATED. PLEASE DON NOT MODIFY THIS FILE. >=20 > +# This file is generated by running: >=20 > +# java org.antlr.Tool C.g >=20 > +# >=20 > +# Copyright (c) 2009 - 2010, Intel Corporation All rights reserved. >=20 > +# >=20 > +# This program and the accompanying materials are licensed and made avai= lable >=20 > +# under the terms and conditions of the BSD License which accompanies th= is >=20 > +# distribution. The full text of the license may be found at: >=20 > +# http://opensource.org/licenses/bsd-license.php >=20 > +# >=20 > +# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, >=20 > +# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR I= MPLIED. >=20 > +# >=20 > +## >=20 > + >=20 > +import Ecc.CodeFragment as CodeFragment >=20 > +import Ecc.FileProfile as FileProfile >=20 > + >=20 > + >=20 > +def serializedATN(): >=20 > + with StringIO() as buf: >=20 > + buf.write("\3\u608b\ua72a\u8133\ub9ed\u417c\u3be7\u7786\u5964\2k= ") >=20 > + 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") >=20 > + 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") >=20 > + buf.write("\4\16\t\16\4\17\t\17\4\20\t\20\4\21\t\21\4\22\t\22\4\= 23") >=20 > + buf.write("\t\23\4\24\t\24\4\25\t\25\4\26\t\26\4\27\t\27\4\30\t\= 30") >=20 > + buf.write("\4\31\t\31\4\32\t\32\4\33\t\33\4\34\t\34\4\35\t\35\4\= 36") >=20 > + buf.write("\t\36\4\37\t\37\4 \t \4!\t!\4\"\t\"\4#\t#\4$\t$\4%\t%= ") >=20 > + buf.write("\4&\t&\4\'\t\'\4(\t(\4)\t)\4*\t*\4+\t+\4,\t,\4-\t-\4.= ") >=20 > + buf.write("\t.\4/\t/\4\60\t\60\4\61\t\61\4\62\t\62\4\63\t\63\4\6= 4") >=20 > + buf.write("\t\64\4\65\t\65\4\66\t\66\4\67\t\67\48\t8\49\t9\4:\t:= ") >=20 > + buf.write("\4;\t;\4<\t<\4=3D\t=3D\4>\t>\4?\t?\4@\t@\4A\tA\4B\tB\= 4C\t") >=20 > + buf.write("C\4D\tD\4E\tE\4F\tF\4G\tG\4H\tH\4I\tI\4J\tJ\4K\tK\4L\= t") >=20 > + buf.write("L\4M\tM\4N\tN\4O\tO\4P\tP\4Q\tQ\4R\tR\4S\tS\4T\tT\4U\= t") >=20 > + buf.write("U\4V\tV\4W\tW\4X\tX\4Y\tY\4Z\tZ\4[\t[\4\\\t\\\4]\t]\4= ") >=20 > + buf.write("^\t^\4_\t_\4`\t`\4a\ta\4b\tb\4c\tc\4d\td\4e\te\4f\tf\= 4") >=20 > + buf.write("g\tg\4h\th\4i\ti\4j\tj\4k\tk\4l\tl\4m\tm\4n\tn\4o\to\= 4") >=20 > + 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") >=20 > + 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") >=20 > + 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") >=20 > + 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") >=20 > + 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") >=20 > + buf.write("\3\16\3\16\3\16\3\16\3\16\3\17\3\17\3\17\3\17\3\20\3\= 20") >=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") >=20 > + buf.write("\3\22\3\22\3\22\3\22\3\22\3\23\3\23\3\23\3\23\3\23\3\= 23") >=20 > + buf.write("\3\23\3\24\3\24\3\24\3\24\3\24\3\24\3\24\3\24\3\24\3\= 25") >=20 > + buf.write("\3\25\3\26\3\26\3\26\3\26\3\26\3\26\3\26\3\27\3\27\3\= 27") >=20 > + buf.write("\3\27\3\27\3\27\3\30\3\30\3\31\3\31\3\31\3\31\3\31\3\= 32") >=20 > + buf.write("\3\32\3\32\3\32\3\32\3\32\3\33\3\33\3\33\3\33\3\33\3\= 33") >=20 > + buf.write("\3\33\3\33\3\33\3\34\3\34\3\34\3\35\3\35\3\35\3\35\3\= 36") >=20 > + buf.write("\3\36\3\36\3\36\3\36\3\36\3\36\3\36\3\36\3\37\3\37\3\= 37") >=20 > + buf.write("\3\37\3\37\3\37\3 \3 \3 \3 \3 \3 \3 \3 \3 \3 \3!\3!\3= ") >=20 > + buf.write("!\3!\3!\3!\3!\3!\3!\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3= ") >=20 > + buf.write("\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\= "") >=20 > + buf.write("\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3#\3#\3#\3#\3#\3#\3#= ") >=20 > + buf.write("\3$\3$\3$\3$\3$\3$\3$\3$\3$\3$\3$\3$\3$\3$\3$\3$\3%\3= ") >=20 > + buf.write("%\3%\3%\3%\3%\3%\3%\3%\3%\3%\3%\3%\3%\3%\3%\3%\3%\3%\= 3") >=20 > + buf.write("&\3&\3&\3&\3&\3&\3&\3\'\3\'\3(\3(\3)\3)\3*\3*\3+\3+\3= ") >=20 > + buf.write(",\3,\3,\3,\3-\3-\3.\3.\3/\3/\3\60\3\60\3\61\3\61\3\61= ") >=20 > + buf.write("\3\62\3\62\3\62\3\63\3\63\3\63\3\63\3\63\3\63\3\63\3\= 64") >=20 > + buf.write("\3\64\3\65\3\65\3\65\3\66\3\66\3\67\3\67\38\38\39\39\= 3") >=20 > + buf.write("9\3:\3:\3:\3;\3;\3;\3<\3<\3<\3=3D\3=3D\3=3D\3>\3>\3>\= 3>\3?\3") >=20 > + buf.write("?\3?\3?\3@\3@\3@\3A\3A\3A\3B\3B\3B\3C\3C\3D\3D\3D\3E\= 3") >=20 > + buf.write("E\3E\3F\3F\3G\3G\3H\3H\3H\3I\3I\3I\3J\3J\3K\3K\3L\3L\= 3") >=20 > + buf.write("L\3M\3M\3M\3N\3N\3N\3O\3O\3O\3P\3P\3P\3P\3P\3P\3P\3P\= 3") >=20 > + buf.write("Q\3Q\3Q\3Q\3Q\3R\3R\3R\3R\3R\3R\3S\3S\3S\3S\3S\3T\3T\= 3") >=20 > + buf.write("T\3T\3T\3T\3T\3T\3U\3U\3U\3V\3V\3V\3V\3V\3W\3W\3W\3W\= 3") >=20 > + buf.write("W\3W\3W\3X\3X\3X\3X\3X\3X\3Y\3Y\3Y\3Z\3Z\3Z\3Z\3Z\3[\= 3") >=20 > + buf.write("[\3[\3[\3[\3[\3[\3[\3[\3\\\3\\\3\\\3\\\3\\\3\\\3]\3]\= 3") >=20 > + buf.write("]\3]\3]\3]\3]\3^\3^\3^\7^\u02b2\n^\f^\16^\u02b5\13^\3= ") >=20 > + buf.write("_\3_\3`\5`\u02ba\n`\3`\3`\3`\5`\u02bf\n`\3`\3`\3a\5a\= u02c4") >=20 > + buf.write("\na\3a\3a\3a\7a\u02c9\na\fa\16a\u02cc\13a\3a\3a\3b\3b= ") >=20 > + buf.write("\3b\6b\u02d3\nb\rb\16b\u02d4\3b\5b\u02d8\nb\3c\3c\3c\= 7") >=20 > + buf.write("c\u02dd\nc\fc\16c\u02e0\13c\5c\u02e2\nc\3c\5c\u02e5\n= ") >=20 > + buf.write("c\3d\3d\6d\u02e9\nd\rd\16d\u02ea\3d\5d\u02ee\nd\3e\3e= ") >=20 > + buf.write("\3f\3f\3f\3f\3f\3f\5f\u02f8\nf\3g\6g\u02fb\ng\rg\16g\= u02fc") >=20 > + buf.write("\3g\3g\7g\u0301\ng\fg\16g\u0304\13g\3g\5g\u0307\ng\3g= ") >=20 > + buf.write("\5g\u030a\ng\3g\3g\6g\u030e\ng\rg\16g\u030f\3g\5g\u03= 13") >=20 > + buf.write("\ng\3g\5g\u0316\ng\3g\6g\u0319\ng\rg\16g\u031a\3g\3g\= 5") >=20 > + buf.write("g\u031f\ng\3g\6g\u0322\ng\rg\16g\u0323\3g\5g\u0327\ng= ") >=20 > + buf.write("\3g\5g\u032a\ng\3h\3h\5h\u032e\nh\3h\6h\u0331\nh\rh\1= 6") >=20 > + buf.write("h\u0332\3i\3i\3j\3j\3j\5j\u033a\nj\3k\3k\3k\3k\3k\3k\= 3") >=20 > + buf.write("k\3k\3k\5k\u0345\nk\3l\3l\3l\3l\3l\3l\3l\3m\3m\3m\3m\= 3") >=20 > + buf.write("n\3n\3n\3n\3o\3o\3p\3p\3p\3p\7p\u035c\np\fp\16p\u035f= ") >=20 > + buf.write("\13p\3p\3p\3p\3p\3p\3q\3q\3q\3q\7q\u036a\nq\fq\16q\u0= 36d") >=20 > + buf.write("\13q\3q\5q\u0370\nq\3q\3q\3q\3q\3r\3r\7r\u0378\nr\fr\= 16") >=20 > + buf.write("r\u037b\13r\3r\5r\u037e\nr\3r\3r\3r\3r\3\u035d\2s\3\3= ") >=20 > + buf.write("\5\4\7\5\t\6\13\7\r\b\17\t\21\n\23\13\25\f\27\r\31\16= ") >=20 > + buf.write("\33\17\35\20\37\21!\22#\23%\24\'\25)\26+\27-\30/\31\6= 1") >=20 > + buf.write("\32\63\33\65\34\67\359\36;\37=3D ?!A\"C#E$G%I&K\'M(O)= Q*") >=20 > + buf.write("S+U,W-Y.[/]\60_\61a\62c\63e\64g\65i\66k\67m8o9q:s;u=20 > + buf.write("=3Dy>{?}@\177A\u0081B\u0083C\u0085D\u0087E\u0089F\u00= 8b") >=20 > + buf.write("G\u008dH\u008fI\u0091J\u0093K\u0095L\u0097M\u0099N\u0= 09b") >=20 > + buf.write("O\u009dP\u009fQ\u00a1R\u00a3S\u00a5T\u00a7U\u00a9V\u0= 0ab") >=20 > + buf.write("W\u00adX\u00afY\u00b1Z\u00b3[\u00b5\\\u00b7]\u00b9^\u= 00bb") >=20 > + buf.write("_\u00bd\2\u00bf`\u00c1a\u00c3b\u00c5c\u00c7d\u00c9\2\= u00cb") >=20 > + buf.write("\2\u00cde\u00cf\2\u00d1\2\u00d3\2\u00d5\2\u00d7\2\u00= d9") >=20 > + buf.write("f\u00dbg\u00ddh\u00dfi\u00e1j\u00e3k\3\2\20\6\2&&C\\a= ") >=20 > + buf.write("ac|\4\2))^^\4\2$$^^\4\2ZZzz\5\2\62;CHch\6\2NNWWnnww\4= ") >=20 > + buf.write("\2WWww\4\2NNnn\4\2GGgg\4\2--//\6\2FFHHffhh\t\2))^^ddh= ") >=20 > + buf.write("hppttvv\5\2\13\f\16\17\"\"\4\2\f\f\17\17\2\u03a2\2\3\= 3") >=20 > + 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= ") >=20 > + 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= ") >=20 > + 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") >=20 > + 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= ") >=20 > + 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") >=20 > + 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") >=20 > + buf.write("\2\2\29\3\2\2\2\2;\3\2\2\2\2=3D\3\2\2\2\2?\3\2\2\2\2A= \3") >=20 > + 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= ") >=20 > + 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") >=20 > + 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= ") >=20 > + 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= ") >=20 > + 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= ") >=20 > + 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= ") >=20 > + buf.write("\2\2\2\2}\3\2\2\2\2\177\3\2\2\2\2\u0081\3\2\2\2\2\u00= 83") >=20 > + buf.write("\3\2\2\2\2\u0085\3\2\2\2\2\u0087\3\2\2\2\2\u0089\3\2\= 2") >=20 > + buf.write("\2\2\u008b\3\2\2\2\2\u008d\3\2\2\2\2\u008f\3\2\2\2\2\= u0091") >=20 > + buf.write("\3\2\2\2\2\u0093\3\2\2\2\2\u0095\3\2\2\2\2\u0097\3\2\= 2") >=20 > + buf.write("\2\2\u0099\3\2\2\2\2\u009b\3\2\2\2\2\u009d\3\2\2\2\2\= u009f") >=20 > + buf.write("\3\2\2\2\2\u00a1\3\2\2\2\2\u00a3\3\2\2\2\2\u00a5\3\2\= 2") >=20 > + buf.write("\2\2\u00a7\3\2\2\2\2\u00a9\3\2\2\2\2\u00ab\3\2\2\2\2\= u00ad") >=20 > + buf.write("\3\2\2\2\2\u00af\3\2\2\2\2\u00b1\3\2\2\2\2\u00b3\3\2\= 2") >=20 > + buf.write("\2\2\u00b5\3\2\2\2\2\u00b7\3\2\2\2\2\u00b9\3\2\2\2\2\= u00bb") >=20 > + buf.write("\3\2\2\2\2\u00bf\3\2\2\2\2\u00c1\3\2\2\2\2\u00c3\3\2\= 2") >=20 > + buf.write("\2\2\u00c5\3\2\2\2\2\u00c7\3\2\2\2\2\u00cd\3\2\2\2\2\= u00d9") >=20 > + buf.write("\3\2\2\2\2\u00db\3\2\2\2\2\u00dd\3\2\2\2\2\u00df\3\2\= 2") >=20 > + buf.write("\2\2\u00e1\3\2\2\2\2\u00e3\3\2\2\2\3\u00e5\3\2\2\2\5\= u00e7") >=20 > + buf.write("\3\2\2\2\7\u00e9\3\2\2\2\t\u00f1\3\2\2\2\13\u00f3\3\2= ") >=20 > + buf.write("\2\2\r\u00f5\3\2\2\2\17\u00fc\3\2\2\2\21\u0103\3\2\2\= 2") >=20 > + buf.write("\23\u0108\3\2\2\2\25\u0111\3\2\2\2\27\u0118\3\2\2\2\3= 1") >=20 > + buf.write("\u011d\3\2\2\2\33\u0122\3\2\2\2\35\u0128\3\2\2\2\37\u= 012c") >=20 > + buf.write("\3\2\2\2!\u0131\3\2\2\2#\u0137\3\2\2\2%\u013e\3\2\2\2= ") >=20 > + buf.write("\'\u0145\3\2\2\2)\u014e\3\2\2\2+\u0150\3\2\2\2-\u0157= ") >=20 > + buf.write("\3\2\2\2/\u015d\3\2\2\2\61\u015f\3\2\2\2\63\u0164\3\2= ") >=20 > + buf.write("\2\2\65\u016a\3\2\2\2\67\u0173\3\2\2\29\u0176\3\2\2\2= ") >=20 > + buf.write(";\u017a\3\2\2\2=3D\u0183\3\2\2\2?\u0189\3\2\2\2A\u019= 3\3") >=20 > + buf.write("\2\2\2C\u019c\3\2\2\2E\u01ba\3\2\2\2G\u01c1\3\2\2\2I\= u01d1") >=20 > + buf.write("\3\2\2\2K\u01e4\3\2\2\2M\u01eb\3\2\2\2O\u01ed\3\2\2\2= ") >=20 > + buf.write("Q\u01ef\3\2\2\2S\u01f1\3\2\2\2U\u01f3\3\2\2\2W\u01f5\= 3") >=20 > + buf.write("\2\2\2Y\u01f9\3\2\2\2[\u01fb\3\2\2\2]\u01fd\3\2\2\2_\= u01ff") >=20 > + buf.write("\3\2\2\2a\u0201\3\2\2\2c\u0204\3\2\2\2e\u0207\3\2\2\2= ") >=20 > + buf.write("g\u020e\3\2\2\2i\u0210\3\2\2\2k\u0213\3\2\2\2m\u0215\= 3") >=20 > + buf.write("\2\2\2o\u0217\3\2\2\2q\u0219\3\2\2\2s\u021c\3\2\2\2u\= u021f") >=20 > + buf.write("\3\2\2\2w\u0222\3\2\2\2y\u0225\3\2\2\2{\u0228\3\2\2\2= ") >=20 > + buf.write("}\u022c\3\2\2\2\177\u0230\3\2\2\2\u0081\u0233\3\2\2\2= ") >=20 > + buf.write("\u0083\u0236\3\2\2\2\u0085\u0239\3\2\2\2\u0087\u023b\= 3") >=20 > + buf.write("\2\2\2\u0089\u023e\3\2\2\2\u008b\u0241\3\2\2\2\u008d\= u0243") >=20 > + buf.write("\3\2\2\2\u008f\u0245\3\2\2\2\u0091\u0248\3\2\2\2\u009= 3") >=20 > + buf.write("\u024b\3\2\2\2\u0095\u024d\3\2\2\2\u0097\u024f\3\2\2\= 2") >=20 > + buf.write("\u0099\u0252\3\2\2\2\u009b\u0255\3\2\2\2\u009d\u0258\= 3") >=20 > + buf.write("\2\2\2\u009f\u025b\3\2\2\2\u00a1\u0263\3\2\2\2\u00a3\= u0268") >=20 > + buf.write("\3\2\2\2\u00a5\u026e\3\2\2\2\u00a7\u0273\3\2\2\2\u00a= 9") >=20 > + buf.write("\u027b\3\2\2\2\u00ab\u027e\3\2\2\2\u00ad\u0283\3\2\2\= 2") >=20 > + buf.write("\u00af\u028a\3\2\2\2\u00b1\u0290\3\2\2\2\u00b3\u0293\= 3") >=20 > + buf.write("\2\2\2\u00b5\u0298\3\2\2\2\u00b7\u02a1\3\2\2\2\u00b9\= u02a7") >=20 > + buf.write("\3\2\2\2\u00bb\u02ae\3\2\2\2\u00bd\u02b6\3\2\2\2\u00b= f") >=20 > + buf.write("\u02b9\3\2\2\2\u00c1\u02c3\3\2\2\2\u00c3\u02cf\3\2\2\= 2") >=20 > + buf.write("\u00c5\u02e1\3\2\2\2\u00c7\u02e6\3\2\2\2\u00c9\u02ef\= 3") >=20 > + buf.write("\2\2\2\u00cb\u02f7\3\2\2\2\u00cd\u0329\3\2\2\2\u00cf\= u032b") >=20 > + buf.write("\3\2\2\2\u00d1\u0334\3\2\2\2\u00d3\u0339\3\2\2\2\u00d= 5") >=20 > + buf.write("\u0344\3\2\2\2\u00d7\u0346\3\2\2\2\u00d9\u034d\3\2\2\= 2") >=20 > + buf.write("\u00db\u0351\3\2\2\2\u00dd\u0355\3\2\2\2\u00df\u0357\= 3") >=20 > + buf.write("\2\2\2\u00e1\u0365\3\2\2\2\u00e3\u0375\3\2\2\2\u00e5\= u00e6") >=20 > + buf.write("\7}\2\2\u00e6\4\3\2\2\2\u00e7\u00e8\7=3D\2\2\u00e8\6\= 3\2") >=20 > + buf.write("\2\2\u00e9\u00ea\7v\2\2\u00ea\u00eb\7{\2\2\u00eb\u00e= c") >=20 > + buf.write("\7r\2\2\u00ec\u00ed\7g\2\2\u00ed\u00ee\7f\2\2\u00ee\u= 00ef") >=20 > + buf.write("\7g\2\2\u00ef\u00f0\7h\2\2\u00f0\b\3\2\2\2\u00f1\u00f= 2") >=20 > + buf.write("\7.\2\2\u00f2\n\3\2\2\2\u00f3\u00f4\7?\2\2\u00f4\f\3\= 2") >=20 > + buf.write("\2\2\u00f5\u00f6\7g\2\2\u00f6\u00f7\7z\2\2\u00f7\u00f= 8") >=20 > + buf.write("\7v\2\2\u00f8\u00f9\7g\2\2\u00f9\u00fa\7t\2\2\u00fa\u= 00fb") >=20 > + buf.write("\7p\2\2\u00fb\16\3\2\2\2\u00fc\u00fd\7u\2\2\u00fd\u00= fe") >=20 > + buf.write("\7v\2\2\u00fe\u00ff\7c\2\2\u00ff\u0100\7v\2\2\u0100\u= 0101") >=20 > + buf.write("\7k\2\2\u0101\u0102\7e\2\2\u0102\20\3\2\2\2\u0103\u01= 04") >=20 > + buf.write("\7c\2\2\u0104\u0105\7w\2\2\u0105\u0106\7v\2\2\u0106\u= 0107") >=20 > + buf.write("\7q\2\2\u0107\22\3\2\2\2\u0108\u0109\7t\2\2\u0109\u01= 0a") >=20 > + buf.write("\7g\2\2\u010a\u010b\7i\2\2\u010b\u010c\7k\2\2\u010c\u= 010d") >=20 > + buf.write("\7u\2\2\u010d\u010e\7v\2\2\u010e\u010f\7g\2\2\u010f\u= 0110") >=20 > + buf.write("\7t\2\2\u0110\24\3\2\2\2\u0111\u0112\7U\2\2\u0112\u01= 13") >=20 > + buf.write("\7V\2\2\u0113\u0114\7C\2\2\u0114\u0115\7V\2\2\u0115\u= 0116") >=20 > + buf.write("\7K\2\2\u0116\u0117\7E\2\2\u0117\26\3\2\2\2\u0118\u01= 19") >=20 > + buf.write("\7x\2\2\u0119\u011a\7q\2\2\u011a\u011b\7k\2\2\u011b\u= 011c") >=20 > + buf.write("\7f\2\2\u011c\30\3\2\2\2\u011d\u011e\7e\2\2\u011e\u01= 1f") >=20 > + buf.write("\7j\2\2\u011f\u0120\7c\2\2\u0120\u0121\7t\2\2\u0121\3= 2") >=20 > + buf.write("\3\2\2\2\u0122\u0123\7u\2\2\u0123\u0124\7j\2\2\u0124\= u0125") >=20 > + buf.write("\7q\2\2\u0125\u0126\7t\2\2\u0126\u0127\7v\2\2\u0127\3= 4") >=20 > + buf.write("\3\2\2\2\u0128\u0129\7k\2\2\u0129\u012a\7p\2\2\u012a\= u012b") >=20 > + buf.write("\7v\2\2\u012b\36\3\2\2\2\u012c\u012d\7n\2\2\u012d\u01= 2e") >=20 > + buf.write("\7q\2\2\u012e\u012f\7p\2\2\u012f\u0130\7i\2\2\u0130 \= 3") >=20 > + buf.write("\2\2\2\u0131\u0132\7h\2\2\u0132\u0133\7n\2\2\u0133\u0= 134") >=20 > + buf.write("\7q\2\2\u0134\u0135\7c\2\2\u0135\u0136\7v\2\2\u0136\"= ") >=20 > + buf.write("\3\2\2\2\u0137\u0138\7f\2\2\u0138\u0139\7q\2\2\u0139\= u013a") >=20 > + buf.write("\7w\2\2\u013a\u013b\7d\2\2\u013b\u013c\7n\2\2\u013c\u= 013d") >=20 > + buf.write("\7g\2\2\u013d$\3\2\2\2\u013e\u013f\7u\2\2\u013f\u0140= ") >=20 > + buf.write("\7k\2\2\u0140\u0141\7i\2\2\u0141\u0142\7p\2\2\u0142\u= 0143") >=20 > + buf.write("\7g\2\2\u0143\u0144\7f\2\2\u0144&\3\2\2\2\u0145\u0146= ") >=20 > + buf.write("\7w\2\2\u0146\u0147\7p\2\2\u0147\u0148\7u\2\2\u0148\u= 0149") >=20 > + buf.write("\7k\2\2\u0149\u014a\7i\2\2\u014a\u014b\7p\2\2\u014b\u= 014c") >=20 > + buf.write("\7g\2\2\u014c\u014d\7f\2\2\u014d(\3\2\2\2\u014e\u014f= ") >=20 > + buf.write("\7\177\2\2\u014f*\3\2\2\2\u0150\u0151\7u\2\2\u0151\u0= 152") >=20 > + buf.write("\7v\2\2\u0152\u0153\7t\2\2\u0153\u0154\7w\2\2\u0154\u= 0155") >=20 > + buf.write("\7e\2\2\u0155\u0156\7v\2\2\u0156,\3\2\2\2\u0157\u0158= ") >=20 > + buf.write("\7w\2\2\u0158\u0159\7p\2\2\u0159\u015a\7k\2\2\u015a\u= 015b") >=20 > + buf.write("\7q\2\2\u015b\u015c\7p\2\2\u015c.\3\2\2\2\u015d\u015e= ") >=20 > + buf.write("\7<\2\2\u015e\60\3\2\2\2\u015f\u0160\7g\2\2\u0160\u01= 61") >=20 > + buf.write("\7p\2\2\u0161\u0162\7w\2\2\u0162\u0163\7o\2\2\u0163\6= 2") >=20 > + buf.write("\3\2\2\2\u0164\u0165\7e\2\2\u0165\u0166\7q\2\2\u0166\= u0167") >=20 > + buf.write("\7p\2\2\u0167\u0168\7u\2\2\u0168\u0169\7v\2\2\u0169\6= 4") >=20 > + buf.write("\3\2\2\2\u016a\u016b\7x\2\2\u016b\u016c\7q\2\2\u016c\= u016d") >=20 > + buf.write("\7n\2\2\u016d\u016e\7c\2\2\u016e\u016f\7v\2\2\u016f\u= 0170") >=20 > + buf.write("\7k\2\2\u0170\u0171\7n\2\2\u0171\u0172\7g\2\2\u0172\6= 6") >=20 > + buf.write("\3\2\2\2\u0173\u0174\7K\2\2\u0174\u0175\7P\2\2\u01758= ") >=20 > + buf.write("\3\2\2\2\u0176\u0177\7Q\2\2\u0177\u0178\7W\2\2\u0178\= u0179") >=20 > + buf.write("\7V\2\2\u0179:\3\2\2\2\u017a\u017b\7Q\2\2\u017b\u017c= ") >=20 > + buf.write("\7R\2\2\u017c\u017d\7V\2\2\u017d\u017e\7K\2\2\u017e\u= 017f") >=20 > + buf.write("\7Q\2\2\u017f\u0180\7P\2\2\u0180\u0181\7C\2\2\u0181\u= 0182") >=20 > + buf.write("\7N\2\2\u0182<\3\2\2\2\u0183\u0184\7E\2\2\u0184\u0185= ") >=20 > + buf.write("\7Q\2\2\u0185\u0186\7P\2\2\u0186\u0187\7U\2\2\u0187\u= 0188") >=20 > + buf.write("\7V\2\2\u0188>\3\2\2\2\u0189\u018a\7W\2\2\u018a\u018b= ") >=20 > + buf.write("\7P\2\2\u018b\u018c\7C\2\2\u018c\u018d\7N\2\2\u018d\u= 018e") >=20 > + buf.write("\7K\2\2\u018e\u018f\7I\2\2\u018f\u0190\7P\2\2\u0190\u= 0191") >=20 > + buf.write("\7G\2\2\u0191\u0192\7F\2\2\u0192@\3\2\2\2\u0193\u0194= ") >=20 > + buf.write("\7X\2\2\u0194\u0195\7Q\2\2\u0195\u0196\7N\2\2\u0196\u= 0197") >=20 > + buf.write("\7C\2\2\u0197\u0198\7V\2\2\u0198\u0199\7K\2\2\u0199\u= 019a") >=20 > + buf.write("\7N\2\2\u019a\u019b\7G\2\2\u019bB\3\2\2\2\u019c\u019d= ") >=20 > + buf.write("\7I\2\2\u019d\u019e\7N\2\2\u019e\u019f\7Q\2\2\u019f\u= 01a0") >=20 > + buf.write("\7D\2\2\u01a0\u01a1\7C\2\2\u01a1\u01a2\7N\2\2\u01a2\u= 01a3") >=20 > + buf.write("\7a\2\2\u01a3\u01a4\7T\2\2\u01a4\u01a5\7G\2\2\u01a5\u= 01a6") >=20 > + buf.write("\7O\2\2\u01a6\u01a7\7Q\2\2\u01a7\u01a8\7X\2\2\u01a8\u= 01a9") >=20 > + buf.write("\7G\2\2\u01a9\u01aa\7a\2\2\u01aa\u01ab\7K\2\2\u01ab\u= 01ac") >=20 > + buf.write("\7H\2\2\u01ac\u01ad\7a\2\2\u01ad\u01ae\7W\2\2\u01ae\u= 01af") >=20 > + buf.write("\7P\2\2\u01af\u01b0\7T\2\2\u01b0\u01b1\7G\2\2\u01b1\u= 01b2") >=20 > + buf.write("\7H\2\2\u01b2\u01b3\7G\2\2\u01b3\u01b4\7T\2\2\u01b4\u= 01b5") >=20 > + buf.write("\7G\2\2\u01b5\u01b6\7P\2\2\u01b6\u01b7\7E\2\2\u01b7\u= 01b8") >=20 > + buf.write("\7G\2\2\u01b8\u01b9\7F\2\2\u01b9D\3\2\2\2\u01ba\u01bb= ") >=20 > + buf.write("\7G\2\2\u01bb\u01bc\7H\2\2\u01bc\u01bd\7K\2\2\u01bd\u= 01be") >=20 > + buf.write("\7C\2\2\u01be\u01bf\7R\2\2\u01bf\u01c0\7K\2\2\u01c0F\= 3") >=20 > + buf.write("\2\2\2\u01c1\u01c2\7G\2\2\u01c2\u01c3\7H\2\2\u01c3\u0= 1c4") >=20 > + buf.write("\7K\2\2\u01c4\u01c5\7a\2\2\u01c5\u01c6\7D\2\2\u01c6\u= 01c7") >=20 > + buf.write("\7Q\2\2\u01c7\u01c8\7Q\2\2\u01c8\u01c9\7V\2\2\u01c9\u= 01ca") >=20 > + buf.write("\7U\2\2\u01ca\u01cb\7G\2\2\u01cb\u01cc\7T\2\2\u01cc\u= 01cd") >=20 > + buf.write("\7X\2\2\u01cd\u01ce\7K\2\2\u01ce\u01cf\7E\2\2\u01cf\u= 01d0") >=20 > + buf.write("\7G\2\2\u01d0H\3\2\2\2\u01d1\u01d2\7G\2\2\u01d2\u01d3= ") >=20 > + buf.write("\7H\2\2\u01d3\u01d4\7K\2\2\u01d4\u01d5\7a\2\2\u01d5\u= 01d6") >=20 > + buf.write("\7T\2\2\u01d6\u01d7\7W\2\2\u01d7\u01d8\7P\2\2\u01d8\u= 01d9") >=20 > + buf.write("\7V\2\2\u01d9\u01da\7K\2\2\u01da\u01db\7O\2\2\u01db\u= 01dc") >=20 > + buf.write("\7G\2\2\u01dc\u01dd\7U\2\2\u01dd\u01de\7G\2\2\u01de\u= 01df") >=20 > + buf.write("\7T\2\2\u01df\u01e0\7X\2\2\u01e0\u01e1\7K\2\2\u01e1\u= 01e2") >=20 > + buf.write("\7E\2\2\u01e2\u01e3\7G\2\2\u01e3J\3\2\2\2\u01e4\u01e5= ") >=20 > + buf.write("\7R\2\2\u01e5\u01e6\7C\2\2\u01e6\u01e7\7E\2\2\u01e7\u= 01e8") >=20 > + buf.write("\7M\2\2\u01e8\u01e9\7G\2\2\u01e9\u01ea\7F\2\2\u01eaL\= 3") >=20 > + buf.write("\2\2\2\u01eb\u01ec\7*\2\2\u01ecN\3\2\2\2\u01ed\u01ee\= 7") >=20 > + buf.write("+\2\2\u01eeP\3\2\2\2\u01ef\u01f0\7]\2\2\u01f0R\3\2\2\= 2") >=20 > + buf.write("\u01f1\u01f2\7_\2\2\u01f2T\3\2\2\2\u01f3\u01f4\7,\2\2= ") >=20 > + buf.write("\u01f4V\3\2\2\2\u01f5\u01f6\7\60\2\2\u01f6\u01f7\7\60= ") >=20 > + buf.write("\2\2\u01f7\u01f8\7\60\2\2\u01f8X\3\2\2\2\u01f9\u01fa\= 7") >=20 > + buf.write("-\2\2\u01faZ\3\2\2\2\u01fb\u01fc\7/\2\2\u01fc\\\3\2\2= ") >=20 > + buf.write("\2\u01fd\u01fe\7\61\2\2\u01fe^\3\2\2\2\u01ff\u0200\7\= '") >=20 > + buf.write("\2\2\u0200`\3\2\2\2\u0201\u0202\7-\2\2\u0202\u0203\7-= ") >=20 > + buf.write("\2\2\u0203b\3\2\2\2\u0204\u0205\7/\2\2\u0205\u0206\7/= ") >=20 > + buf.write("\2\2\u0206d\3\2\2\2\u0207\u0208\7u\2\2\u0208\u0209\7k= ") >=20 > + buf.write("\2\2\u0209\u020a\7|\2\2\u020a\u020b\7g\2\2\u020b\u020= c") >=20 > + buf.write("\7q\2\2\u020c\u020d\7h\2\2\u020df\3\2\2\2\u020e\u020f= ") >=20 > + buf.write("\7\60\2\2\u020fh\3\2\2\2\u0210\u0211\7/\2\2\u0211\u02= 12") >=20 > + buf.write("\7@\2\2\u0212j\3\2\2\2\u0213\u0214\7(\2\2\u0214l\3\2\= 2") >=20 > + buf.write("\2\u0215\u0216\7\u0080\2\2\u0216n\3\2\2\2\u0217\u0218= ") >=20 > + buf.write("\7#\2\2\u0218p\3\2\2\2\u0219\u021a\7,\2\2\u021a\u021b= ") >=20 > + buf.write("\7?\2\2\u021br\3\2\2\2\u021c\u021d\7\61\2\2\u021d\u02= 1e") >=20 > + buf.write("\7?\2\2\u021et\3\2\2\2\u021f\u0220\7\'\2\2\u0220\u022= 1") >=20 > + buf.write("\7?\2\2\u0221v\3\2\2\2\u0222\u0223\7-\2\2\u0223\u0224= ") >=20 > + buf.write("\7?\2\2\u0224x\3\2\2\2\u0225\u0226\7/\2\2\u0226\u0227= ") >=20 > + buf.write("\7?\2\2\u0227z\3\2\2\2\u0228\u0229\7>\2\2\u0229\u022a= ") >=20 > + buf.write("\7>\2\2\u022a\u022b\7?\2\2\u022b|\3\2\2\2\u022c\u022d= ") >=20 > + buf.write("\7@\2\2\u022d\u022e\7@\2\2\u022e\u022f\7?\2\2\u022f~\= 3") >=20 > + buf.write("\2\2\2\u0230\u0231\7(\2\2\u0231\u0232\7?\2\2\u0232\u0= 080") >=20 > + buf.write("\3\2\2\2\u0233\u0234\7`\2\2\u0234\u0235\7?\2\2\u0235\= u0082") >=20 > + buf.write("\3\2\2\2\u0236\u0237\7~\2\2\u0237\u0238\7?\2\2\u0238\= u0084") >=20 > + buf.write("\3\2\2\2\u0239\u023a\7A\2\2\u023a\u0086\3\2\2\2\u023b= ") >=20 > + buf.write("\u023c\7~\2\2\u023c\u023d\7~\2\2\u023d\u0088\3\2\2\2\= u023e") >=20 > + buf.write("\u023f\7(\2\2\u023f\u0240\7(\2\2\u0240\u008a\3\2\2\2\= u0241") >=20 > + buf.write("\u0242\7~\2\2\u0242\u008c\3\2\2\2\u0243\u0244\7`\2\2\= u0244") >=20 > + buf.write("\u008e\3\2\2\2\u0245\u0246\7?\2\2\u0246\u0247\7?\2\2\= u0247") >=20 > + buf.write("\u0090\3\2\2\2\u0248\u0249\7#\2\2\u0249\u024a\7?\2\2\= u024a") >=20 > + buf.write("\u0092\3\2\2\2\u024b\u024c\7>\2\2\u024c\u0094\3\2\2\2= ") >=20 > + buf.write("\u024d\u024e\7@\2\2\u024e\u0096\3\2\2\2\u024f\u0250\7= ") >=20 > + buf.write(">\2\2\u0250\u0251\7?\2\2\u0251\u0098\3\2\2\2\u0252\u0= 253") >=20 > + buf.write("\7@\2\2\u0253\u0254\7?\2\2\u0254\u009a\3\2\2\2\u0255\= u0256") >=20 > + buf.write("\7>\2\2\u0256\u0257\7>\2\2\u0257\u009c\3\2\2\2\u0258\= u0259") >=20 > + buf.write("\7@\2\2\u0259\u025a\7@\2\2\u025a\u009e\3\2\2\2\u025b\= u025c") >=20 > + buf.write("\7a\2\2\u025c\u025d\7a\2\2\u025d\u025e\7c\2\2\u025e\u= 025f") >=20 > + buf.write("\7u\2\2\u025f\u0260\7o\2\2\u0260\u0261\7a\2\2\u0261\u= 0262") >=20 > + buf.write("\7a\2\2\u0262\u00a0\3\2\2\2\u0263\u0264\7a\2\2\u0264\= u0265") >=20 > + buf.write("\7c\2\2\u0265\u0266\7u\2\2\u0266\u0267\7o\2\2\u0267\u= 00a2") >=20 > + buf.write("\3\2\2\2\u0268\u0269\7a\2\2\u0269\u026a\7a\2\2\u026a\= u026b") >=20 > + buf.write("\7c\2\2\u026b\u026c\7u\2\2\u026c\u026d\7o\2\2\u026d\u= 00a4") >=20 > + buf.write("\3\2\2\2\u026e\u026f\7e\2\2\u026f\u0270\7c\2\2\u0270\= u0271") >=20 > + buf.write("\7u\2\2\u0271\u0272\7g\2\2\u0272\u00a6\3\2\2\2\u0273\= u0274") >=20 > + buf.write("\7f\2\2\u0274\u0275\7g\2\2\u0275\u0276\7h\2\2\u0276\u= 0277") >=20 > + buf.write("\7c\2\2\u0277\u0278\7w\2\2\u0278\u0279\7n\2\2\u0279\u= 027a") >=20 > + buf.write("\7v\2\2\u027a\u00a8\3\2\2\2\u027b\u027c\7k\2\2\u027c\= u027d") >=20 > + buf.write("\7h\2\2\u027d\u00aa\3\2\2\2\u027e\u027f\7g\2\2\u027f\= u0280") >=20 > + buf.write("\7n\2\2\u0280\u0281\7u\2\2\u0281\u0282\7g\2\2\u0282\u= 00ac") >=20 > + buf.write("\3\2\2\2\u0283\u0284\7u\2\2\u0284\u0285\7y\2\2\u0285\= u0286") >=20 > + buf.write("\7k\2\2\u0286\u0287\7v\2\2\u0287\u0288\7e\2\2\u0288\u= 0289") >=20 > + buf.write("\7j\2\2\u0289\u00ae\3\2\2\2\u028a\u028b\7y\2\2\u028b\= u028c") >=20 > + buf.write("\7j\2\2\u028c\u028d\7k\2\2\u028d\u028e\7n\2\2\u028e\u= 028f") >=20 > + buf.write("\7g\2\2\u028f\u00b0\3\2\2\2\u0290\u0291\7f\2\2\u0291\= u0292") >=20 > + buf.write("\7q\2\2\u0292\u00b2\3\2\2\2\u0293\u0294\7i\2\2\u0294\= u0295") >=20 > + buf.write("\7q\2\2\u0295\u0296\7v\2\2\u0296\u0297\7q\2\2\u0297\u= 00b4") >=20 > + buf.write("\3\2\2\2\u0298\u0299\7e\2\2\u0299\u029a\7q\2\2\u029a\= u029b") >=20 > + buf.write("\7p\2\2\u029b\u029c\7v\2\2\u029c\u029d\7k\2\2\u029d\u= 029e") >=20 > + buf.write("\7p\2\2\u029e\u029f\7w\2\2\u029f\u02a0\7g\2\2\u02a0\u= 00b6") >=20 > + buf.write("\3\2\2\2\u02a1\u02a2\7d\2\2\u02a2\u02a3\7t\2\2\u02a3\= u02a4") >=20 > + buf.write("\7g\2\2\u02a4\u02a5\7c\2\2\u02a5\u02a6\7m\2\2\u02a6\u= 00b8") >=20 > + buf.write("\3\2\2\2\u02a7\u02a8\7t\2\2\u02a8\u02a9\7g\2\2\u02a9\= u02aa") >=20 > + buf.write("\7v\2\2\u02aa\u02ab\7w\2\2\u02ab\u02ac\7t\2\2\u02ac\u= 02ad") >=20 > + buf.write("\7p\2\2\u02ad\u00ba\3\2\2\2\u02ae\u02b3\5\u00bd_\2\u0= 2af") >=20 > + buf.write("\u02b2\5\u00bd_\2\u02b0\u02b2\4\62;\2\u02b1\u02af\3\2= ") >=20 > + buf.write("\2\2\u02b1\u02b0\3\2\2\2\u02b2\u02b5\3\2\2\2\u02b3\u0= 2b1") >=20 > + buf.write("\3\2\2\2\u02b3\u02b4\3\2\2\2\u02b4\u00bc\3\2\2\2\u02b= 5") >=20 > + buf.write("\u02b3\3\2\2\2\u02b6\u02b7\t\2\2\2\u02b7\u00be\3\2\2\= 2") >=20 > + buf.write("\u02b8\u02ba\7N\2\2\u02b9\u02b8\3\2\2\2\u02b9\u02ba\3= ") >=20 > + buf.write("\2\2\2\u02ba\u02bb\3\2\2\2\u02bb\u02be\7)\2\2\u02bc\u= 02bf") >=20 > + buf.write("\5\u00d3j\2\u02bd\u02bf\n\3\2\2\u02be\u02bc\3\2\2\2\u= 02be") >=20 > + buf.write("\u02bd\3\2\2\2\u02bf\u02c0\3\2\2\2\u02c0\u02c1\7)\2\2= ") >=20 > + buf.write("\u02c1\u00c0\3\2\2\2\u02c2\u02c4\7N\2\2\u02c3\u02c2\3= ") >=20 > + buf.write("\2\2\2\u02c3\u02c4\3\2\2\2\u02c4\u02c5\3\2\2\2\u02c5\= u02ca") >=20 > + buf.write("\7$\2\2\u02c6\u02c9\5\u00d3j\2\u02c7\u02c9\n\4\2\2\u0= 2c8") >=20 > + buf.write("\u02c6\3\2\2\2\u02c8\u02c7\3\2\2\2\u02c9\u02cc\3\2\2\= 2") >=20 > + buf.write("\u02ca\u02c8\3\2\2\2\u02ca\u02cb\3\2\2\2\u02cb\u02cd\= 3") >=20 > + buf.write("\2\2\2\u02cc\u02ca\3\2\2\2\u02cd\u02ce\7$\2\2\u02ce\u= 00c2") >=20 > + buf.write("\3\2\2\2\u02cf\u02d0\7\62\2\2\u02d0\u02d2\t\5\2\2\u02= d1") >=20 > + buf.write("\u02d3\5\u00c9e\2\u02d2\u02d1\3\2\2\2\u02d3\u02d4\3\2= ") >=20 > + buf.write("\2\2\u02d4\u02d2\3\2\2\2\u02d4\u02d5\3\2\2\2\u02d5\u0= 2d7") >=20 > + buf.write("\3\2\2\2\u02d6\u02d8\5\u00cbf\2\u02d7\u02d6\3\2\2\2\u= 02d7") >=20 > + buf.write("\u02d8\3\2\2\2\u02d8\u00c4\3\2\2\2\u02d9\u02e2\7\62\2= ") >=20 > + buf.write("\2\u02da\u02de\4\63;\2\u02db\u02dd\4\62;\2\u02dc\u02d= b") >=20 > + buf.write("\3\2\2\2\u02dd\u02e0\3\2\2\2\u02de\u02dc\3\2\2\2\u02d= e") >=20 > + buf.write("\u02df\3\2\2\2\u02df\u02e2\3\2\2\2\u02e0\u02de\3\2\2\= 2") >=20 > + buf.write("\u02e1\u02d9\3\2\2\2\u02e1\u02da\3\2\2\2\u02e2\u02e4\= 3") >=20 > + buf.write("\2\2\2\u02e3\u02e5\5\u00cbf\2\u02e4\u02e3\3\2\2\2\u02= e4") >=20 > + buf.write("\u02e5\3\2\2\2\u02e5\u00c6\3\2\2\2\u02e6\u02e8\7\62\2= ") >=20 > + buf.write("\2\u02e7\u02e9\4\629\2\u02e8\u02e7\3\2\2\2\u02e9\u02e= a") >=20 > + buf.write("\3\2\2\2\u02ea\u02e8\3\2\2\2\u02ea\u02eb\3\2\2\2\u02e= b") >=20 > + buf.write("\u02ed\3\2\2\2\u02ec\u02ee\5\u00cbf\2\u02ed\u02ec\3\2= ") >=20 > + buf.write("\2\2\u02ed\u02ee\3\2\2\2\u02ee\u00c8\3\2\2\2\u02ef\u0= 2f0") >=20 > + buf.write("\t\6\2\2\u02f0\u00ca\3\2\2\2\u02f1\u02f8\t\7\2\2\u02f= 2") >=20 > + buf.write("\u02f3\t\b\2\2\u02f3\u02f8\t\t\2\2\u02f4\u02f5\t\b\2\= 2") >=20 > + buf.write("\u02f5\u02f6\t\t\2\2\u02f6\u02f8\t\t\2\2\u02f7\u02f1\= 3") >=20 > + buf.write("\2\2\2\u02f7\u02f2\3\2\2\2\u02f7\u02f4\3\2\2\2\u02f8\= u00cc") >=20 > + buf.write("\3\2\2\2\u02f9\u02fb\4\62;\2\u02fa\u02f9\3\2\2\2\u02f= b") >=20 > + buf.write("\u02fc\3\2\2\2\u02fc\u02fa\3\2\2\2\u02fc\u02fd\3\2\2\= 2") >=20 > + buf.write("\u02fd\u02fe\3\2\2\2\u02fe\u0302\7\60\2\2\u02ff\u0301= ") >=20 > + buf.write("\4\62;\2\u0300\u02ff\3\2\2\2\u0301\u0304\3\2\2\2\u030= 2") >=20 > + buf.write("\u0300\3\2\2\2\u0302\u0303\3\2\2\2\u0303\u0306\3\2\2\= 2") >=20 > + buf.write("\u0304\u0302\3\2\2\2\u0305\u0307\5\u00cfh\2\u0306\u03= 05") >=20 > + buf.write("\3\2\2\2\u0306\u0307\3\2\2\2\u0307\u0309\3\2\2\2\u030= 8") >=20 > + buf.write("\u030a\5\u00d1i\2\u0309\u0308\3\2\2\2\u0309\u030a\3\2= ") >=20 > + buf.write("\2\2\u030a\u032a\3\2\2\2\u030b\u030d\7\60\2\2\u030c\u= 030e") >=20 > + buf.write("\4\62;\2\u030d\u030c\3\2\2\2\u030e\u030f\3\2\2\2\u030= f") >=20 > + buf.write("\u030d\3\2\2\2\u030f\u0310\3\2\2\2\u0310\u0312\3\2\2\= 2") >=20 > + buf.write("\u0311\u0313\5\u00cfh\2\u0312\u0311\3\2\2\2\u0312\u03= 13") >=20 > + buf.write("\3\2\2\2\u0313\u0315\3\2\2\2\u0314\u0316\5\u00d1i\2\u= 0315") >=20 > + buf.write("\u0314\3\2\2\2\u0315\u0316\3\2\2\2\u0316\u032a\3\2\2\= 2") >=20 > + buf.write("\u0317\u0319\4\62;\2\u0318\u0317\3\2\2\2\u0319\u031a\= 3") >=20 > + buf.write("\2\2\2\u031a\u0318\3\2\2\2\u031a\u031b\3\2\2\2\u031b\= u031c") >=20 > + buf.write("\3\2\2\2\u031c\u031e\5\u00cfh\2\u031d\u031f\5\u00d1i\= 2") >=20 > + buf.write("\u031e\u031d\3\2\2\2\u031e\u031f\3\2\2\2\u031f\u032a\= 3") >=20 > + buf.write("\2\2\2\u0320\u0322\4\62;\2\u0321\u0320\3\2\2\2\u0322\= u0323") >=20 > + buf.write("\3\2\2\2\u0323\u0321\3\2\2\2\u0323\u0324\3\2\2\2\u032= 4") >=20 > + buf.write("\u0326\3\2\2\2\u0325\u0327\5\u00cfh\2\u0326\u0325\3\2= ") >=20 > + buf.write("\2\2\u0326\u0327\3\2\2\2\u0327\u0328\3\2\2\2\u0328\u0= 32a") >=20 > + buf.write("\5\u00d1i\2\u0329\u02fa\3\2\2\2\u0329\u030b\3\2\2\2\u= 0329") >=20 > + buf.write("\u0318\3\2\2\2\u0329\u0321\3\2\2\2\u032a\u00ce\3\2\2\= 2") >=20 > + buf.write("\u032b\u032d\t\n\2\2\u032c\u032e\t\13\2\2\u032d\u032c= ") >=20 > + buf.write("\3\2\2\2\u032d\u032e\3\2\2\2\u032e\u0330\3\2\2\2\u032= f") >=20 > + buf.write("\u0331\4\62;\2\u0330\u032f\3\2\2\2\u0331\u0332\3\2\2\= 2") >=20 > + buf.write("\u0332\u0330\3\2\2\2\u0332\u0333\3\2\2\2\u0333\u00d0\= 3") >=20 > + buf.write("\2\2\2\u0334\u0335\t\f\2\2\u0335\u00d2\3\2\2\2\u0336\= u0337") >=20 > + buf.write("\7^\2\2\u0337\u033a\t\r\2\2\u0338\u033a\5\u00d5k\2\u0= 339") >=20 > + buf.write("\u0336\3\2\2\2\u0339\u0338\3\2\2\2\u033a\u00d4\3\2\2\= 2") >=20 > + buf.write("\u033b\u033c\7^\2\2\u033c\u033d\4\62\65\2\u033d\u033e= ") >=20 > + buf.write("\4\629\2\u033e\u0345\4\629\2\u033f\u0340\7^\2\2\u0340= ") >=20 > + buf.write("\u0341\4\629\2\u0341\u0345\4\629\2\u0342\u0343\7^\2\2= ") >=20 > + buf.write("\u0343\u0345\4\629\2\u0344\u033b\3\2\2\2\u0344\u033f\= 3") >=20 > + buf.write("\2\2\2\u0344\u0342\3\2\2\2\u0345\u00d6\3\2\2\2\u0346\= u0347") >=20 > + buf.write("\7^\2\2\u0347\u0348\7w\2\2\u0348\u0349\5\u00c9e\2\u03= 49") >=20 > + buf.write("\u034a\5\u00c9e\2\u034a\u034b\5\u00c9e\2\u034b\u034c\= 5") >=20 > + buf.write("\u00c9e\2\u034c\u00d8\3\2\2\2\u034d\u034e\t\16\2\2\u0= 34e") >=20 > + buf.write("\u034f\3\2\2\2\u034f\u0350\bm\2\2\u0350\u00da\3\2\2\2= ") >=20 > + buf.write("\u0351\u0352\7^\2\2\u0352\u0353\3\2\2\2\u0353\u0354\b= ") >=20 > + buf.write("n\2\2\u0354\u00dc\3\2\2\2\u0355\u0356\4\5\0\2\u0356\u= 00de") >=20 > + buf.write("\3\2\2\2\u0357\u0358\7\61\2\2\u0358\u0359\7,\2\2\u035= 9") >=20 > + buf.write("\u035d\3\2\2\2\u035a\u035c\13\2\2\2\u035b\u035a\3\2\2= ") >=20 > + buf.write("\2\u035c\u035f\3\2\2\2\u035d\u035e\3\2\2\2\u035d\u035= b") >=20 > + buf.write("\3\2\2\2\u035e\u0360\3\2\2\2\u035f\u035d\3\2\2\2\u036= 0") >=20 > + buf.write("\u0361\7,\2\2\u0361\u0362\7\61\2\2\u0362\u0363\3\2\2\= 2") >=20 > + buf.write("\u0363\u0364\bp\2\2\u0364\u00e0\3\2\2\2\u0365\u0366\7= ") >=20 > + buf.write("\61\2\2\u0366\u0367\7\61\2\2\u0367\u036b\3\2\2\2\u036= 8") >=20 > + buf.write("\u036a\n\17\2\2\u0369\u0368\3\2\2\2\u036a\u036d\3\2\2= ") >=20 > + buf.write("\2\u036b\u0369\3\2\2\2\u036b\u036c\3\2\2\2\u036c\u036= f") >=20 > + buf.write("\3\2\2\2\u036d\u036b\3\2\2\2\u036e\u0370\7\17\2\2\u03= 6f") >=20 > + buf.write("\u036e\3\2\2\2\u036f\u0370\3\2\2\2\u0370\u0371\3\2\2\= 2") >=20 > + buf.write("\u0371\u0372\7\f\2\2\u0372\u0373\3\2\2\2\u0373\u0374\= b") >=20 > + buf.write("q\2\2\u0374\u00e2\3\2\2\2\u0375\u0379\7%\2\2\u0376\u0= 378") >=20 > + buf.write("\n\17\2\2\u0377\u0376\3\2\2\2\u0378\u037b\3\2\2\2\u03= 79") >=20 > + buf.write("\u0377\3\2\2\2\u0379\u037a\3\2\2\2\u037a\u037d\3\2\2\= 2") >=20 > + buf.write("\u037b\u0379\3\2\2\2\u037c\u037e\7\17\2\2\u037d\u037c= ") >=20 > + buf.write("\3\2\2\2\u037d\u037e\3\2\2\2\u037e\u037f\3\2\2\2\u037= f") >=20 > + buf.write("\u0380\7\f\2\2\u0380\u0381\3\2\2\2\u0381\u0382\br\2\2= ") >=20 > + buf.write("\u0382\u00e4\3\2\2\2\'\2\u02b1\u02b3\u02b9\u02be\u02c= 3") >=20 > + buf.write("\u02c8\u02ca\u02d4\u02d7\u02de\u02e1\u02e4\u02ea\u02e= d") >=20 > + buf.write("\u02f7\u02fc\u0302\u0306\u0309\u030f\u0312\u0315\u031= a") >=20 > + buf.write("\u031e\u0323\u0326\u0329\u032d\u0332\u0339\u0344\u035= d") >=20 > + buf.write("\u036b\u036f\u0379\u037d\3\2\3\2") >=20 > + return buf.getvalue() >=20 > + >=20 > + >=20 > +class CLexer(Lexer): >=20 > + >=20 > + atn =3D ATNDeserializer().deserialize(serializedATN()) >=20 > + >=20 > + decisionsToDFA =3D [ DFA(ds, i) for i, ds in enumerate(atn.decisionT= oState) ] >=20 > + >=20 > + T__0 =3D 1 >=20 > + T__1 =3D 2 >=20 > + T__2 =3D 3 >=20 > + T__3 =3D 4 >=20 > + T__4 =3D 5 >=20 > + T__5 =3D 6 >=20 > + T__6 =3D 7 >=20 > + T__7 =3D 8 >=20 > + T__8 =3D 9 >=20 > + T__9 =3D 10 >=20 > + T__10 =3D 11 >=20 > + T__11 =3D 12 >=20 > + T__12 =3D 13 >=20 > + T__13 =3D 14 >=20 > + T__14 =3D 15 >=20 > + T__15 =3D 16 >=20 > + T__16 =3D 17 >=20 > + T__17 =3D 18 >=20 > + T__18 =3D 19 >=20 > + T__19 =3D 20 >=20 > + T__20 =3D 21 >=20 > + T__21 =3D 22 >=20 > + T__22 =3D 23 >=20 > + T__23 =3D 24 >=20 > + T__24 =3D 25 >=20 > + T__25 =3D 26 >=20 > + T__26 =3D 27 >=20 > + T__27 =3D 28 >=20 > + T__28 =3D 29 >=20 > + T__29 =3D 30 >=20 > + T__30 =3D 31 >=20 > + T__31 =3D 32 >=20 > + T__32 =3D 33 >=20 > + T__33 =3D 34 >=20 > + T__34 =3D 35 >=20 > + T__35 =3D 36 >=20 > + T__36 =3D 37 >=20 > + T__37 =3D 38 >=20 > + T__38 =3D 39 >=20 > + T__39 =3D 40 >=20 > + T__40 =3D 41 >=20 > + T__41 =3D 42 >=20 > + T__42 =3D 43 >=20 > + T__43 =3D 44 >=20 > + T__44 =3D 45 >=20 > + T__45 =3D 46 >=20 > + T__46 =3D 47 >=20 > + T__47 =3D 48 >=20 > + T__48 =3D 49 >=20 > + T__49 =3D 50 >=20 > + T__50 =3D 51 >=20 > + T__51 =3D 52 >=20 > + T__52 =3D 53 >=20 > + T__53 =3D 54 >=20 > + T__54 =3D 55 >=20 > + T__55 =3D 56 >=20 > + T__56 =3D 57 >=20 > + T__57 =3D 58 >=20 > + T__58 =3D 59 >=20 > + T__59 =3D 60 >=20 > + T__60 =3D 61 >=20 > + T__61 =3D 62 >=20 > + T__62 =3D 63 >=20 > + T__63 =3D 64 >=20 > + T__64 =3D 65 >=20 > + T__65 =3D 66 >=20 > + T__66 =3D 67 >=20 > + T__67 =3D 68 >=20 > + T__68 =3D 69 >=20 > + T__69 =3D 70 >=20 > + T__70 =3D 71 >=20 > + T__71 =3D 72 >=20 > + T__72 =3D 73 >=20 > + T__73 =3D 74 >=20 > + T__74 =3D 75 >=20 > + T__75 =3D 76 >=20 > + T__76 =3D 77 >=20 > + T__77 =3D 78 >=20 > + T__78 =3D 79 >=20 > + T__79 =3D 80 >=20 > + T__80 =3D 81 >=20 > + T__81 =3D 82 >=20 > + T__82 =3D 83 >=20 > + T__83 =3D 84 >=20 > + T__84 =3D 85 >=20 > + T__85 =3D 86 >=20 > + T__86 =3D 87 >=20 > + T__87 =3D 88 >=20 > + T__88 =3D 89 >=20 > + T__89 =3D 90 >=20 > + T__90 =3D 91 >=20 > + T__91 =3D 92 >=20 > + IDENTIFIER =3D 93 >=20 > + CHARACTER_LITERAL =3D 94 >=20 > + STRING_LITERAL =3D 95 >=20 > + HEX_LITERAL =3D 96 >=20 > + DECIMAL_LITERAL =3D 97 >=20 > + OCTAL_LITERAL =3D 98 >=20 > + FLOATING_POINT_LITERAL =3D 99 >=20 > + WS =3D 100 >=20 > + BS =3D 101 >=20 > + UnicodeVocabulary =3D 102 >=20 > + COMMENT =3D 103 >=20 > + LINE_COMMENT =3D 104 >=20 > + LINE_COMMAND =3D 105 >=20 > + >=20 > + channelNames =3D [ u"DEFAULT_TOKEN_CHANNEL", u"HIDDEN" ] >=20 > + >=20 > + modeNames =3D [ "DEFAULT_MODE" ] >=20 > + >=20 > + literalNames =3D [ "", >=20 > + "'{'", "';'", "'typedef'", "','", "'=3D'", "'extern'", "'sta= tic'", >=20 > + "'auto'", "'register'", "'STATIC'", "'void'", "'char'", "'sh= ort'", >=20 > + "'int'", "'long'", "'float'", "'double'", "'signed'", "'unsi= gned'", >=20 > + "'}'", "'struct'", "'union'", "':'", "'enum'", "'const'", "'= volatile'", >=20 > + "'IN'", "'OUT'", "'OPTIONAL'", "'CONST'", "'UNALIGNED'", "'V= OLATILE'", >=20 > + "'GLOBAL_REMOVE_IF_UNREFERENCED'", "'EFIAPI'", "'EFI_BOOTSER= VICE'", >=20 > + "'EFI_RUNTIMESERVICE'", "'PACKED'", "'('", "')'", "'['", "']= '", >=20 > + "'*'", "'...'", "'+'", "'-'", "'/'", "'%'", "'++'", "'--'", >=20 > + "'sizeof'", "'.'", "'->'", "'&'", "'~'", "'!'", "'*=3D'", "'= /=3D'", >=20 > + "'%=3D'", "'+=3D'", "'-=3D'", "'<<=3D'", "'>>=3D'", "'&=3D'"= , "'^=3D'", "'|=3D'", >=20 > + "'?'", "'||'", "'&&'", "'|'", "'^'", "'=3D=3D'", "'!=3D'", "= '<'", >=20 > + "'>'", "'<=3D'", "'>=3D'", "'<<'", "'>>'", "'__asm__'", "'_a= sm'", >=20 > + "'__asm'", "'case'", "'default'", "'if'", "'else'", "'switch= '", >=20 > + "'while'", "'do'", "'goto'", "'continue'", "'break'", "'retu= rn'" ] >=20 > + >=20 > + symbolicNames =3D [ "", >=20 > + "IDENTIFIER", "CHARACTER_LITERAL", "STRING_LITERAL", "HEX_LI= TERAL", >=20 > + "DECIMAL_LITERAL", "OCTAL_LITERAL", "FLOATING_POINT_LITERAL"= , >=20 > + "WS", "BS", "UnicodeVocabulary", "COMMENT", "LINE_COMMENT", >=20 > + "LINE_COMMAND" ] >=20 > + >=20 > + ruleNames =3D [ "T__0", "T__1", "T__2", "T__3", "T__4", "T__5", "T__= 6", >=20 > + "T__7", "T__8", "T__9", "T__10", "T__11", "T__12", "T_= _13", >=20 > + "T__14", "T__15", "T__16", "T__17", "T__18", "T__19", >=20 > + "T__20", "T__21", "T__22", "T__23", "T__24", "T__25", >=20 > + "T__26", "T__27", "T__28", "T__29", "T__30", "T__31", >=20 > + "T__32", "T__33", "T__34", "T__35", "T__36", "T__37", >=20 > + "T__38", "T__39", "T__40", "T__41", "T__42", "T__43", >=20 > + "T__44", "T__45", "T__46", "T__47", "T__48", "T__49", >=20 > + "T__50", "T__51", "T__52", "T__53", "T__54", "T__55", >=20 > + "T__56", "T__57", "T__58", "T__59", "T__60", "T__61", >=20 > + "T__62", "T__63", "T__64", "T__65", "T__66", "T__67", >=20 > + "T__68", "T__69", "T__70", "T__71", "T__72", "T__73", >=20 > + "T__74", "T__75", "T__76", "T__77", "T__78", "T__79", >=20 > + "T__80", "T__81", "T__82", "T__83", "T__84", "T__85", >=20 > + "T__86", "T__87", "T__88", "T__89", "T__90", "T__91", >=20 > + "IDENTIFIER", "LETTER", "CHARACTER_LITERAL", "STRING_L= ITERAL", >=20 > + "HEX_LITERAL", "DECIMAL_LITERAL", "OCTAL_LITERAL", "He= xDigit", >=20 > + "IntegerTypeSuffix", "FLOATING_POINT_LITERAL", "Expone= nt", >=20 > + "FloatTypeSuffix", "EscapeSequence", "OctalEscape", "U= nicodeEscape", >=20 > + "WS", "BS", "UnicodeVocabulary", "COMMENT", "LINE_COMM= ENT", >=20 > + "LINE_COMMAND" ] >=20 > + >=20 > + grammarFileName =3D "C.g4" >=20 > + >=20 > + # @param output=3D sys.stdout Type: TextIO >=20 > + def __init__(self,input=3DNone,output=3D sys.stdout): >=20 > + super().__init__(input, output) >=20 > + self.checkVersion("4.7.1") >=20 > + self._interp =3D LexerATNSimulator(self, self.atn, self.decision= sToDFA, PredictionContextCache()) >=20 > + self._actions =3D None >=20 > + self._predicates =3D None >=20 > + >=20 > + >=20 > + >=20 > + def printTokenInfo(self,line,offset,tokenText): >=20 > + print(str(line)+ ',' + str(offset) + ':' + str(tokenText)) >=20 > + >=20 > + def StorePredicateExpression(self,StartLine,StartOffset,EndLine,EndO= ffset,Text): >=20 > + PredExp =3D CodeFragment.PredicateExpression(Text, (StartLine, S= tartOffset), (EndLine, EndOffset)) >=20 > + FileProfile.PredicateExpressionList.append(PredExp) >=20 > + >=20 > + def StoreEnumerationDefinition(self,StartLine,StartOffset,EndLine,En= dOffset,Text): >=20 > + EnumDef =3D CodeFragment.EnumerationDefinition(Text, (StartLine,= StartOffset), (EndLine, EndOffset)) >=20 > + FileProfile.EnumerationDefinitionList.append(EnumDef) >=20 > + >=20 > + def StoreStructUnionDefinition(self,StartLine,StartOffset,EndLine,En= dOffset,Text): >=20 > + SUDef =3D CodeFragment.StructUnionDefinition(Text, (StartLine, S= tartOffset), (EndLine, EndOffset)) >=20 > + FileProfile.StructUnionDefinitionList.append(SUDef) >=20 > + >=20 > + def StoreTypedefDefinition(self,StartLine,StartOffset,EndLine,EndOff= set,FromText,ToText): >=20 > + Tdef =3D CodeFragment.TypedefDefinition(FromText, ToText, (Start= Line, StartOffset), (EndLine, EndOffset)) >=20 > + FileProfile.TypedefDefinitionList.append(Tdef) >=20 > + >=20 > + def > StoreFunctionDefinition(self,StartLine,StartOffset,EndLine,EndOffset,Modi= fierText,DeclText,LeftBraceLine,LeftBraceOffset,DeclLine,DeclOffse > t): >=20 > + FuncDef =3D CodeFragment.FunctionDefinition(ModifierText, DeclTe= xt, (StartLine, StartOffset), (EndLine, EndOffset), (LeftBraceLine, > LeftBraceOffset), (DeclLine, DeclOffset)) >=20 > + FileProfile.FunctionDefinitionList.append(FuncDef) >=20 > + >=20 > + def StoreVariableDeclaration(self,StartLine,StartOffset,EndLine,EndO= ffset,ModifierText,DeclText): >=20 > + VarDecl =3D CodeFragment.VariableDeclaration(ModifierText, DeclT= ext, (StartLine, StartOffset), (EndLine, EndOffset)) >=20 > + FileProfile.VariableDeclarationList.append(VarDecl) >=20 > + >=20 > + def StoreFunctionCalling(self,StartLine,StartOffset,EndLine,EndOffse= t,FuncName,ParamList): >=20 > + FuncCall =3D CodeFragment.FunctionCalling(FuncName, ParamList, (= StartLine, StartOffset), (EndLine, EndOffset)) >=20 > + FileProfile.FunctionCallingList.append(FuncCall) >=20 > + >=20 > + >=20 > + >=20 > diff --git a/BaseTools/Source/Python/Eot/CParser4/CListener.py b/BaseTool= s/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 >=20 > +from antlr4 import * >=20 > +if __name__ is not None and "." in __name__: >=20 > + from .CParser import CParser >=20 > +else: >=20 > + from CParser import CParser >=20 > + >=20 > +## @file >=20 > +# The file defines the parser for C source files. >=20 > +# >=20 > +# THIS FILE IS AUTO-GENENERATED. PLEASE DON NOT MODIFY THIS FILE. >=20 > +# This file is generated by running: >=20 > +# java org.antlr.Tool C.g >=20 > +# >=20 > +# Copyright (c) 2009 - 2010, Intel Corporation All rights reserved. >=20 > +# >=20 > +# This program and the accompanying materials are licensed and made avai= lable >=20 > +# under the terms and conditions of the BSD License which accompanies th= is >=20 > +# distribution. The full text of the license may be found at: >=20 > +# http://opensource.org/licenses/bsd-license.php >=20 > +# >=20 > +# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, >=20 > +# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR I= MPLIED. >=20 > +# >=20 > +## >=20 > + >=20 > +import Ecc.CodeFragment as CodeFragment >=20 > +import Ecc.FileProfile as FileProfile >=20 > + >=20 > + >=20 > +# This class defines a complete listener for a parse tree produced by CP= arser. >=20 > +class CListener(ParseTreeListener): >=20 > + >=20 > + # Enter a parse tree produced by CParser#translation_unit. >=20 > + # @param ctx Type: CParser.Translation_unitContext >=20 > + def enterTranslation_unit(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#translation_unit. >=20 > + # @param ctx Type: CParser.Translation_unitContext >=20 > + def exitTranslation_unit(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#external_declaration. >=20 > + # @param ctx Type: CParser.External_declarationContext >=20 > + def enterExternal_declaration(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#external_declaration. >=20 > + # @param ctx Type: CParser.External_declarationContext >=20 > + def exitExternal_declaration(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#function_definition. >=20 > + # @param ctx Type: CParser.Function_definitionContext >=20 > + def enterFunction_definition(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#function_definition. >=20 > + # @param ctx Type: CParser.Function_definitionContext >=20 > + def exitFunction_definition(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#declaration_specifiers. >=20 > + # @param ctx Type: CParser.Declaration_specifiersContext >=20 > + def enterDeclaration_specifiers(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#declaration_specifiers. >=20 > + # @param ctx Type: CParser.Declaration_specifiersContext >=20 > + def exitDeclaration_specifiers(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#declaration. >=20 > + # @param ctx Type: CParser.DeclarationContext >=20 > + def enterDeclaration(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#declaration. >=20 > + # @param ctx Type: CParser.DeclarationContext >=20 > + def exitDeclaration(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#init_declarator_list. >=20 > + # @param ctx Type: CParser.Init_declarator_listContext >=20 > + def enterInit_declarator_list(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#init_declarator_list. >=20 > + # @param ctx Type: CParser.Init_declarator_listContext >=20 > + def exitInit_declarator_list(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#init_declarator. >=20 > + # @param ctx Type: CParser.Init_declaratorContext >=20 > + def enterInit_declarator(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#init_declarator. >=20 > + # @param ctx Type: CParser.Init_declaratorContext >=20 > + def exitInit_declarator(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#storage_class_specifier. >=20 > + # @param ctx Type: CParser.Storage_class_specifierContext >=20 > + def enterStorage_class_specifier(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#storage_class_specifier. >=20 > + # @param ctx Type: CParser.Storage_class_specifierContext >=20 > + def exitStorage_class_specifier(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#type_specifier. >=20 > + # @param ctx Type: CParser.Type_specifierContext >=20 > + def enterType_specifier(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#type_specifier. >=20 > + # @param ctx Type: CParser.Type_specifierContext >=20 > + def exitType_specifier(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#type_id. >=20 > + # @param ctx Type: CParser.Type_idContext >=20 > + def enterType_id(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#type_id. >=20 > + # @param ctx Type: CParser.Type_idContext >=20 > + def exitType_id(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#struct_or_union_specifier. >=20 > + # @param ctx Type: CParser.Struct_or_union_specifierContext >=20 > + def enterStruct_or_union_specifier(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#struct_or_union_specifier. >=20 > + # @param ctx Type: CParser.Struct_or_union_specifierContext >=20 > + def exitStruct_or_union_specifier(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#struct_or_union. >=20 > + # @param ctx Type: CParser.Struct_or_unionContext >=20 > + def enterStruct_or_union(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#struct_or_union. >=20 > + # @param ctx Type: CParser.Struct_or_unionContext >=20 > + def exitStruct_or_union(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#struct_declaration_list. >=20 > + # @param ctx Type: CParser.Struct_declaration_listContext >=20 > + def enterStruct_declaration_list(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#struct_declaration_list. >=20 > + # @param ctx Type: CParser.Struct_declaration_listContext >=20 > + def exitStruct_declaration_list(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#struct_declaration. >=20 > + # @param ctx Type: CParser.Struct_declarationContext >=20 > + def enterStruct_declaration(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#struct_declaration. >=20 > + # @param ctx Type: CParser.Struct_declarationContext >=20 > + def exitStruct_declaration(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#specifier_qualifier_list. >=20 > + # @param ctx Type: CParser.Specifier_qualifier_listContext >=20 > + def enterSpecifier_qualifier_list(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#specifier_qualifier_list. >=20 > + # @param ctx Type: CParser.Specifier_qualifier_listContext >=20 > + def exitSpecifier_qualifier_list(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#struct_declarator_list. >=20 > + # @param ctx Type: CParser.Struct_declarator_listContext >=20 > + def enterStruct_declarator_list(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#struct_declarator_list. >=20 > + # @param ctx Type: CParser.Struct_declarator_listContext >=20 > + def exitStruct_declarator_list(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#struct_declarator. >=20 > + # @param ctx Type: CParser.Struct_declaratorContext >=20 > + def enterStruct_declarator(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#struct_declarator. >=20 > + # @param ctx Type: CParser.Struct_declaratorContext >=20 > + def exitStruct_declarator(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#enum_specifier. >=20 > + # @param ctx Type: CParser.Enum_specifierContext >=20 > + def enterEnum_specifier(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#enum_specifier. >=20 > + # @param ctx Type: CParser.Enum_specifierContext >=20 > + def exitEnum_specifier(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#enumerator_list. >=20 > + # @param ctx Type: CParser.Enumerator_listContext >=20 > + def enterEnumerator_list(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#enumerator_list. >=20 > + # @param ctx Type: CParser.Enumerator_listContext >=20 > + def exitEnumerator_list(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#enumerator. >=20 > + # @param ctx Type: CParser.EnumeratorContext >=20 > + def enterEnumerator(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#enumerator. >=20 > + # @param ctx Type: CParser.EnumeratorContext >=20 > + def exitEnumerator(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#type_qualifier. >=20 > + # @param ctx Type: CParser.Type_qualifierContext >=20 > + def enterType_qualifier(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#type_qualifier. >=20 > + # @param ctx Type: CParser.Type_qualifierContext >=20 > + def exitType_qualifier(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#declarator. >=20 > + # @param ctx Type: CParser.DeclaratorContext >=20 > + def enterDeclarator(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#declarator. >=20 > + # @param ctx Type: CParser.DeclaratorContext >=20 > + def exitDeclarator(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#direct_declarator. >=20 > + # @param ctx Type: CParser.Direct_declaratorContext >=20 > + def enterDirect_declarator(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#direct_declarator. >=20 > + # @param ctx Type: CParser.Direct_declaratorContext >=20 > + def exitDirect_declarator(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#declarator_suffix. >=20 > + # @param ctx Type: CParser.Declarator_suffixContext >=20 > + def enterDeclarator_suffix(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#declarator_suffix. >=20 > + # @param ctx Type: CParser.Declarator_suffixContext >=20 > + def exitDeclarator_suffix(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#pointer. >=20 > + # @param ctx Type: CParser.PointerContext >=20 > + def enterPointer(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#pointer. >=20 > + # @param ctx Type: CParser.PointerContext >=20 > + def exitPointer(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#parameter_type_list. >=20 > + # @param ctx Type: CParser.Parameter_type_listContext >=20 > + def enterParameter_type_list(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#parameter_type_list. >=20 > + # @param ctx Type: CParser.Parameter_type_listContext >=20 > + def exitParameter_type_list(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#parameter_list. >=20 > + # @param ctx Type: CParser.Parameter_listContext >=20 > + def enterParameter_list(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#parameter_list. >=20 > + # @param ctx Type: CParser.Parameter_listContext >=20 > + def exitParameter_list(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#parameter_declaration. >=20 > + # @param ctx Type: CParser.Parameter_declarationContext >=20 > + def enterParameter_declaration(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#parameter_declaration. >=20 > + # @param ctx Type: CParser.Parameter_declarationContext >=20 > + def exitParameter_declaration(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#identifier_list. >=20 > + # @param ctx Type: CParser.Identifier_listContext >=20 > + def enterIdentifier_list(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#identifier_list. >=20 > + # @param ctx Type: CParser.Identifier_listContext >=20 > + def exitIdentifier_list(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#type_name. >=20 > + # @param ctx Type: CParser.Type_nameContext >=20 > + def enterType_name(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#type_name. >=20 > + # @param ctx Type: CParser.Type_nameContext >=20 > + def exitType_name(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#abstract_declarator. >=20 > + # @param ctx Type: CParser.Abstract_declaratorContext >=20 > + def enterAbstract_declarator(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#abstract_declarator. >=20 > + # @param ctx Type: CParser.Abstract_declaratorContext >=20 > + def exitAbstract_declarator(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#direct_abstract_declarator. >=20 > + # @param ctx Type: CParser.Direct_abstract_declaratorContext >=20 > + def enterDirect_abstract_declarator(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#direct_abstract_declarator. >=20 > + # @param ctx Type: CParser.Direct_abstract_declaratorContext >=20 > + def exitDirect_abstract_declarator(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#abstract_declarator_suffix. >=20 > + # @param ctx Type: CParser.Abstract_declarator_suffixContext >=20 > + def enterAbstract_declarator_suffix(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#abstract_declarator_suffix. >=20 > + # @param ctx Type: CParser.Abstract_declarator_suffixContext >=20 > + def exitAbstract_declarator_suffix(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#initializer. >=20 > + # @param ctx Type: CParser.InitializerContext >=20 > + def enterInitializer(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#initializer. >=20 > + # @param ctx Type: CParser.InitializerContext >=20 > + def exitInitializer(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#initializer_list. >=20 > + # @param ctx Type: CParser.Initializer_listContext >=20 > + def enterInitializer_list(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#initializer_list. >=20 > + # @param ctx Type: CParser.Initializer_listContext >=20 > + def exitInitializer_list(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#argument_expression_list. >=20 > + # @param ctx Type: CParser.Argument_expression_listContext >=20 > + def enterArgument_expression_list(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#argument_expression_list. >=20 > + # @param ctx Type: CParser.Argument_expression_listContext >=20 > + def exitArgument_expression_list(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#additive_expression. >=20 > + # @param ctx Type: CParser.Additive_expressionContext >=20 > + def enterAdditive_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#additive_expression. >=20 > + # @param ctx Type: CParser.Additive_expressionContext >=20 > + def exitAdditive_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#multiplicative_expression. >=20 > + # @param ctx Type: CParser.Multiplicative_expressionContext >=20 > + def enterMultiplicative_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#multiplicative_expression. >=20 > + # @param ctx Type: CParser.Multiplicative_expressionContext >=20 > + def exitMultiplicative_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#cast_expression. >=20 > + # @param ctx Type: CParser.Cast_expressionContext >=20 > + def enterCast_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#cast_expression. >=20 > + # @param ctx Type: CParser.Cast_expressionContext >=20 > + def exitCast_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#unary_expression. >=20 > + # @param ctx Type: CParser.Unary_expressionContext >=20 > + def enterUnary_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#unary_expression. >=20 > + # @param ctx Type: CParser.Unary_expressionContext >=20 > + def exitUnary_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#postfix_expression. >=20 > + # @param ctx Type: CParser.Postfix_expressionContext >=20 > + def enterPostfix_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#postfix_expression. >=20 > + # @param ctx Type: CParser.Postfix_expressionContext >=20 > + def exitPostfix_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#macro_parameter_list. >=20 > + # @param ctx Type: CParser.Macro_parameter_listContext >=20 > + def enterMacro_parameter_list(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#macro_parameter_list. >=20 > + # @param ctx Type: CParser.Macro_parameter_listContext >=20 > + def exitMacro_parameter_list(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#unary_operator. >=20 > + # @param ctx Type: CParser.Unary_operatorContext >=20 > + def enterUnary_operator(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#unary_operator. >=20 > + # @param ctx Type: CParser.Unary_operatorContext >=20 > + def exitUnary_operator(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#primary_expression. >=20 > + # @param ctx Type: CParser.Primary_expressionContext >=20 > + def enterPrimary_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#primary_expression. >=20 > + # @param ctx Type: CParser.Primary_expressionContext >=20 > + def exitPrimary_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#constant. >=20 > + # @param ctx Type: CParser.ConstantContext >=20 > + def enterConstant(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#constant. >=20 > + # @param ctx Type: CParser.ConstantContext >=20 > + def exitConstant(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#expression. >=20 > + # @param ctx Type: CParser.ExpressionContext >=20 > + def enterExpression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#expression. >=20 > + # @param ctx Type: CParser.ExpressionContext >=20 > + def exitExpression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#constant_expression. >=20 > + # @param ctx Type: CParser.Constant_expressionContext >=20 > + def enterConstant_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#constant_expression. >=20 > + # @param ctx Type: CParser.Constant_expressionContext >=20 > + def exitConstant_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#assignment_expression. >=20 > + # @param ctx Type: CParser.Assignment_expressionContext >=20 > + def enterAssignment_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#assignment_expression. >=20 > + # @param ctx Type: CParser.Assignment_expressionContext >=20 > + def exitAssignment_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#lvalue. >=20 > + # @param ctx Type: CParser.LvalueContext >=20 > + def enterLvalue(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#lvalue. >=20 > + # @param ctx Type: CParser.LvalueContext >=20 > + def exitLvalue(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#assignment_operator. >=20 > + # @param ctx Type: CParser.Assignment_operatorContext >=20 > + def enterAssignment_operator(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#assignment_operator. >=20 > + # @param ctx Type: CParser.Assignment_operatorContext >=20 > + def exitAssignment_operator(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#conditional_expression. >=20 > + # @param ctx Type: CParser.Conditional_expressionContext >=20 > + def enterConditional_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#conditional_expression. >=20 > + # @param ctx Type: CParser.Conditional_expressionContext >=20 > + def exitConditional_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#logical_or_expression. >=20 > + # @param ctx Type: CParser.Logical_or_expressionContext >=20 > + def enterLogical_or_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#logical_or_expression. >=20 > + # @param ctx Type: CParser.Logical_or_expressionContext >=20 > + def exitLogical_or_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#logical_and_expression. >=20 > + # @param ctx Type: CParser.Logical_and_expressionContext >=20 > + def enterLogical_and_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#logical_and_expression. >=20 > + # @param ctx Type: CParser.Logical_and_expressionContext >=20 > + def exitLogical_and_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#inclusive_or_expression. >=20 > + # @param ctx Type: CParser.Inclusive_or_expressionContext >=20 > + def enterInclusive_or_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#inclusive_or_expression. >=20 > + # @param ctx Type: CParser.Inclusive_or_expressionContext >=20 > + def exitInclusive_or_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#exclusive_or_expression. >=20 > + # @param ctx Type: CParser.Exclusive_or_expressionContext >=20 > + def enterExclusive_or_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#exclusive_or_expression. >=20 > + # @param ctx Type: CParser.Exclusive_or_expressionContext >=20 > + def exitExclusive_or_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#and_expression. >=20 > + # @param ctx Type: CParser.And_expressionContext >=20 > + def enterAnd_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#and_expression. >=20 > + # @param ctx Type: CParser.And_expressionContext >=20 > + def exitAnd_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#equality_expression. >=20 > + # @param ctx Type: CParser.Equality_expressionContext >=20 > + def enterEquality_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#equality_expression. >=20 > + # @param ctx Type: CParser.Equality_expressionContext >=20 > + def exitEquality_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#relational_expression. >=20 > + # @param ctx Type: CParser.Relational_expressionContext >=20 > + def enterRelational_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#relational_expression. >=20 > + # @param ctx Type: CParser.Relational_expressionContext >=20 > + def exitRelational_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#shift_expression. >=20 > + # @param ctx Type: CParser.Shift_expressionContext >=20 > + def enterShift_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#shift_expression. >=20 > + # @param ctx Type: CParser.Shift_expressionContext >=20 > + def exitShift_expression(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#statement. >=20 > + # @param ctx Type: CParser.StatementContext >=20 > + def enterStatement(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#statement. >=20 > + # @param ctx Type: CParser.StatementContext >=20 > + def exitStatement(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#asm2_statement. >=20 > + # @param ctx Type: CParser.Asm2_statementContext >=20 > + def enterAsm2_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#asm2_statement. >=20 > + # @param ctx Type: CParser.Asm2_statementContext >=20 > + def exitAsm2_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#asm1_statement. >=20 > + # @param ctx Type: CParser.Asm1_statementContext >=20 > + def enterAsm1_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#asm1_statement. >=20 > + # @param ctx Type: CParser.Asm1_statementContext >=20 > + def exitAsm1_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#asm_statement. >=20 > + # @param ctx Type: CParser.Asm_statementContext >=20 > + def enterAsm_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#asm_statement. >=20 > + # @param ctx Type: CParser.Asm_statementContext >=20 > + def exitAsm_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#macro_statement. >=20 > + # @param ctx Type: CParser.Macro_statementContext >=20 > + def enterMacro_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#macro_statement. >=20 > + # @param ctx Type: CParser.Macro_statementContext >=20 > + def exitMacro_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#labeled_statement. >=20 > + # @param ctx Type: CParser.Labeled_statementContext >=20 > + def enterLabeled_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#labeled_statement. >=20 > + # @param ctx Type: CParser.Labeled_statementContext >=20 > + def exitLabeled_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#compound_statement. >=20 > + # @param ctx Type: CParser.Compound_statementContext >=20 > + def enterCompound_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#compound_statement. >=20 > + # @param ctx Type: CParser.Compound_statementContext >=20 > + def exitCompound_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#statement_list. >=20 > + # @param ctx Type: CParser.Statement_listContext >=20 > + def enterStatement_list(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#statement_list. >=20 > + # @param ctx Type: CParser.Statement_listContext >=20 > + def exitStatement_list(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#expression_statement. >=20 > + # @param ctx Type: CParser.Expression_statementContext >=20 > + def enterExpression_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#expression_statement. >=20 > + # @param ctx Type: CParser.Expression_statementContext >=20 > + def exitExpression_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#selection_statement. >=20 > + # @param ctx Type: CParser.Selection_statementContext >=20 > + def enterSelection_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#selection_statement. >=20 > + # @param ctx Type: CParser.Selection_statementContext >=20 > + def exitSelection_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#iteration_statement. >=20 > + # @param ctx Type: CParser.Iteration_statementContext >=20 > + def enterIteration_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#iteration_statement. >=20 > + # @param ctx Type: CParser.Iteration_statementContext >=20 > + def exitIteration_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > + # Enter a parse tree produced by CParser#jump_statement. >=20 > + # @param ctx Type: CParser.Jump_statementContext >=20 > + def enterJump_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + # Exit a parse tree produced by CParser#jump_statement. >=20 > + # @param ctx Type: CParser.Jump_statementContext >=20 > + def exitJump_statement(self,ctx): >=20 > + pass >=20 > + >=20 > + >=20 > 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 >=20 > +# encoding: utf-8 >=20 > +from antlr4 import * >=20 > +from io import StringIO >=20 > +from typing.io import TextIO >=20 > +import sys >=20 > + >=20 > + >=20 > +## @file >=20 > +# The file defines the parser for C source files. >=20 > +# >=20 > +# THIS FILE IS AUTO-GENENERATED. PLEASE DON NOT MODIFY THIS FILE. >=20 > +# This file is generated by running: >=20 > +# java org.antlr.Tool C.g >=20 > +# >=20 > +# Copyright (c) 2009 - 2010, Intel Corporation All rights reserved. >=20 > +# >=20 > +# This program and the accompanying materials are licensed and made avai= lable >=20 > +# under the terms and conditions of the BSD License which accompanies th= is >=20 > +# distribution. The full text of the license may be found at: >=20 > +# http://opensource.org/licenses/bsd-license.php >=20 > +# >=20 > +# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, >=20 > +# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR I= MPLIED. >=20 > +# >=20 > +## >=20 > + >=20 > +import Ecc.CodeFragment as CodeFragment >=20 > +import Ecc.FileProfile as FileProfile >=20 > + >=20 > +def serializedATN(): >=20 > + with StringIO() as buf: >=20 > + buf.write("\3\u608b\ua72a\u8133\ub9ed\u417c\u3be7\u7786\u5964\3k= ") >=20 > + 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") >=20 > + 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") >=20 > + buf.write("\t\16\4\17\t\17\4\20\t\20\4\21\t\21\4\22\t\22\4\23\t\= 23") >=20 > + buf.write("\4\24\t\24\4\25\t\25\4\26\t\26\4\27\t\27\4\30\t\30\4\= 31") >=20 > + buf.write("\t\31\4\32\t\32\4\33\t\33\4\34\t\34\4\35\t\35\4\36\t\= 36") >=20 > + buf.write("\4\37\t\37\4 \t \4!\t!\4\"\t\"\4#\t#\4$\t$\4%\t%\4&\t= ") >=20 > + buf.write("&\4\'\t\'\4(\t(\4)\t)\4*\t*\4+\t+\4,\t,\4-\t-\4.\t.\4= ") >=20 > + buf.write("/\t/\4\60\t\60\4\61\t\61\4\62\t\62\4\63\t\63\4\64\t\6= 4") >=20 > + buf.write("\4\65\t\65\4\66\t\66\4\67\t\67\48\t8\49\t9\4:\t:\4;\t= ") >=20 > + buf.write(";\4<\t<\4=3D\t=3D\4>\t>\4?\t?\4@\t@\4A\tA\4B\tB\4C\tC= \4D\t") >=20 > + buf.write("D\4E\tE\4F\tF\4G\tG\4H\tH\3\2\7\2\u0092\n\2\f\2\16\2\= u0095") >=20 > + buf.write("\13\2\3\3\5\3\u0098\n\3\3\3\3\3\7\3\u009c\n\3\f\3\16\= 3") >=20 > + buf.write("\u009f\13\3\3\3\3\3\3\3\3\3\3\3\3\3\5\3\u00a7\n\3\5\3= ") >=20 > + buf.write("\u00a9\n\3\3\4\5\4\u00ac\n\4\3\4\3\4\6\4\u00b0\n\4\r\= 4") >=20 > + buf.write("\16\4\u00b1\3\4\3\4\3\4\5\4\u00b7\n\4\3\4\3\4\3\5\3\5= ") >=20 > + buf.write("\3\5\6\5\u00be\n\5\r\5\16\5\u00bf\3\6\3\6\5\6\u00c4\n= ") >=20 > + 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") >=20 > + buf.write("\6\u00d1\n\6\3\7\3\7\3\7\7\7\u00d6\n\7\f\7\16\7\u00d9= ") >=20 > + 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= ") >=20 > + 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") >=20 > + buf.write("\7\n\u00f3\n\n\f\n\16\n\u00f6\13\n\3\n\3\n\5\n\u00fa\= n") >=20 > + 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") >=20 > + buf.write("\3\f\3\f\5\f\u0109\n\f\3\r\3\r\3\16\6\16\u010e\n\16\r= ") >=20 > + buf.write("\16\16\16\u010f\3\17\3\17\3\17\3\17\3\20\3\20\6\20\u0= 118") >=20 > + buf.write("\n\20\r\20\16\20\u0119\3\21\3\21\3\21\7\21\u011f\n\21= ") >=20 > + buf.write("\f\21\16\21\u0122\13\21\3\22\3\22\3\22\5\22\u0127\n\2= 2") >=20 > + buf.write("\3\22\3\22\5\22\u012b\n\22\3\23\3\23\3\23\3\23\5\23\u= 0131") >=20 > + buf.write("\n\23\3\23\3\23\3\23\3\23\3\23\3\23\3\23\5\23\u013a\n= ") >=20 > + buf.write("\23\3\23\3\23\3\23\3\23\5\23\u0140\n\23\3\24\3\24\3\2= 4") >=20 > + buf.write("\7\24\u0145\n\24\f\24\16\24\u0148\13\24\3\25\3\25\3\2= 5") >=20 > + buf.write("\5\25\u014d\n\25\3\26\3\26\3\27\5\27\u0152\n\27\3\27\= 5") >=20 > + buf.write("\27\u0155\n\27\3\27\5\27\u0158\n\27\3\27\5\27\u015b\n= ") >=20 > + buf.write("\27\3\27\3\27\5\27\u015f\n\27\3\30\3\30\7\30\u0163\n\= 30") >=20 > + buf.write("\f\30\16\30\u0166\13\30\3\30\3\30\5\30\u016a\n\30\3\3= 0") >=20 > + buf.write("\3\30\3\30\6\30\u016f\n\30\r\30\16\30\u0170\5\30\u017= 3") >=20 > + buf.write("\n\30\3\31\3\31\3\31\3\31\3\31\3\31\3\31\3\31\3\31\3\= 31") >=20 > + buf.write("\3\31\3\31\3\31\3\31\3\31\3\31\5\31\u0185\n\31\3\32\3= ") >=20 > + buf.write("\32\6\32\u0189\n\32\r\32\16\32\u018a\3\32\5\32\u018e\= n") >=20 > + buf.write("\32\3\32\3\32\3\32\5\32\u0193\n\32\3\33\3\33\3\33\5\3= 3") >=20 > + buf.write("\u0198\n\33\3\33\5\33\u019b\n\33\3\34\3\34\3\34\5\34\= u01a0") >=20 > + buf.write("\n\34\3\34\7\34\u01a3\n\34\f\34\16\34\u01a6\13\34\3\3= 5") >=20 > + buf.write("\3\35\3\35\7\35\u01ab\n\35\f\35\16\35\u01ae\13\35\3\3= 5") >=20 > + buf.write("\5\35\u01b1\n\35\3\35\7\35\u01b4\n\35\f\35\16\35\u01b= 7") >=20 > + buf.write("\13\35\3\35\5\35\u01ba\n\35\3\36\3\36\3\36\7\36\u01bf= ") >=20 > + buf.write("\n\36\f\36\16\36\u01c2\13\36\3\37\3\37\5\37\u01c6\n\3= 7") >=20 > + buf.write("\3\37\5\37\u01c9\n\37\3 \3 \5 \u01cd\n \3 \5 \u01d0\n= ") >=20 > + buf.write(" \3!\3!\3!\3!\3!\5!\u01d7\n!\3!\7!\u01da\n!\f!\16!\u0= 1dd") >=20 > + buf.write("\13!\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\3\"\= 5") >=20 > + buf.write("\"\u01eb\n\"\3#\3#\3#\3#\5#\u01f1\n#\3#\3#\5#\u01f5\n= ") >=20 > + buf.write("#\3$\3$\3$\7$\u01fa\n$\f$\16$\u01fd\13$\3%\3%\5%\u020= 1") >=20 > + buf.write("\n%\3%\3%\3%\5%\u0206\n%\7%\u0208\n%\f%\16%\u020b\13%= ") >=20 > + buf.write("\3&\3&\3&\3&\3&\7&\u0212\n&\f&\16&\u0215\13&\3\'\3\'\= 3") >=20 > + buf.write("\'\3\'\3\'\3\'\3\'\7\'\u021e\n\'\f\'\16\'\u0221\13\'\= 3") >=20 > + buf.write("(\3(\3(\3(\3(\3(\5(\u0229\n(\3)\3)\3)\3)\3)\3)\3)\3)\= 3") >=20 > + buf.write(")\3)\3)\3)\3)\3)\3)\5)\u023a\n)\3*\3*\3*\3*\3*\3*\3*\= 3") >=20 > + buf.write("*\3*\3*\3*\3*\3*\3*\3*\3*\3*\3*\3*\3*\3*\3*\3*\3*\3*\= 3") >=20 > + buf.write("*\3*\3*\3*\7*\u0259\n*\f*\16*\u025c\13*\3+\3+\3+\7+\u= 0261") >=20 > + buf.write("\n+\f+\16+\u0264\13+\3,\3,\3-\3-\3-\3-\3-\3-\5-\u026e= ") >=20 > + buf.write("\n-\3.\3.\3.\3.\3.\7.\u0275\n.\f.\16.\u0278\13.\3.\6.= ") >=20 > + buf.write("\u027b\n.\r.\16.\u027c\6.\u027f\n.\r.\16.\u0280\3.\7.= ") >=20 > + buf.write("\u0284\n.\f.\16.\u0287\13.\3.\5.\u028a\n.\3/\3/\3/\7/= ") >=20 > + buf.write("\u028f\n/\f/\16/\u0292\13/\3\60\3\60\3\61\3\61\3\61\3= ") >=20 > + buf.write("\61\3\61\5\61\u029b\n\61\3\62\3\62\3\63\3\63\3\64\3\6= 4") >=20 > + buf.write("\3\64\3\64\3\64\3\64\3\64\5\64\u02a8\n\64\3\65\3\65\3= ") >=20 > + buf.write("\65\7\65\u02ad\n\65\f\65\16\65\u02b0\13\65\3\66\3\66\= 3") >=20 > + buf.write("\66\7\66\u02b5\n\66\f\66\16\66\u02b8\13\66\3\67\3\67\= 3") >=20 > + buf.write("\67\7\67\u02bd\n\67\f\67\16\67\u02c0\13\67\38\38\38\7= ") >=20 > + buf.write("8\u02c5\n8\f8\168\u02c8\138\39\39\39\79\u02cd\n9\f9\1= 6") >=20 > + buf.write("9\u02d0\139\3:\3:\3:\7:\u02d5\n:\f:\16:\u02d8\13:\3;\= 3") >=20 > + buf.write(";\3;\7;\u02dd\n;\f;\16;\u02e0\13;\3<\3<\3<\7<\u02e5\n= ") >=20 > + buf.write("<\f<\16<\u02e8\13<\3=3D\3=3D\3=3D\3=3D\3=3D\3=3D\3=3D= \3=3D\3=3D\3=3D\3=3D\5") >=20 > + buf.write("=3D\u02f5\n=3D\3>\5>\u02f8\n>\3>\3>\3>\7>\u02fd\n>\f>= \16>") >=20 > + buf.write("\u0300\13>\3>\3>\3>\3?\3?\3?\7?\u0308\n?\f?\16?\u030b= ") >=20 > + buf.write("\13?\3?\3?\3@\3@\3@\7@\u0312\n@\f@\16@\u0315\13@\3@\3= ") >=20 > + buf.write("@\3A\3A\3A\7A\u031c\nA\fA\16A\u031f\13A\3A\5A\u0322\n= ") >=20 > + buf.write("A\3A\5A\u0325\nA\3A\3A\3B\3B\3B\3B\3B\3B\3B\3B\3B\3B\= 3") >=20 > + buf.write("B\5B\u0334\nB\3C\3C\7C\u0338\nC\fC\16C\u033b\13C\3C\5= ") >=20 > + buf.write("C\u033e\nC\3C\3C\3D\6D\u0343\nD\rD\16D\u0344\3E\3E\3E= ") >=20 > + buf.write("\3E\5E\u034b\nE\3F\3F\3F\3F\3F\3F\3F\3F\5F\u0355\nF\3= ") >=20 > + buf.write("F\3F\3F\3F\3F\3F\5F\u035d\nF\3G\3G\3G\3G\3G\3G\3G\3G\= 3") >=20 > + buf.write("G\3G\3G\3G\3G\3G\3G\3G\5G\u036f\nG\3H\3H\3H\3H\3H\3H\= 3") >=20 > + buf.write("H\3H\3H\3H\3H\3H\3H\5H\u037e\nH\3H\2\2I\2\4\6\b\n\f\1= 6") >=20 > + buf.write("\20\22\24\26\30\32\34\36 \"$&(*,.\60\62\64\668:<>@BDF= ") >=20 > + buf.write("HJLNPRTVXZ\\^`bdfhjlnprtvxz|~\u0080\u0082\u0084\u0086= ") >=20 > + buf.write("\u0088\u008a\u008c\u008e\2\f\3\2\b\f\3\2\27\30\3\2\33= ") >=20 > + buf.write("\'\5\2,,./\679\4\2\7\7:C\3\2IJ\3\2KN\3\2OP\3\2\4\4\3\= 2") >=20 > + buf.write("\26\26\2\u03d8\2\u0093\3\2\2\2\4\u00a8\3\2\2\2\6\u00a= b") >=20 > + buf.write("\3\2\2\2\b\u00bd\3\2\2\2\n\u00d0\3\2\2\2\f\u00d2\3\2\= 2") >=20 > + buf.write("\2\16\u00da\3\2\2\2\20\u00df\3\2\2\2\22\u00f9\3\2\2\2= ") >=20 > + buf.write("\24\u00fb\3\2\2\2\26\u0108\3\2\2\2\30\u010a\3\2\2\2\3= 2") >=20 > + buf.write("\u010d\3\2\2\2\34\u0111\3\2\2\2\36\u0117\3\2\2\2 \u01= 1b") >=20 > + buf.write("\3\2\2\2\"\u012a\3\2\2\2$\u013f\3\2\2\2&\u0141\3\2\2\= 2") >=20 > + buf.write("(\u0149\3\2\2\2*\u014e\3\2\2\2,\u015e\3\2\2\2.\u0172\= 3") >=20 > + buf.write("\2\2\2\60\u0184\3\2\2\2\62\u0192\3\2\2\2\64\u0194\3\2= ") >=20 > + buf.write("\2\2\66\u019c\3\2\2\28\u01b9\3\2\2\2:\u01bb\3\2\2\2<\= u01c8") >=20 > + buf.write("\3\2\2\2>\u01cf\3\2\2\2@\u01d6\3\2\2\2B\u01ea\3\2\2\2= ") >=20 > + buf.write("D\u01f4\3\2\2\2F\u01f6\3\2\2\2H\u01fe\3\2\2\2J\u020c\= 3") >=20 > + buf.write("\2\2\2L\u0216\3\2\2\2N\u0228\3\2\2\2P\u0239\3\2\2\2R\= u023b") >=20 > + buf.write("\3\2\2\2T\u025d\3\2\2\2V\u0265\3\2\2\2X\u026d\3\2\2\2= ") >=20 > + buf.write("Z\u0289\3\2\2\2\\\u028b\3\2\2\2^\u0293\3\2\2\2`\u029a= ") >=20 > + buf.write("\3\2\2\2b\u029c\3\2\2\2d\u029e\3\2\2\2f\u02a0\3\2\2\2= ") >=20 > + buf.write("h\u02a9\3\2\2\2j\u02b1\3\2\2\2l\u02b9\3\2\2\2n\u02c1\= 3") >=20 > + buf.write("\2\2\2p\u02c9\3\2\2\2r\u02d1\3\2\2\2t\u02d9\3\2\2\2v\= u02e1") >=20 > + buf.write("\3\2\2\2x\u02f4\3\2\2\2z\u02f7\3\2\2\2|\u0304\3\2\2\2= ") >=20 > + buf.write("~\u030e\3\2\2\2\u0080\u0318\3\2\2\2\u0082\u0333\3\2\2= ") >=20 > + buf.write("\2\u0084\u0335\3\2\2\2\u0086\u0342\3\2\2\2\u0088\u034= a") >=20 > + buf.write("\3\2\2\2\u008a\u035c\3\2\2\2\u008c\u036e\3\2\2\2\u008= e") >=20 > + buf.write("\u037d\3\2\2\2\u0090\u0092\5\4\3\2\u0091\u0090\3\2\2\= 2") >=20 > + buf.write("\u0092\u0095\3\2\2\2\u0093\u0091\3\2\2\2\u0093\u0094\= 3") >=20 > + buf.write("\2\2\2\u0094\3\3\2\2\2\u0095\u0093\3\2\2\2\u0096\u009= 8") >=20 > + buf.write("\5\b\5\2\u0097\u0096\3\2\2\2\u0097\u0098\3\2\2\2\u009= 8") >=20 > + buf.write("\u0099\3\2\2\2\u0099\u009d\5,\27\2\u009a\u009c\5\n\6\= 2") >=20 > + buf.write("\u009b\u009a\3\2\2\2\u009c\u009f\3\2\2\2\u009d\u009b\= 3") >=20 > + buf.write("\2\2\2\u009d\u009e\3\2\2\2\u009e\u00a0\3\2\2\2\u009f\= u009d") >=20 > + buf.write("\3\2\2\2\u00a0\u00a1\7\3\2\2\u00a1\u00a9\3\2\2\2\u00a= 2") >=20 > + buf.write("\u00a9\5\6\4\2\u00a3\u00a9\5\n\6\2\u00a4\u00a6\5\u008= 0") >=20 > + buf.write("A\2\u00a5\u00a7\7\4\2\2\u00a6\u00a5\3\2\2\2\u00a6\u00= a7") >=20 > + buf.write("\3\2\2\2\u00a7\u00a9\3\2\2\2\u00a8\u0097\3\2\2\2\u00a= 8") >=20 > + buf.write("\u00a2\3\2\2\2\u00a8\u00a3\3\2\2\2\u00a8\u00a4\3\2\2\= 2") >=20 > + buf.write("\u00a9\5\3\2\2\2\u00aa\u00ac\5\b\5\2\u00ab\u00aa\3\2\= 2") >=20 > + buf.write("\2\u00ab\u00ac\3\2\2\2\u00ac\u00ad\3\2\2\2\u00ad\u00b= 6") >=20 > + buf.write("\5,\27\2\u00ae\u00b0\5\n\6\2\u00af\u00ae\3\2\2\2\u00b= 0") >=20 > + buf.write("\u00b1\3\2\2\2\u00b1\u00af\3\2\2\2\u00b1\u00b2\3\2\2\= 2") >=20 > + buf.write("\u00b2\u00b3\3\2\2\2\u00b3\u00b4\5\u0084C\2\u00b4\u00= b7") >=20 > + buf.write("\3\2\2\2\u00b5\u00b7\5\u0084C\2\u00b6\u00af\3\2\2\2\u= 00b6") >=20 > + buf.write("\u00b5\3\2\2\2\u00b7\u00b8\3\2\2\2\u00b8\u00b9\b\4\1\= 2") >=20 > + buf.write("\u00b9\7\3\2\2\2\u00ba\u00be\5\20\t\2\u00bb\u00be\5\2= 2") >=20 > + buf.write("\n\2\u00bc\u00be\5*\26\2\u00bd\u00ba\3\2\2\2\u00bd\u0= 0bb") >=20 > + buf.write("\3\2\2\2\u00bd\u00bc\3\2\2\2\u00be\u00bf\3\2\2\2\u00b= f") >=20 > + buf.write("\u00bd\3\2\2\2\u00bf\u00c0\3\2\2\2\u00c0\t\3\2\2\2\u0= 0c1") >=20 > + buf.write("\u00c3\7\5\2\2\u00c2\u00c4\5\b\5\2\u00c3\u00c2\3\2\2\= 2") >=20 > + buf.write("\u00c3\u00c4\3\2\2\2\u00c4\u00c5\3\2\2\2\u00c5\u00c6\= 5") >=20 > + buf.write("\f\7\2\u00c6\u00c7\7\4\2\2\u00c7\u00c8\b\6\1\2\u00c8\= u00d1") >=20 > + buf.write("\3\2\2\2\u00c9\u00cb\5\b\5\2\u00ca\u00cc\5\f\7\2\u00c= b") >=20 > + buf.write("\u00ca\3\2\2\2\u00cb\u00cc\3\2\2\2\u00cc\u00cd\3\2\2\= 2") >=20 > + buf.write("\u00cd\u00ce\7\4\2\2\u00ce\u00cf\b\6\1\2\u00cf\u00d1\= 3") >=20 > + buf.write("\2\2\2\u00d0\u00c1\3\2\2\2\u00d0\u00c9\3\2\2\2\u00d1\= 13") >=20 > + buf.write("\3\2\2\2\u00d2\u00d7\5\16\b\2\u00d3\u00d4\7\6\2\2\u00= d4") >=20 > + buf.write("\u00d6\5\16\b\2\u00d5\u00d3\3\2\2\2\u00d6\u00d9\3\2\2= ") >=20 > + buf.write("\2\u00d7\u00d5\3\2\2\2\u00d7\u00d8\3\2\2\2\u00d8\r\3\= 2") >=20 > + buf.write("\2\2\u00d9\u00d7\3\2\2\2\u00da\u00dd\5,\27\2\u00db\u0= 0dc") >=20 > + buf.write("\7\7\2\2\u00dc\u00de\5D#\2\u00dd\u00db\3\2\2\2\u00dd\= u00de") >=20 > + buf.write("\3\2\2\2\u00de\17\3\2\2\2\u00df\u00e0\t\2\2\2\u00e0\2= 1") >=20 > + buf.write("\3\2\2\2\u00e1\u00fa\7\r\2\2\u00e2\u00fa\7\16\2\2\u00= e3") >=20 > + buf.write("\u00fa\7\17\2\2\u00e4\u00fa\7\20\2\2\u00e5\u00fa\7\21= ") >=20 > + buf.write("\2\2\u00e6\u00fa\7\22\2\2\u00e7\u00fa\7\23\2\2\u00e8\= u00fa") >=20 > + buf.write("\7\24\2\2\u00e9\u00fa\7\25\2\2\u00ea\u00eb\5\26\f\2\u= 00eb") >=20 > + buf.write("\u00ec\b\n\1\2\u00ec\u00fa\3\2\2\2\u00ed\u00ee\5$\23\= 2") >=20 > + buf.write("\u00ee\u00ef\b\n\1\2\u00ef\u00fa\3\2\2\2\u00f0\u00f4\= 7") >=20 > + buf.write("_\2\2\u00f1\u00f3\5*\26\2\u00f2\u00f1\3\2\2\2\u00f3\u= 00f6") >=20 > + buf.write("\3\2\2\2\u00f4\u00f2\3\2\2\2\u00f4\u00f5\3\2\2\2\u00f= 5") >=20 > + buf.write("\u00f7\3\2\2\2\u00f6\u00f4\3\2\2\2\u00f7\u00fa\5,\27\= 2") >=20 > + buf.write("\u00f8\u00fa\5\24\13\2\u00f9\u00e1\3\2\2\2\u00f9\u00e= 2") >=20 > + buf.write("\3\2\2\2\u00f9\u00e3\3\2\2\2\u00f9\u00e4\3\2\2\2\u00f= 9") >=20 > + buf.write("\u00e5\3\2\2\2\u00f9\u00e6\3\2\2\2\u00f9\u00e7\3\2\2\= 2") >=20 > + buf.write("\u00f9\u00e8\3\2\2\2\u00f9\u00e9\3\2\2\2\u00f9\u00ea\= 3") >=20 > + buf.write("\2\2\2\u00f9\u00ed\3\2\2\2\u00f9\u00f0\3\2\2\2\u00f9\= u00f8") >=20 > + buf.write("\3\2\2\2\u00fa\23\3\2\2\2\u00fb\u00fc\7_\2\2\u00fc\25= ") >=20 > + buf.write("\3\2\2\2\u00fd\u00ff\5\30\r\2\u00fe\u0100\7_\2\2\u00f= f") >=20 > + buf.write("\u00fe\3\2\2\2\u00ff\u0100\3\2\2\2\u0100\u0101\3\2\2\= 2") >=20 > + buf.write("\u0101\u0102\7\3\2\2\u0102\u0103\5\32\16\2\u0103\u010= 4") >=20 > + buf.write("\7\26\2\2\u0104\u0109\3\2\2\2\u0105\u0106\5\30\r\2\u0= 106") >=20 > + buf.write("\u0107\7_\2\2\u0107\u0109\3\2\2\2\u0108\u00fd\3\2\2\2= ") >=20 > + buf.write("\u0108\u0105\3\2\2\2\u0109\27\3\2\2\2\u010a\u010b\t\3= ") >=20 > + buf.write("\2\2\u010b\31\3\2\2\2\u010c\u010e\5\34\17\2\u010d\u01= 0c") >=20 > + buf.write("\3\2\2\2\u010e\u010f\3\2\2\2\u010f\u010d\3\2\2\2\u010= f") >=20 > + buf.write("\u0110\3\2\2\2\u0110\33\3\2\2\2\u0111\u0112\5\36\20\2= ") >=20 > + buf.write("\u0112\u0113\5 \21\2\u0113\u0114\7\4\2\2\u0114\35\3\2= ") >=20 > + buf.write("\2\2\u0115\u0118\5*\26\2\u0116\u0118\5\22\n\2\u0117\u= 0115") >=20 > + buf.write("\3\2\2\2\u0117\u0116\3\2\2\2\u0118\u0119\3\2\2\2\u011= 9") >=20 > + buf.write("\u0117\3\2\2\2\u0119\u011a\3\2\2\2\u011a\37\3\2\2\2\u= 011b") >=20 > + buf.write("\u0120\5\"\22\2\u011c\u011d\7\6\2\2\u011d\u011f\5\"\2= 2") >=20 > + buf.write("\2\u011e\u011c\3\2\2\2\u011f\u0122\3\2\2\2\u0120\u011= e") >=20 > + buf.write("\3\2\2\2\u0120\u0121\3\2\2\2\u0121!\3\2\2\2\u0122\u01= 20") >=20 > + buf.write("\3\2\2\2\u0123\u0126\5,\27\2\u0124\u0125\7\31\2\2\u01= 25") >=20 > + buf.write("\u0127\5^\60\2\u0126\u0124\3\2\2\2\u0126\u0127\3\2\2\= 2") >=20 > + buf.write("\u0127\u012b\3\2\2\2\u0128\u0129\7\31\2\2\u0129\u012b= ") >=20 > + buf.write("\5^\60\2\u012a\u0123\3\2\2\2\u012a\u0128\3\2\2\2\u012= b") >=20 > + buf.write("#\3\2\2\2\u012c\u012d\7\32\2\2\u012d\u012e\7\3\2\2\u0= 12e") >=20 > + buf.write("\u0130\5&\24\2\u012f\u0131\7\6\2\2\u0130\u012f\3\2\2\= 2") >=20 > + buf.write("\u0130\u0131\3\2\2\2\u0131\u0132\3\2\2\2\u0132\u0133\= 7") >=20 > + buf.write("\26\2\2\u0133\u0140\3\2\2\2\u0134\u0135\7\32\2\2\u013= 5") >=20 > + buf.write("\u0136\7_\2\2\u0136\u0137\7\3\2\2\u0137\u0139\5&\24\2= ") >=20 > + buf.write("\u0138\u013a\7\6\2\2\u0139\u0138\3\2\2\2\u0139\u013a\= 3") >=20 > + buf.write("\2\2\2\u013a\u013b\3\2\2\2\u013b\u013c\7\26\2\2\u013c= ") >=20 > + buf.write("\u0140\3\2\2\2\u013d\u013e\7\32\2\2\u013e\u0140\7_\2\= 2") >=20 > + buf.write("\u013f\u012c\3\2\2\2\u013f\u0134\3\2\2\2\u013f\u013d\= 3") >=20 > + buf.write("\2\2\2\u0140%\3\2\2\2\u0141\u0146\5(\25\2\u0142\u0143= ") >=20 > + buf.write("\7\6\2\2\u0143\u0145\5(\25\2\u0144\u0142\3\2\2\2\u014= 5") >=20 > + buf.write("\u0148\3\2\2\2\u0146\u0144\3\2\2\2\u0146\u0147\3\2\2\= 2") >=20 > + buf.write("\u0147\'\3\2\2\2\u0148\u0146\3\2\2\2\u0149\u014c\7_\2= ") >=20 > + buf.write("\2\u014a\u014b\7\7\2\2\u014b\u014d\5^\60\2\u014c\u014= a") >=20 > + buf.write("\3\2\2\2\u014c\u014d\3\2\2\2\u014d)\3\2\2\2\u014e\u01= 4f") >=20 > + buf.write("\t\4\2\2\u014f+\3\2\2\2\u0150\u0152\5\62\32\2\u0151\u= 0150") >=20 > + buf.write("\3\2\2\2\u0151\u0152\3\2\2\2\u0152\u0154\3\2\2\2\u015= 3") >=20 > + buf.write("\u0155\7$\2\2\u0154\u0153\3\2\2\2\u0154\u0155\3\2\2\2= ") >=20 > + buf.write("\u0155\u0157\3\2\2\2\u0156\u0158\7%\2\2\u0157\u0156\3= ") >=20 > + buf.write("\2\2\2\u0157\u0158\3\2\2\2\u0158\u015a\3\2\2\2\u0159\= u015b") >=20 > + buf.write("\7&\2\2\u015a\u0159\3\2\2\2\u015a\u015b\3\2\2\2\u015b= ") >=20 > + buf.write("\u015c\3\2\2\2\u015c\u015f\5.\30\2\u015d\u015f\5\62\3= 2") >=20 > + buf.write("\2\u015e\u0151\3\2\2\2\u015e\u015d\3\2\2\2\u015f-\3\2= ") >=20 > + buf.write("\2\2\u0160\u0164\7_\2\2\u0161\u0163\5\60\31\2\u0162\u= 0161") >=20 > + buf.write("\3\2\2\2\u0163\u0166\3\2\2\2\u0164\u0162\3\2\2\2\u016= 4") >=20 > + buf.write("\u0165\3\2\2\2\u0165\u0173\3\2\2\2\u0166\u0164\3\2\2\= 2") >=20 > + buf.write("\u0167\u0169\7(\2\2\u0168\u016a\7$\2\2\u0169\u0168\3\= 2") >=20 > + buf.write("\2\2\u0169\u016a\3\2\2\2\u016a\u016b\3\2\2\2\u016b\u0= 16c") >=20 > + buf.write("\5,\27\2\u016c\u016e\7)\2\2\u016d\u016f\5\60\31\2\u01= 6e") >=20 > + buf.write("\u016d\3\2\2\2\u016f\u0170\3\2\2\2\u0170\u016e\3\2\2\= 2") >=20 > + buf.write("\u0170\u0171\3\2\2\2\u0171\u0173\3\2\2\2\u0172\u0160\= 3") >=20 > + buf.write("\2\2\2\u0172\u0167\3\2\2\2\u0173/\3\2\2\2\u0174\u0175= ") >=20 > + buf.write("\7*\2\2\u0175\u0176\5^\60\2\u0176\u0177\7+\2\2\u0177\= u0185") >=20 > + buf.write("\3\2\2\2\u0178\u0179\7*\2\2\u0179\u0185\7+\2\2\u017a\= u017b") >=20 > + buf.write("\7(\2\2\u017b\u017c\5\64\33\2\u017c\u017d\7)\2\2\u017= d") >=20 > + buf.write("\u0185\3\2\2\2\u017e\u017f\7(\2\2\u017f\u0180\5:\36\2= ") >=20 > + buf.write("\u0180\u0181\7)\2\2\u0181\u0185\3\2\2\2\u0182\u0183\7= ") >=20 > + buf.write("(\2\2\u0183\u0185\7)\2\2\u0184\u0174\3\2\2\2\u0184\u0= 178") >=20 > + buf.write("\3\2\2\2\u0184\u017a\3\2\2\2\u0184\u017e\3\2\2\2\u018= 4") >=20 > + buf.write("\u0182\3\2\2\2\u0185\61\3\2\2\2\u0186\u0188\7,\2\2\u0= 187") >=20 > + buf.write("\u0189\5*\26\2\u0188\u0187\3\2\2\2\u0189\u018a\3\2\2\= 2") >=20 > + buf.write("\u018a\u0188\3\2\2\2\u018a\u018b\3\2\2\2\u018b\u018d\= 3") >=20 > + buf.write("\2\2\2\u018c\u018e\5\62\32\2\u018d\u018c\3\2\2\2\u018= d") >=20 > + buf.write("\u018e\3\2\2\2\u018e\u0193\3\2\2\2\u018f\u0190\7,\2\2= ") >=20 > + buf.write("\u0190\u0193\5\62\32\2\u0191\u0193\7,\2\2\u0192\u0186= ") >=20 > + buf.write("\3\2\2\2\u0192\u018f\3\2\2\2\u0192\u0191\3\2\2\2\u019= 3") >=20 > + buf.write("\63\3\2\2\2\u0194\u019a\5\66\34\2\u0195\u0197\7\6\2\2= ") >=20 > + buf.write("\u0196\u0198\7\37\2\2\u0197\u0196\3\2\2\2\u0197\u0198= ") >=20 > + buf.write("\3\2\2\2\u0198\u0199\3\2\2\2\u0199\u019b\7-\2\2\u019a= ") >=20 > + buf.write("\u0195\3\2\2\2\u019a\u019b\3\2\2\2\u019b\65\3\2\2\2\u= 019c") >=20 > + buf.write("\u01a4\58\35\2\u019d\u019f\7\6\2\2\u019e\u01a0\7\37\2= ") >=20 > + buf.write("\2\u019f\u019e\3\2\2\2\u019f\u01a0\3\2\2\2\u01a0\u01a= 1") >=20 > + buf.write("\3\2\2\2\u01a1\u01a3\58\35\2\u01a2\u019d\3\2\2\2\u01a= 3") >=20 > + buf.write("\u01a6\3\2\2\2\u01a4\u01a2\3\2\2\2\u01a4\u01a5\3\2\2\= 2") >=20 > + buf.write("\u01a5\67\3\2\2\2\u01a6\u01a4\3\2\2\2\u01a7\u01ac\5\b= ") >=20 > + buf.write("\5\2\u01a8\u01ab\5,\27\2\u01a9\u01ab\5> \2\u01aa\u01a= 8") >=20 > + buf.write("\3\2\2\2\u01aa\u01a9\3\2\2\2\u01ab\u01ae\3\2\2\2\u01a= c") >=20 > + buf.write("\u01aa\3\2\2\2\u01ac\u01ad\3\2\2\2\u01ad\u01b0\3\2\2\= 2") >=20 > + buf.write("\u01ae\u01ac\3\2\2\2\u01af\u01b1\7\37\2\2\u01b0\u01af= ") >=20 > + buf.write("\3\2\2\2\u01b0\u01b1\3\2\2\2\u01b1\u01ba\3\2\2\2\u01b= 2") >=20 > + buf.write("\u01b4\5\62\32\2\u01b3\u01b2\3\2\2\2\u01b4\u01b7\3\2\= 2") >=20 > + buf.write("\2\u01b5\u01b3\3\2\2\2\u01b5\u01b6\3\2\2\2\u01b6\u01b= 8") >=20 > + buf.write("\3\2\2\2\u01b7\u01b5\3\2\2\2\u01b8\u01ba\7_\2\2\u01b9= ") >=20 > + buf.write("\u01a7\3\2\2\2\u01b9\u01b5\3\2\2\2\u01ba9\3\2\2\2\u01= bb") >=20 > + buf.write("\u01c0\7_\2\2\u01bc\u01bd\7\6\2\2\u01bd\u01bf\7_\2\2\= u01be") >=20 > + buf.write("\u01bc\3\2\2\2\u01bf\u01c2\3\2\2\2\u01c0\u01be\3\2\2\= 2") >=20 > + buf.write("\u01c0\u01c1\3\2\2\2\u01c1;\3\2\2\2\u01c2\u01c0\3\2\2= ") >=20 > + buf.write("\2\u01c3\u01c5\5\36\20\2\u01c4\u01c6\5> \2\u01c5\u01c= 4") >=20 > + buf.write("\3\2\2\2\u01c5\u01c6\3\2\2\2\u01c6\u01c9\3\2\2\2\u01c= 7") >=20 > + buf.write("\u01c9\5\24\13\2\u01c8\u01c3\3\2\2\2\u01c8\u01c7\3\2\= 2") >=20 > + buf.write("\2\u01c9=3D\3\2\2\2\u01ca\u01cc\5\62\32\2\u01cb\u01cd= \5") >=20 > + buf.write("@!\2\u01cc\u01cb\3\2\2\2\u01cc\u01cd\3\2\2\2\u01cd\u0= 1d0") >=20 > + buf.write("\3\2\2\2\u01ce\u01d0\5@!\2\u01cf\u01ca\3\2\2\2\u01cf\= u01ce") >=20 > + buf.write("\3\2\2\2\u01d0?\3\2\2\2\u01d1\u01d2\7(\2\2\u01d2\u01d= 3") >=20 > + buf.write("\5> \2\u01d3\u01d4\7)\2\2\u01d4\u01d7\3\2\2\2\u01d5\u= 01d7") >=20 > + buf.write("\5B\"\2\u01d6\u01d1\3\2\2\2\u01d6\u01d5\3\2\2\2\u01d7= ") >=20 > + buf.write("\u01db\3\2\2\2\u01d8\u01da\5B\"\2\u01d9\u01d8\3\2\2\2= ") >=20 > + buf.write("\u01da\u01dd\3\2\2\2\u01db\u01d9\3\2\2\2\u01db\u01dc\= 3") >=20 > + buf.write("\2\2\2\u01dcA\3\2\2\2\u01dd\u01db\3\2\2\2\u01de\u01df= ") >=20 > + buf.write("\7*\2\2\u01df\u01eb\7+\2\2\u01e0\u01e1\7*\2\2\u01e1\u= 01e2") >=20 > + buf.write("\5^\60\2\u01e2\u01e3\7+\2\2\u01e3\u01eb\3\2\2\2\u01e4= ") >=20 > + buf.write("\u01e5\7(\2\2\u01e5\u01eb\7)\2\2\u01e6\u01e7\7(\2\2\u= 01e7") >=20 > + buf.write("\u01e8\5\64\33\2\u01e8\u01e9\7)\2\2\u01e9\u01eb\3\2\2= ") >=20 > + buf.write("\2\u01ea\u01de\3\2\2\2\u01ea\u01e0\3\2\2\2\u01ea\u01e= 4") >=20 > + buf.write("\3\2\2\2\u01ea\u01e6\3\2\2\2\u01ebC\3\2\2\2\u01ec\u01= f5") >=20 > + buf.write("\5`\61\2\u01ed\u01ee\7\3\2\2\u01ee\u01f0\5F$\2\u01ef\= u01f1") >=20 > + buf.write("\7\6\2\2\u01f0\u01ef\3\2\2\2\u01f0\u01f1\3\2\2\2\u01f= 1") >=20 > + buf.write("\u01f2\3\2\2\2\u01f2\u01f3\7\26\2\2\u01f3\u01f5\3\2\2= ") >=20 > + buf.write("\2\u01f4\u01ec\3\2\2\2\u01f4\u01ed\3\2\2\2\u01f5E\3\2= ") >=20 > + buf.write("\2\2\u01f6\u01fb\5D#\2\u01f7\u01f8\7\6\2\2\u01f8\u01f= a") >=20 > + buf.write("\5D#\2\u01f9\u01f7\3\2\2\2\u01fa\u01fd\3\2\2\2\u01fb\= u01f9") >=20 > + buf.write("\3\2\2\2\u01fb\u01fc\3\2\2\2\u01fcG\3\2\2\2\u01fd\u01= fb") >=20 > + buf.write("\3\2\2\2\u01fe\u0200\5`\61\2\u01ff\u0201\7\37\2\2\u02= 00") >=20 > + buf.write("\u01ff\3\2\2\2\u0200\u0201\3\2\2\2\u0201\u0209\3\2\2\= 2") >=20 > + buf.write("\u0202\u0203\7\6\2\2\u0203\u0205\5`\61\2\u0204\u0206\= 7") >=20 > + buf.write("\37\2\2\u0205\u0204\3\2\2\2\u0205\u0206\3\2\2\2\u0206= ") >=20 > + buf.write("\u0208\3\2\2\2\u0207\u0202\3\2\2\2\u0208\u020b\3\2\2\= 2") >=20 > + buf.write("\u0209\u0207\3\2\2\2\u0209\u020a\3\2\2\2\u020aI\3\2\2= ") >=20 > + buf.write("\2\u020b\u0209\3\2\2\2\u020c\u0213\5L\'\2\u020d\u020e= ") >=20 > + buf.write("\7.\2\2\u020e\u0212\5L\'\2\u020f\u0210\7/\2\2\u0210\u= 0212") >=20 > + buf.write("\5L\'\2\u0211\u020d\3\2\2\2\u0211\u020f\3\2\2\2\u0212= ") >=20 > + buf.write("\u0215\3\2\2\2\u0213\u0211\3\2\2\2\u0213\u0214\3\2\2\= 2") >=20 > + buf.write("\u0214K\3\2\2\2\u0215\u0213\3\2\2\2\u0216\u021f\5N(\2= ") >=20 > + buf.write("\u0217\u0218\7,\2\2\u0218\u021e\5N(\2\u0219\u021a\7\6= 0") >=20 > + buf.write("\2\2\u021a\u021e\5N(\2\u021b\u021c\7\61\2\2\u021c\u02= 1e") >=20 > + buf.write("\5N(\2\u021d\u0217\3\2\2\2\u021d\u0219\3\2\2\2\u021d\= u021b") >=20 > + buf.write("\3\2\2\2\u021e\u0221\3\2\2\2\u021f\u021d\3\2\2\2\u021= f") >=20 > + buf.write("\u0220\3\2\2\2\u0220M\3\2\2\2\u0221\u021f\3\2\2\2\u02= 22") >=20 > + buf.write("\u0223\7(\2\2\u0223\u0224\5<\37\2\u0224\u0225\7)\2\2\= u0225") >=20 > + buf.write("\u0226\5N(\2\u0226\u0229\3\2\2\2\u0227\u0229\5P)\2\u0= 228") >=20 > + buf.write("\u0222\3\2\2\2\u0228\u0227\3\2\2\2\u0229O\3\2\2\2\u02= 2a") >=20 > + buf.write("\u023a\5R*\2\u022b\u022c\7\62\2\2\u022c\u023a\5P)\2\u= 022d") >=20 > + buf.write("\u022e\7\63\2\2\u022e\u023a\5P)\2\u022f\u0230\5V,\2\u= 0230") >=20 > + buf.write("\u0231\5N(\2\u0231\u023a\3\2\2\2\u0232\u0233\7\64\2\2= ") >=20 > + buf.write("\u0233\u023a\5P)\2\u0234\u0235\7\64\2\2\u0235\u0236\7= ") >=20 > + buf.write("(\2\2\u0236\u0237\5<\37\2\u0237\u0238\7)\2\2\u0238\u0= 23a") >=20 > + buf.write("\3\2\2\2\u0239\u022a\3\2\2\2\u0239\u022b\3\2\2\2\u023= 9") >=20 > + buf.write("\u022d\3\2\2\2\u0239\u022f\3\2\2\2\u0239\u0232\3\2\2\= 2") >=20 > + buf.write("\u0239\u0234\3\2\2\2\u023aQ\3\2\2\2\u023b\u023c\5X-\2= ") >=20 > + buf.write("\u023c\u025a\b*\1\2\u023d\u023e\7*\2\2\u023e\u023f\5\= \") >=20 > + buf.write("/\2\u023f\u0240\7+\2\2\u0240\u0259\3\2\2\2\u0241\u024= 2") >=20 > + buf.write("\7(\2\2\u0242\u0243\7)\2\2\u0243\u0259\b*\1\2\u0244\u= 0245") >=20 > + buf.write("\7(\2\2\u0245\u0246\5H%\2\u0246\u0247\7)\2\2\u0247\u0= 248") >=20 > + buf.write("\b*\1\2\u0248\u0259\3\2\2\2\u0249\u024a\7(\2\2\u024a\= u024b") >=20 > + buf.write("\5T+\2\u024b\u024c\7)\2\2\u024c\u0259\3\2\2\2\u024d\u= 024e") >=20 > + buf.write("\7\65\2\2\u024e\u024f\7_\2\2\u024f\u0259\b*\1\2\u0250= ") >=20 > + buf.write("\u0251\7,\2\2\u0251\u0252\7_\2\2\u0252\u0259\b*\1\2\u= 0253") >=20 > + buf.write("\u0254\7\66\2\2\u0254\u0255\7_\2\2\u0255\u0259\b*\1\2= ") >=20 > + buf.write("\u0256\u0259\7\62\2\2\u0257\u0259\7\63\2\2\u0258\u023= d") >=20 > + buf.write("\3\2\2\2\u0258\u0241\3\2\2\2\u0258\u0244\3\2\2\2\u025= 8") >=20 > + buf.write("\u0249\3\2\2\2\u0258\u024d\3\2\2\2\u0258\u0250\3\2\2\= 2") >=20 > + buf.write("\u0258\u0253\3\2\2\2\u0258\u0256\3\2\2\2\u0258\u0257\= 3") >=20 > + buf.write("\2\2\2\u0259\u025c\3\2\2\2\u025a\u0258\3\2\2\2\u025a\= u025b") >=20 > + buf.write("\3\2\2\2\u025bS\3\2\2\2\u025c\u025a\3\2\2\2\u025d\u02= 62") >=20 > + buf.write("\58\35\2\u025e\u025f\7\6\2\2\u025f\u0261\58\35\2\u026= 0") >=20 > + buf.write("\u025e\3\2\2\2\u0261\u0264\3\2\2\2\u0262\u0260\3\2\2\= 2") >=20 > + buf.write("\u0262\u0263\3\2\2\2\u0263U\3\2\2\2\u0264\u0262\3\2\2= ") >=20 > + buf.write("\2\u0265\u0266\t\5\2\2\u0266W\3\2\2\2\u0267\u026e\7_\= 2") >=20 > + buf.write("\2\u0268\u026e\5Z.\2\u0269\u026a\7(\2\2\u026a\u026b\5= ") >=20 > + buf.write("\\/\2\u026b\u026c\7)\2\2\u026c\u026e\3\2\2\2\u026d\u0= 267") >=20 > + buf.write("\3\2\2\2\u026d\u0268\3\2\2\2\u026d\u0269\3\2\2\2\u026= e") >=20 > + buf.write("Y\3\2\2\2\u026f\u028a\7b\2\2\u0270\u028a\7d\2\2\u0271= ") >=20 > + buf.write("\u028a\7c\2\2\u0272\u028a\7`\2\2\u0273\u0275\7_\2\2\u= 0274") >=20 > + buf.write("\u0273\3\2\2\2\u0275\u0278\3\2\2\2\u0276\u0274\3\2\2\= 2") >=20 > + buf.write("\u0276\u0277\3\2\2\2\u0277\u027a\3\2\2\2\u0278\u0276\= 3") >=20 > + buf.write("\2\2\2\u0279\u027b\7a\2\2\u027a\u0279\3\2\2\2\u027b\u= 027c") >=20 > + buf.write("\3\2\2\2\u027c\u027a\3\2\2\2\u027c\u027d\3\2\2\2\u027= d") >=20 > + buf.write("\u027f\3\2\2\2\u027e\u0276\3\2\2\2\u027f\u0280\3\2\2\= 2") >=20 > + buf.write("\u0280\u027e\3\2\2\2\u0280\u0281\3\2\2\2\u0281\u0285\= 3") >=20 > + buf.write("\2\2\2\u0282\u0284\7_\2\2\u0283\u0282\3\2\2\2\u0284\u= 0287") >=20 > + buf.write("\3\2\2\2\u0285\u0283\3\2\2\2\u0285\u0286\3\2\2\2\u028= 6") >=20 > + buf.write("\u028a\3\2\2\2\u0287\u0285\3\2\2\2\u0288\u028a\7e\2\2= ") >=20 > + buf.write("\u0289\u026f\3\2\2\2\u0289\u0270\3\2\2\2\u0289\u0271\= 3") >=20 > + buf.write("\2\2\2\u0289\u0272\3\2\2\2\u0289\u027e\3\2\2\2\u0289\= u0288") >=20 > + buf.write("\3\2\2\2\u028a[\3\2\2\2\u028b\u0290\5`\61\2\u028c\u02= 8d") >=20 > + buf.write("\7\6\2\2\u028d\u028f\5`\61\2\u028e\u028c\3\2\2\2\u028= f") >=20 > + buf.write("\u0292\3\2\2\2\u0290\u028e\3\2\2\2\u0290\u0291\3\2\2\= 2") >=20 > + buf.write("\u0291]\3\2\2\2\u0292\u0290\3\2\2\2\u0293\u0294\5f\64= ") >=20 > + buf.write("\2\u0294_\3\2\2\2\u0295\u0296\5b\62\2\u0296\u0297\5d\= 63") >=20 > + buf.write("\2\u0297\u0298\5`\61\2\u0298\u029b\3\2\2\2\u0299\u029= b") >=20 > + buf.write("\5f\64\2\u029a\u0295\3\2\2\2\u029a\u0299\3\2\2\2\u029= b") >=20 > + buf.write("a\3\2\2\2\u029c\u029d\5P)\2\u029dc\3\2\2\2\u029e\u029= f") >=20 > + buf.write("\t\6\2\2\u029fe\3\2\2\2\u02a0\u02a7\5h\65\2\u02a1\u02= a2") >=20 > + buf.write("\7D\2\2\u02a2\u02a3\5\\/\2\u02a3\u02a4\7\31\2\2\u02a4= ") >=20 > + buf.write("\u02a5\5f\64\2\u02a5\u02a6\b\64\1\2\u02a6\u02a8\3\2\2= ") >=20 > + buf.write("\2\u02a7\u02a1\3\2\2\2\u02a7\u02a8\3\2\2\2\u02a8g\3\2= ") >=20 > + buf.write("\2\2\u02a9\u02ae\5j\66\2\u02aa\u02ab\7E\2\2\u02ab\u02= ad") >=20 > + buf.write("\5j\66\2\u02ac\u02aa\3\2\2\2\u02ad\u02b0\3\2\2\2\u02a= e") >=20 > + buf.write("\u02ac\3\2\2\2\u02ae\u02af\3\2\2\2\u02afi\3\2\2\2\u02= b0") >=20 > + buf.write("\u02ae\3\2\2\2\u02b1\u02b6\5l\67\2\u02b2\u02b3\7F\2\2= ") >=20 > + buf.write("\u02b3\u02b5\5l\67\2\u02b4\u02b2\3\2\2\2\u02b5\u02b8\= 3") >=20 > + buf.write("\2\2\2\u02b6\u02b4\3\2\2\2\u02b6\u02b7\3\2\2\2\u02b7k= ") >=20 > + buf.write("\3\2\2\2\u02b8\u02b6\3\2\2\2\u02b9\u02be\5n8\2\u02ba\= u02bb") >=20 > + buf.write("\7G\2\2\u02bb\u02bd\5n8\2\u02bc\u02ba\3\2\2\2\u02bd\u= 02c0") >=20 > + buf.write("\3\2\2\2\u02be\u02bc\3\2\2\2\u02be\u02bf\3\2\2\2\u02b= f") >=20 > + buf.write("m\3\2\2\2\u02c0\u02be\3\2\2\2\u02c1\u02c6\5p9\2\u02c2= ") >=20 > + buf.write("\u02c3\7H\2\2\u02c3\u02c5\5p9\2\u02c4\u02c2\3\2\2\2\u= 02c5") >=20 > + buf.write("\u02c8\3\2\2\2\u02c6\u02c4\3\2\2\2\u02c6\u02c7\3\2\2\= 2") >=20 > + buf.write("\u02c7o\3\2\2\2\u02c8\u02c6\3\2\2\2\u02c9\u02ce\5r:\2= ") >=20 > + buf.write("\u02ca\u02cb\7\67\2\2\u02cb\u02cd\5r:\2\u02cc\u02ca\3= ") >=20 > + buf.write("\2\2\2\u02cd\u02d0\3\2\2\2\u02ce\u02cc\3\2\2\2\u02ce\= u02cf") >=20 > + buf.write("\3\2\2\2\u02cfq\3\2\2\2\u02d0\u02ce\3\2\2\2\u02d1\u02= d6") >=20 > + buf.write("\5t;\2\u02d2\u02d3\t\7\2\2\u02d3\u02d5\5t;\2\u02d4\u0= 2d2") >=20 > + buf.write("\3\2\2\2\u02d5\u02d8\3\2\2\2\u02d6\u02d4\3\2\2\2\u02d= 6") >=20 > + buf.write("\u02d7\3\2\2\2\u02d7s\3\2\2\2\u02d8\u02d6\3\2\2\2\u02= d9") >=20 > + buf.write("\u02de\5v<\2\u02da\u02db\t\b\2\2\u02db\u02dd\5v<\2\u0= 2dc") >=20 > + buf.write("\u02da\3\2\2\2\u02dd\u02e0\3\2\2\2\u02de\u02dc\3\2\2\= 2") >=20 > + buf.write("\u02de\u02df\3\2\2\2\u02dfu\3\2\2\2\u02e0\u02de\3\2\2= ") >=20 > + buf.write("\2\u02e1\u02e6\5J&\2\u02e2\u02e3\t\t\2\2\u02e3\u02e5\= 5") >=20 > + buf.write("J&\2\u02e4\u02e2\3\2\2\2\u02e5\u02e8\3\2\2\2\u02e6\u0= 2e4") >=20 > + buf.write("\3\2\2\2\u02e6\u02e7\3\2\2\2\u02e7w\3\2\2\2\u02e8\u02= e6") >=20 > + buf.write("\3\2\2\2\u02e9\u02f5\5\u0082B\2\u02ea\u02f5\5\u0084C\= 2") >=20 > + buf.write("\u02eb\u02f5\5\u0088E\2\u02ec\u02f5\5\u008aF\2\u02ed\= u02f5") >=20 > + buf.write("\5\u008cG\2\u02ee\u02f5\5\u008eH\2\u02ef\u02f5\5\u008= 0") >=20 > + buf.write("A\2\u02f0\u02f5\5z>\2\u02f1\u02f5\5|?\2\u02f2\u02f5\5= ") >=20 > + buf.write("~@\2\u02f3\u02f5\5\n\6\2\u02f4\u02e9\3\2\2\2\u02f4\u0= 2ea") >=20 > + buf.write("\3\2\2\2\u02f4\u02eb\3\2\2\2\u02f4\u02ec\3\2\2\2\u02f= 4") >=20 > + buf.write("\u02ed\3\2\2\2\u02f4\u02ee\3\2\2\2\u02f4\u02ef\3\2\2\= 2") >=20 > + buf.write("\u02f4\u02f0\3\2\2\2\u02f4\u02f1\3\2\2\2\u02f4\u02f2\= 3") >=20 > + buf.write("\2\2\2\u02f4\u02f3\3\2\2\2\u02f5y\3\2\2\2\u02f6\u02f8= ") >=20 > + buf.write("\7Q\2\2\u02f7\u02f6\3\2\2\2\u02f7\u02f8\3\2\2\2\u02f8= ") >=20 > + buf.write("\u02f9\3\2\2\2\u02f9\u02fa\7_\2\2\u02fa\u02fe\7(\2\2\= u02fb") >=20 > + buf.write("\u02fd\n\n\2\2\u02fc\u02fb\3\2\2\2\u02fd\u0300\3\2\2\= 2") >=20 > + buf.write("\u02fe\u02fc\3\2\2\2\u02fe\u02ff\3\2\2\2\u02ff\u0301\= 3") >=20 > + buf.write("\2\2\2\u0300\u02fe\3\2\2\2\u0301\u0302\7)\2\2\u0302\u= 0303") >=20 > + buf.write("\7\4\2\2\u0303{\3\2\2\2\u0304\u0305\7R\2\2\u0305\u030= 9") >=20 > + buf.write("\7\3\2\2\u0306\u0308\n\13\2\2\u0307\u0306\3\2\2\2\u03= 08") >=20 > + buf.write("\u030b\3\2\2\2\u0309\u0307\3\2\2\2\u0309\u030a\3\2\2\= 2") >=20 > + buf.write("\u030a\u030c\3\2\2\2\u030b\u0309\3\2\2\2\u030c\u030d\= 7") >=20 > + buf.write("\26\2\2\u030d}\3\2\2\2\u030e\u030f\7S\2\2\u030f\u0313= ") >=20 > + buf.write("\7\3\2\2\u0310\u0312\n\13\2\2\u0311\u0310\3\2\2\2\u03= 12") >=20 > + buf.write("\u0315\3\2\2\2\u0313\u0311\3\2\2\2\u0313\u0314\3\2\2\= 2") >=20 > + buf.write("\u0314\u0316\3\2\2\2\u0315\u0313\3\2\2\2\u0316\u0317\= 7") >=20 > + buf.write("\26\2\2\u0317\177\3\2\2\2\u0318\u0319\7_\2\2\u0319\u0= 31d") >=20 > + buf.write("\7(\2\2\u031a\u031c\5\n\6\2\u031b\u031a\3\2\2\2\u031c= ") >=20 > + buf.write("\u031f\3\2\2\2\u031d\u031b\3\2\2\2\u031d\u031e\3\2\2\= 2") >=20 > + buf.write("\u031e\u0321\3\2\2\2\u031f\u031d\3\2\2\2\u0320\u0322\= 5") >=20 > + buf.write("\u0086D\2\u0321\u0320\3\2\2\2\u0321\u0322\3\2\2\2\u03= 22") >=20 > + buf.write("\u0324\3\2\2\2\u0323\u0325\5\\/\2\u0324\u0323\3\2\2\2= ") >=20 > + buf.write("\u0324\u0325\3\2\2\2\u0325\u0326\3\2\2\2\u0326\u0327\= 7") >=20 > + buf.write(")\2\2\u0327\u0081\3\2\2\2\u0328\u0329\7_\2\2\u0329\u0= 32a") >=20 > + buf.write("\7\31\2\2\u032a\u0334\5x=3D\2\u032b\u032c\7T\2\2\u032= c\u032d") >=20 > + buf.write("\5^\60\2\u032d\u032e\7\31\2\2\u032e\u032f\5x=3D\2\u03= 2f") >=20 > + buf.write("\u0334\3\2\2\2\u0330\u0331\7U\2\2\u0331\u0332\7\31\2\= 2") >=20 > + buf.write("\u0332\u0334\5x=3D\2\u0333\u0328\3\2\2\2\u0333\u032b\= 3\2") >=20 > + buf.write("\2\2\u0333\u0330\3\2\2\2\u0334\u0083\3\2\2\2\u0335\u0= 339") >=20 > + buf.write("\7\3\2\2\u0336\u0338\5\n\6\2\u0337\u0336\3\2\2\2\u033= 8") >=20 > + buf.write("\u033b\3\2\2\2\u0339\u0337\3\2\2\2\u0339\u033a\3\2\2\= 2") >=20 > + buf.write("\u033a\u033d\3\2\2\2\u033b\u0339\3\2\2\2\u033c\u033e\= 5") >=20 > + buf.write("\u0086D\2\u033d\u033c\3\2\2\2\u033d\u033e\3\2\2\2\u03= 3e") >=20 > + buf.write("\u033f\3\2\2\2\u033f\u0340\7\26\2\2\u0340\u0085\3\2\2= ") >=20 > + buf.write("\2\u0341\u0343\5x=3D\2\u0342\u0341\3\2\2\2\u0343\u034= 4\3") >=20 > + buf.write("\2\2\2\u0344\u0342\3\2\2\2\u0344\u0345\3\2\2\2\u0345\= u0087") >=20 > + buf.write("\3\2\2\2\u0346\u034b\7\4\2\2\u0347\u0348\5\\/\2\u0348= ") >=20 > + buf.write("\u0349\7\4\2\2\u0349\u034b\3\2\2\2\u034a\u0346\3\2\2\= 2") >=20 > + buf.write("\u034a\u0347\3\2\2\2\u034b\u0089\3\2\2\2\u034c\u034d\= 7") >=20 > + buf.write("V\2\2\u034d\u034e\7(\2\2\u034e\u034f\5\\/\2\u034f\u03= 50") >=20 > + buf.write("\7)\2\2\u0350\u0351\bF\1\2\u0351\u0354\5x=3D\2\u0352\= u0353") >=20 > + buf.write("\7W\2\2\u0353\u0355\5x=3D\2\u0354\u0352\3\2\2\2\u0354= \u0355") >=20 > + buf.write("\3\2\2\2\u0355\u035d\3\2\2\2\u0356\u0357\7X\2\2\u0357= ") >=20 > + buf.write("\u0358\7(\2\2\u0358\u0359\5\\/\2\u0359\u035a\7)\2\2\u= 035a") >=20 > + buf.write("\u035b\5x=3D\2\u035b\u035d\3\2\2\2\u035c\u034c\3\2\2\= 2\u035c") >=20 > + buf.write("\u0356\3\2\2\2\u035d\u008b\3\2\2\2\u035e\u035f\7Y\2\2= ") >=20 > + buf.write("\u035f\u0360\7(\2\2\u0360\u0361\5\\/\2\u0361\u0362\7)= ") >=20 > + buf.write("\2\2\u0362\u0363\5x=3D\2\u0363\u0364\bG\1\2\u0364\u03= 6f") >=20 > + buf.write("\3\2\2\2\u0365\u0366\7Z\2\2\u0366\u0367\5x=3D\2\u0367= \u0368") >=20 > + buf.write("\7Y\2\2\u0368\u0369\7(\2\2\u0369\u036a\5\\/\2\u036a\u= 036b") >=20 > + buf.write("\7)\2\2\u036b\u036c\7\4\2\2\u036c\u036d\bG\1\2\u036d\= u036f") >=20 > + buf.write("\3\2\2\2\u036e\u035e\3\2\2\2\u036e\u0365\3\2\2\2\u036= f") >=20 > + buf.write("\u008d\3\2\2\2\u0370\u0371\7[\2\2\u0371\u0372\7_\2\2\= u0372") >=20 > + buf.write("\u037e\7\4\2\2\u0373\u0374\7\\\2\2\u0374\u037e\7\4\2\= 2") >=20 > + buf.write("\u0375\u0376\7]\2\2\u0376\u037e\7\4\2\2\u0377\u0378\7= ") >=20 > + buf.write("^\2\2\u0378\u037e\7\4\2\2\u0379\u037a\7^\2\2\u037a\u0= 37b") >=20 > + buf.write("\5\\/\2\u037b\u037c\7\4\2\2\u037c\u037e\3\2\2\2\u037d= ") >=20 > + buf.write("\u0370\3\2\2\2\u037d\u0373\3\2\2\2\u037d\u0375\3\2\2\= 2") >=20 > + buf.write("\u037d\u0377\3\2\2\2\u037d\u0379\3\2\2\2\u037e\u008f\= 3") >=20 > + buf.write("\2\2\2o\u0093\u0097\u009d\u00a6\u00a8\u00ab\u00b1\u00= b6") >=20 > + buf.write("\u00bd\u00bf\u00c3\u00cb\u00d0\u00d7\u00dd\u00f4\u00f= 9") >=20 > + buf.write("\u00ff\u0108\u010f\u0117\u0119\u0120\u0126\u012a\u013= 0") >=20 > + buf.write("\u0139\u013f\u0146\u014c\u0151\u0154\u0157\u015a\u015= e") >=20 > + buf.write("\u0164\u0169\u0170\u0172\u0184\u018a\u018d\u0192\u019= 7") >=20 > + buf.write("\u019a\u019f\u01a4\u01aa\u01ac\u01b0\u01b5\u01b9\u01c= 0") >=20 > + buf.write("\u01c5\u01c8\u01cc\u01cf\u01d6\u01db\u01ea\u01f0\u01f= 4") >=20 > + buf.write("\u01fb\u0200\u0205\u0209\u0211\u0213\u021d\u021f\u022= 8") >=20 > + buf.write("\u0239\u0258\u025a\u0262\u026d\u0276\u027c\u0280\u028= 5") >=20 > + buf.write("\u0289\u0290\u029a\u02a7\u02ae\u02b6\u02be\u02c6\u02c= e") >=20 > + buf.write("\u02d6\u02de\u02e6\u02f4\u02f7\u02fe\u0309\u0313\u031= d") >=20 > + buf.write("\u0321\u0324\u0333\u0339\u033d\u0344\u034a\u0354\u035= c") >=20 > + buf.write("\u036e\u037d") >=20 > + return buf.getvalue() >=20 > + >=20 > + >=20 > +class CParser ( Parser ): >=20 > + >=20 > + grammarFileName =3D "C.g4" >=20 > + >=20 > + atn =3D ATNDeserializer().deserialize(serializedATN()) >=20 > + >=20 > + decisionsToDFA =3D [ DFA(ds, i) for i, ds in enumerate(atn.decisionT= oState) ] >=20 > + >=20 > + sharedContextCache =3D PredictionContextCache() >=20 > + >=20 > + literalNames =3D [ "", "'{'", "';'", "'typedef'", "','", "'= =3D'", >=20 > + "'extern'", "'static'", "'auto'", "'register'", "'S= TATIC'", >=20 > + "'void'", "'char'", "'short'", "'int'", "'long'", "= 'float'", >=20 > + "'double'", "'signed'", "'unsigned'", "'}'", "'stru= ct'", >=20 > + "'union'", "':'", "'enum'", "'const'", "'volatile'"= , >=20 > + "'IN'", "'OUT'", "'OPTIONAL'", "'CONST'", "'UNALIGN= ED'", >=20 > + "'VOLATILE'", "'GLOBAL_REMOVE_IF_UNREFERENCED'", "'= EFIAPI'", >=20 > + "'EFI_BOOTSERVICE'", "'EFI_RUNTIMESERVICE'", "'PACK= ED'", >=20 > + "'('", "')'", "'['", "']'", "'*'", "'...'", "'+'", >=20 > + "'-'", "'/'", "'%'", "'++'", "'--'", "'sizeof'", "'= .'", >=20 > + "'->'", "'&'", "'~'", "'!'", "'*=3D'", "'/=3D'", "'= %=3D'", >=20 > + "'+=3D'", "'-=3D'", "'<<=3D'", "'>>=3D'", "'&=3D'",= "'^=3D'", "'|=3D'", >=20 > + "'?'", "'||'", "'&&'", "'|'", "'^'", "'=3D=3D'", "'= !=3D'", >=20 > + "'<'", "'>'", "'<=3D'", "'>=3D'", "'<<'", "'>>'", "= '__asm__'", >=20 > + "'_asm'", "'__asm'", "'case'", "'default'", "'if'", >=20 > + "'else'", "'switch'", "'while'", "'do'", "'goto'", >=20 > + "'continue'", "'break'", "'return'" ] >=20 > + >=20 > + symbolicNames =3D [ "", "", "", "", >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "", "", ""= , >=20 > + "", "IDENTIFIER", "CHARACTER_LITERAL", "S= TRING_LITERAL", >=20 > + "HEX_LITERAL", "DECIMAL_LITERAL", "OCTAL_LITERAL", >=20 > + "FLOATING_POINT_LITERAL", "WS", "BS", "UnicodeVoca= bulary", >=20 > + "COMMENT", "LINE_COMMENT", "LINE_COMMAND" ] >=20 > + >=20 > + RULE_translation_unit =3D 0 >=20 > + RULE_external_declaration =3D 1 >=20 > + RULE_function_definition =3D 2 >=20 > + RULE_declaration_specifiers =3D 3 >=20 > + RULE_declaration =3D 4 >=20 > + RULE_init_declarator_list =3D 5 >=20 > + RULE_init_declarator =3D 6 >=20 > + RULE_storage_class_specifier =3D 7 >=20 > + RULE_type_specifier =3D 8 >=20 > + RULE_type_id =3D 9 >=20 > + RULE_struct_or_union_specifier =3D 10 >=20 > + RULE_struct_or_union =3D 11 >=20 > + RULE_struct_declaration_list =3D 12 >=20 > + RULE_struct_declaration =3D 13 >=20 > + RULE_specifier_qualifier_list =3D 14 >=20 > + RULE_struct_declarator_list =3D 15 >=20 > + RULE_struct_declarator =3D 16 >=20 > + RULE_enum_specifier =3D 17 >=20 > + RULE_enumerator_list =3D 18 >=20 > + RULE_enumerator =3D 19 >=20 > + RULE_type_qualifier =3D 20 >=20 > + RULE_declarator =3D 21 >=20 > + RULE_direct_declarator =3D 22 >=20 > + RULE_declarator_suffix =3D 23 >=20 > + RULE_pointer =3D 24 >=20 > + RULE_parameter_type_list =3D 25 >=20 > + RULE_parameter_list =3D 26 >=20 > + RULE_parameter_declaration =3D 27 >=20 > + RULE_identifier_list =3D 28 >=20 > + RULE_type_name =3D 29 >=20 > + RULE_abstract_declarator =3D 30 >=20 > + RULE_direct_abstract_declarator =3D 31 >=20 > + RULE_abstract_declarator_suffix =3D 32 >=20 > + RULE_initializer =3D 33 >=20 > + RULE_initializer_list =3D 34 >=20 > + RULE_argument_expression_list =3D 35 >=20 > + RULE_additive_expression =3D 36 >=20 > + RULE_multiplicative_expression =3D 37 >=20 > + RULE_cast_expression =3D 38 >=20 > + RULE_unary_expression =3D 39 >=20 > + RULE_postfix_expression =3D 40 >=20 > + RULE_macro_parameter_list =3D 41 >=20 > + RULE_unary_operator =3D 42 >=20 > + RULE_primary_expression =3D 43 >=20 > + RULE_constant =3D 44 >=20 > + RULE_expression =3D 45 >=20 > + RULE_constant_expression =3D 46 >=20 > + RULE_assignment_expression =3D 47 >=20 > + RULE_lvalue =3D 48 >=20 > + RULE_assignment_operator =3D 49 >=20 > + RULE_conditional_expression =3D 50 >=20 > + RULE_logical_or_expression =3D 51 >=20 > + RULE_logical_and_expression =3D 52 >=20 > + RULE_inclusive_or_expression =3D 53 >=20 > + RULE_exclusive_or_expression =3D 54 >=20 > + RULE_and_expression =3D 55 >=20 > + RULE_equality_expression =3D 56 >=20 > + RULE_relational_expression =3D 57 >=20 > + RULE_shift_expression =3D 58 >=20 > + RULE_statement =3D 59 >=20 > + RULE_asm2_statement =3D 60 >=20 > + RULE_asm1_statement =3D 61 >=20 > + RULE_asm_statement =3D 62 >=20 > + RULE_macro_statement =3D 63 >=20 > + RULE_labeled_statement =3D 64 >=20 > + RULE_compound_statement =3D 65 >=20 > + RULE_statement_list =3D 66 >=20 > + RULE_expression_statement =3D 67 >=20 > + RULE_selection_statement =3D 68 >=20 > + RULE_iteration_statement =3D 69 >=20 > + RULE_jump_statement =3D 70 >=20 > + >=20 > + ruleNames =3D [ "translation_unit", "external_declaration", "functi= on_definition", >=20 > + "declaration_specifiers", "declaration", "init_declar= ator_list", >=20 > + "init_declarator", "storage_class_specifier", "type_s= pecifier", >=20 > + "type_id", "struct_or_union_specifier", "struct_or_un= ion", >=20 > + "struct_declaration_list", "struct_declaration", "spe= cifier_qualifier_list", >=20 > + "struct_declarator_list", "struct_declarator", "enum_= specifier", >=20 > + "enumerator_list", "enumerator", "type_qualifier", "d= eclarator", >=20 > + "direct_declarator", "declarator_suffix", "pointer", >=20 > + "parameter_type_list", "parameter_list", "parameter_d= eclaration", >=20 > + "identifier_list", "type_name", "abstract_declarator"= , >=20 > + "direct_abstract_declarator", "abstract_declarator_su= ffix", >=20 > + "initializer", "initializer_list", "argument_expressi= on_list", >=20 > + "additive_expression", "multiplicative_expression", "= cast_expression", >=20 > + "unary_expression", "postfix_expression", "macro_para= meter_list", >=20 > + "unary_operator", "primary_expression", "constant", "= expression", >=20 > + "constant_expression", "assignment_expression", "lval= ue", >=20 > + "assignment_operator", "conditional_expression", "log= ical_or_expression", >=20 > + "logical_and_expression", "inclusive_or_expression", >=20 > + "exclusive_or_expression", "and_expression", "equalit= y_expression", >=20 > + "relational_expression", "shift_expression", "stateme= nt", >=20 > + "asm2_statement", "asm1_statement", "asm_statement", >=20 > + "macro_statement", "labeled_statement", "compound_sta= tement", >=20 > + "statement_list", "expression_statement", "selection_= statement", >=20 > + "iteration_statement", "jump_statement" ] >=20 > + >=20 > + EOF =3D Token.EOF >=20 > + T__0=3D1 >=20 > + T__1=3D2 >=20 > + T__2=3D3 >=20 > + T__3=3D4 >=20 > + T__4=3D5 >=20 > + T__5=3D6 >=20 > + T__6=3D7 >=20 > + T__7=3D8 >=20 > + T__8=3D9 >=20 > + T__9=3D10 >=20 > + T__10=3D11 >=20 > + T__11=3D12 >=20 > + T__12=3D13 >=20 > + T__13=3D14 >=20 > + T__14=3D15 >=20 > + T__15=3D16 >=20 > + T__16=3D17 >=20 > + T__17=3D18 >=20 > + T__18=3D19 >=20 > + T__19=3D20 >=20 > + T__20=3D21 >=20 > + T__21=3D22 >=20 > + T__22=3D23 >=20 > + T__23=3D24 >=20 > + T__24=3D25 >=20 > + T__25=3D26 >=20 > + T__26=3D27 >=20 > + T__27=3D28 >=20 > + T__28=3D29 >=20 > + T__29=3D30 >=20 > + T__30=3D31 >=20 > + T__31=3D32 >=20 > + T__32=3D33 >=20 > + T__33=3D34 >=20 > + T__34=3D35 >=20 > + T__35=3D36 >=20 > + T__36=3D37 >=20 > + T__37=3D38 >=20 > + T__38=3D39 >=20 > + T__39=3D40 >=20 > + T__40=3D41 >=20 > + T__41=3D42 >=20 > + T__42=3D43 >=20 > + T__43=3D44 >=20 > + T__44=3D45 >=20 > + T__45=3D46 >=20 > + T__46=3D47 >=20 > + T__47=3D48 >=20 > + T__48=3D49 >=20 > + T__49=3D50 >=20 > + T__50=3D51 >=20 > + T__51=3D52 >=20 > + T__52=3D53 >=20 > + T__53=3D54 >=20 > + T__54=3D55 >=20 > + T__55=3D56 >=20 > + T__56=3D57 >=20 > + T__57=3D58 >=20 > + T__58=3D59 >=20 > + T__59=3D60 >=20 > + T__60=3D61 >=20 > + T__61=3D62 >=20 > + T__62=3D63 >=20 > + T__63=3D64 >=20 > + T__64=3D65 >=20 > + T__65=3D66 >=20 > + T__66=3D67 >=20 > + T__67=3D68 >=20 > + T__68=3D69 >=20 > + T__69=3D70 >=20 > + T__70=3D71 >=20 > + T__71=3D72 >=20 > + T__72=3D73 >=20 > + T__73=3D74 >=20 > + T__74=3D75 >=20 > + T__75=3D76 >=20 > + T__76=3D77 >=20 > + T__77=3D78 >=20 > + T__78=3D79 >=20 > + T__79=3D80 >=20 > + T__80=3D81 >=20 > + T__81=3D82 >=20 > + T__82=3D83 >=20 > + T__83=3D84 >=20 > + T__84=3D85 >=20 > + T__85=3D86 >=20 > + T__86=3D87 >=20 > + T__87=3D88 >=20 > + T__88=3D89 >=20 > + T__89=3D90 >=20 > + T__90=3D91 >=20 > + T__91=3D92 >=20 > + IDENTIFIER=3D93 >=20 > + CHARACTER_LITERAL=3D94 >=20 > + STRING_LITERAL=3D95 >=20 > + HEX_LITERAL=3D96 >=20 > + DECIMAL_LITERAL=3D97 >=20 > + OCTAL_LITERAL=3D98 >=20 > + FLOATING_POINT_LITERAL=3D99 >=20 > + WS=3D100 >=20 > + BS=3D101 >=20 > + UnicodeVocabulary=3D102 >=20 > + COMMENT=3D103 >=20 > + LINE_COMMENT=3D104 >=20 > + LINE_COMMAND=3D105 >=20 > + >=20 > + # @param input Type: TokenStream >=20 > + # @param output=3D sys.stdout Type: TextIO >=20 > + def __init__(self,input,output=3D sys.stdout): >=20 > + super().__init__(input, output) >=20 > + self.checkVersion("4.7.1") >=20 > + self._interp =3D ParserATNSimulator(self, self.atn, self.decisio= nsToDFA, self.sharedContextCache) >=20 > + self._predicates =3D None >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def printTokenInfo(self,line,offset,tokenText): >=20 > + print(str(line)+ ',' + str(offset) + ':' + str(tokenText)) >=20 > + >=20 > + def StorePredicateExpression(self,StartLine,StartOffset,EndLine,EndO= ffset,Text): >=20 > + PredExp =3D CodeFragment.PredicateExpression(Text, (StartLine, S= tartOffset), (EndLine, EndOffset)) >=20 > + FileProfile.PredicateExpressionList.append(PredExp) >=20 > + >=20 > + def StoreEnumerationDefinition(self,StartLine,StartOffset,EndLine,En= dOffset,Text): >=20 > + EnumDef =3D CodeFragment.EnumerationDefinition(Text, (StartLine,= StartOffset), (EndLine, EndOffset)) >=20 > + FileProfile.EnumerationDefinitionList.append(EnumDef) >=20 > + >=20 > + def StoreStructUnionDefinition(self,StartLine,StartOffset,EndLine,En= dOffset,Text): >=20 > + SUDef =3D CodeFragment.StructUnionDefinition(Text, (StartLine, S= tartOffset), (EndLine, EndOffset)) >=20 > + FileProfile.StructUnionDefinitionList.append(SUDef) >=20 > + >=20 > + def StoreTypedefDefinition(self,StartLine,StartOffset,EndLine,EndOff= set,FromText,ToText): >=20 > + Tdef =3D CodeFragment.TypedefDefinition(FromText, ToText, (Start= Line, StartOffset), (EndLine, EndOffset)) >=20 > + FileProfile.TypedefDefinitionList.append(Tdef) >=20 > + >=20 > + def > StoreFunctionDefinition(self,StartLine,StartOffset,EndLine,EndOffset,Modi= fierText,DeclText,LeftBraceLine,LeftBraceOffset,DeclLine,DeclOffse > t): >=20 > + FuncDef =3D CodeFragment.FunctionDefinition(ModifierText, DeclTe= xt, (StartLine, StartOffset), (EndLine, EndOffset), (LeftBraceLine, > LeftBraceOffset), (DeclLine, DeclOffset)) >=20 > + FileProfile.FunctionDefinitionList.append(FuncDef) >=20 > + >=20 > + def StoreVariableDeclaration(self,StartLine,StartOffset,EndLine,EndO= ffset,ModifierText,DeclText): >=20 > + VarDecl =3D CodeFragment.VariableDeclaration(ModifierText, DeclT= ext, (StartLine, StartOffset), (EndLine, EndOffset)) >=20 > + FileProfile.VariableDeclarationList.append(VarDecl) >=20 > + >=20 > + def StoreFunctionCalling(self,StartLine,StartOffset,EndLine,EndOffse= t,FuncName,ParamList): >=20 > + FuncCall =3D CodeFragment.FunctionCalling(FuncName, ParamList, (= StartLine, StartOffset), (EndLine, EndOffset)) >=20 > + FileProfile.FunctionCallingList.append(FuncCall) >=20 > + >=20 > + >=20 > + >=20 > + class Translation_unitContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def external_declaration(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.External_declar= ationContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.External_declara= tionContext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_translation_unit >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterTranslation_unit" ): >=20 > + listener.enterTranslation_unit(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitTranslation_unit" ): >=20 > + listener.exitTranslation_unit(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def translation_unit(self): >=20 > + >=20 > + localctx =3D CParser.Translation_unitContext(self, self._ctx, se= lf.state) >=20 > + self.enterRule(localctx, 0, self.RULE_translation_unit) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 145 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while (((_la) & ~0x3f) =3D=3D 0 and ((1 << _la) & ((1 << CPa= rser.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 << CPar= ser.T__16) | (1 << CParser.T__17) | (1 << CParser.T__18) | (1 << > CParser.T__20) | (1 << CParser.T__21) | (1 << CParser.T__23) | (1 << CPar= ser.T__24) | (1 << CParser.T__25) | (1 << CParser.T__26) | (1 << > CParser.T__27) | (1 << CParser.T__28) | (1 << CParser.T__29) | (1 << CPar= ser.T__30) | (1 << CParser.T__31) | (1 << CParser.T__32) | (1 << > CParser.T__33) | (1 << CParser.T__34) | (1 << CParser.T__35) | (1 << CPar= ser.T__36) | (1 << CParser.T__37) | (1 << CParser.T__41))) !=3D 0) or > _la=3D=3DCParser.IDENTIFIER: >=20 > + self.state =3D 142 >=20 > + self.external_declaration() >=20 > + self.state =3D 147 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class External_declarationContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def declarator(self): >=20 > + return self.getTypedRuleContext(CParser.DeclaratorContext,0) >=20 > + >=20 > + >=20 > + def declaration_specifiers(self): >=20 > + return self.getTypedRuleContext(CParser.Declaration_specifie= rsContext,0) >=20 > + >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def declaration(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.DeclarationCont= ext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.DeclarationConte= xt,i) >=20 > + >=20 > + >=20 > + def function_definition(self): >=20 > + return self.getTypedRuleContext(CParser.Function_definitionC= ontext,0) >=20 > + >=20 > + >=20 > + def macro_statement(self): >=20 > + return self.getTypedRuleContext(CParser.Macro_statementConte= xt,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_external_declaration >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterExternal_declaration" ): >=20 > + listener.enterExternal_declaration(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitExternal_declaration" ): >=20 > + listener.exitExternal_declaration(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def external_declaration(self): >=20 > + >=20 > + localctx =3D CParser.External_declarationContext(self, self._ctx= , self.state) >=20 > + self.enterRule(localctx, 2, self.RULE_external_declaration) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.state =3D 166 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,4,self._ctx= ) >=20 > + if la_ =3D=3D 1: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 149 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,1,self.= _ctx) >=20 > + if la_ =3D=3D 1: >=20 > + self.state =3D 148 >=20 > + self.declaration_specifiers() >=20 > + >=20 > + >=20 > + self.state =3D 151 >=20 > + self.declarator() >=20 > + self.state =3D 155 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while (((_la) & ~0x3f) =3D=3D 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 << CPar= ser.T__16) | (1 << CParser.T__17) | (1 << CParser.T__18) | (1 << > CParser.T__20) | (1 << CParser.T__21) | (1 << CParser.T__23) | (1 << CPar= ser.T__24) | (1 << CParser.T__25) | (1 << CParser.T__26) | (1 << > CParser.T__27) | (1 << CParser.T__28) | (1 << CParser.T__29) | (1 << CPar= ser.T__30) | (1 << CParser.T__31) | (1 << CParser.T__32) | (1 << > CParser.T__33) | (1 << CParser.T__34) | (1 << CParser.T__35) | (1 << CPar= ser.T__36))) !=3D 0) or _la=3D=3DCParser.IDENTIFIER: >=20 > + self.state =3D 152 >=20 > + self.declaration() >=20 > + self.state =3D 157 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + self.state =3D 158 >=20 > + self.match(CParser.T__0) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 160 >=20 > + self.function_definition() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 3: >=20 > + self.enterOuterAlt(localctx, 3) >=20 > + self.state =3D 161 >=20 > + self.declaration() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 4: >=20 > + self.enterOuterAlt(localctx, 4) >=20 > + self.state =3D 162 >=20 > + self.macro_statement() >=20 > + self.state =3D 164 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__1: >=20 > + self.state =3D 163 >=20 > + self.match(CParser.T__1) >=20 > + >=20 > + >=20 > + pass >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Function_definitionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + self.ModifierText =3D '' >=20 > + self.DeclText =3D '' >=20 > + self.LBLine =3D 0 >=20 > + self.LBOffset =3D 0 >=20 > + self.DeclLine =3D 0 >=20 > + self.DeclOffset =3D 0 >=20 > + self.d =3D None # Declaration_specifiersContext >=20 > + self._declaration_specifiers =3D None # Declaration_specifie= rsContext >=20 > + self._declarator =3D None # DeclaratorContext >=20 > + self.a =3D None # Compound_statementContext >=20 > + self.b =3D None # Compound_statementContext >=20 > + >=20 > + def declarator(self): >=20 > + return self.getTypedRuleContext(CParser.DeclaratorContext,0) >=20 > + >=20 > + >=20 > + def compound_statement(self): >=20 > + return self.getTypedRuleContext(CParser.Compound_statementCo= ntext,0) >=20 > + >=20 > + >=20 > + def declaration_specifiers(self): >=20 > + return self.getTypedRuleContext(CParser.Declaration_specifie= rsContext,0) >=20 > + >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def declaration(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.DeclarationCont= ext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.DeclarationConte= xt,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_function_definition >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterFunction_definition" ): >=20 > + listener.enterFunction_definition(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitFunction_definition" ): >=20 > + listener.exitFunction_definition(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def function_definition(self): >=20 > + >=20 > + localctx =3D CParser.Function_definitionContext(self, self._ctx,= self.state) >=20 > + self.enterRule(localctx, 4, self.RULE_function_definition) >=20 > + >=20 > + ModifierText =3D ''; >=20 > + DeclText =3D ''; >=20 > + LBLine =3D 0; >=20 > + LBOffset =3D 0; >=20 > + DeclLine =3D 0; >=20 > + DeclOffset =3D 0; >=20 > + >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 169 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,5,self._ctx= ) >=20 > + if la_ =3D=3D 1: >=20 > + self.state =3D 168 >=20 > + localctx.d =3D localctx._declaration_specifiers =3D self= .declaration_specifiers() >=20 > + >=20 > + >=20 > + self.state =3D 171 >=20 > + localctx._declarator =3D self.declarator() >=20 > + self.state =3D 180 >=20 > + self._errHandler.sync(self) >=20 > + token =3D self._input.LA(1) >=20 > + if token in [CParser.T__2, CParser.T__5, CParser.T__6, CPars= er.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]: >=20 > + self.state =3D 173 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while True: >=20 > + self.state =3D 172 >=20 > + self.declaration() >=20 > + self.state =3D 175 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if not ((((_la) & ~0x3f) =3D=3D 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 << CPar= ser.T__16) | (1 << CParser.T__17) | (1 << CParser.T__18) | (1 << > CParser.T__20) | (1 << CParser.T__21) | (1 << CParser.T__23) | (1 << CPar= ser.T__24) | (1 << CParser.T__25) | (1 << CParser.T__26) | (1 << > CParser.T__27) | (1 << CParser.T__28) | (1 << CParser.T__29) | (1 << CPar= ser.T__30) | (1 << CParser.T__31) | (1 << CParser.T__32) | (1 << > CParser.T__33) | (1 << CParser.T__34) | (1 << CParser.T__35) | (1 << CPar= ser.T__36))) !=3D 0) or _la=3D=3DCParser.IDENTIFIER): >=20 > + break >=20 > + >=20 > + self.state =3D 177 >=20 > + localctx.a =3D self.compound_statement() >=20 > + pass >=20 > + elif token in [CParser.T__0]: >=20 > + self.state =3D 179 >=20 > + localctx.b =3D self.compound_statement() >=20 > + pass >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + >=20 > + >=20 > + if localctx.d !=3D None: >=20 > + ModifierText =3D (None if localctx._declaration_specifie= rs is None else > self._input.getText((localctx._declaration_specifiers.start,localctx._dec= laration_specifiers.stop))) >=20 > + else: >=20 > + ModifierText =3D '' >=20 > + DeclText =3D (None if localctx._declarator is None else self= ._input.getText((localctx._declarator.start,localctx._declarator.stop))) >=20 > + DeclLine =3D (None if localctx._declarator is None else loca= lctx._declarator.start).line >=20 > + DeclOffset =3D (None if localctx._declarator is None else lo= calctx._declarator.start).column >=20 > + if localctx.a !=3D None: >=20 > + LBLine =3D (None if localctx.a is None else localctx.a.s= tart).line >=20 > + LBOffset =3D (None if localctx.a is None else localctx.a= .start).column >=20 > + else: >=20 > + LBLine =3D (None if localctx.b is None else localctx.b.s= tart).line >=20 > + LBOffset =3D (None if localctx.b is None else localctx.b= .start).column >=20 > + >=20 > + self._ctx.stop =3D self._input.LT(-1) >=20 > + >=20 > + self.StoreFunctionDefinition(localctx.start.line, localctx.s= tart.column, localctx.stop.line, localctx.stop.column, ModifierText, > DeclText, LBLine, LBOffset, DeclLine, DeclOffset) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Declaration_specifiersContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def storage_class_specifier(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Storage_class_s= pecifierContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Storage_class_sp= ecifierContext,i) >=20 > + >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def type_specifier(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Type_specifierC= ontext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Type_specifierCo= ntext,i) >=20 > + >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def type_qualifier(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Type_qualifierC= ontext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Type_qualifierCo= ntext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_declaration_specifiers >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterDeclaration_specifiers" ): >=20 > + listener.enterDeclaration_specifiers(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitDeclaration_specifiers" ): >=20 > + listener.exitDeclaration_specifiers(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def declaration_specifiers(self): >=20 > + >=20 > + localctx =3D CParser.Declaration_specifiersContext(self, self._c= tx, self.state) >=20 > + self.enterRule(localctx, 6, self.RULE_declaration_specifiers) >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 187 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D 1 >=20 > + while _alt!=3D2 and _alt!=3DATN.INVALID_ALT_NUMBER: >=20 > + if _alt =3D=3D 1: >=20 > + self.state =3D 187 >=20 > + self._errHandler.sync(self) >=20 > + token =3D self._input.LA(1) >=20 > + if token in [CParser.T__5, CParser.T__6, CParser.T__= 7, CParser.T__8, CParser.T__9]: >=20 > + self.state =3D 184 >=20 > + self.storage_class_specifier() >=20 > + pass >=20 > + 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]: >=20 > + self.state =3D 185 >=20 > + self.type_specifier() >=20 > + pass >=20 > + 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]: >=20 > + self.state =3D 186 >=20 > + self.type_qualifier() >=20 > + pass >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + >=20 > + >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + self.state =3D 189 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,9,self= ._ctx) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class DeclarationContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + self.a =3D None # Token >=20 > + self.b =3D None # Declaration_specifiersContext >=20 > + self.c =3D None # Init_declarator_listContext >=20 > + self.d =3D None # Token >=20 > + self.s =3D None # Declaration_specifiersContext >=20 > + self.t =3D None # Init_declarator_listContext >=20 > + self.e =3D None # Token >=20 > + >=20 > + def init_declarator_list(self): >=20 > + return self.getTypedRuleContext(CParser.Init_declarator_list= Context,0) >=20 > + >=20 > + >=20 > + def declaration_specifiers(self): >=20 > + return self.getTypedRuleContext(CParser.Declaration_specifie= rsContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_declaration >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterDeclaration" ): >=20 > + listener.enterDeclaration(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitDeclaration" ): >=20 > + listener.exitDeclaration(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def declaration(self): >=20 > + >=20 > + localctx =3D CParser.DeclarationContext(self, self._ctx, self.st= ate) >=20 > + self.enterRule(localctx, 8, self.RULE_declaration) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.state =3D 206 >=20 > + self._errHandler.sync(self) >=20 > + token =3D self._input.LA(1) >=20 > + if token in [CParser.T__2]: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 191 >=20 > + localctx.a =3D self.match(CParser.T__2) >=20 > + self.state =3D 193 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,10,self= ._ctx) >=20 > + if la_ =3D=3D 1: >=20 > + self.state =3D 192 >=20 > + localctx.b =3D self.declaration_specifiers() >=20 > + >=20 > + >=20 > + self.state =3D 195 >=20 > + localctx.c =3D self.init_declarator_list() >=20 > + self.state =3D 196 >=20 > + localctx.d =3D self.match(CParser.T__1) >=20 > + >=20 > + if localctx.b is not None: >=20 > + self.StoreTypedefDefinition(localctx.a.line, localct= x.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)))) >=20 > + else: >=20 > + self.StoreTypedefDefinition(localctx.a.line, localct= x.a.column, (0 if localctx.d is None else localctx.d.line), > localctx.d.column, '', (None if localctx.c is None else self._input.getTe= xt((localctx.c.start,localctx.c.stop)))) >=20 > + >=20 > + pass >=20 > + elif token in [CParser.T__5, CParser.T__6, CParser.T__7, CPa= rser.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]: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 199 >=20 > + localctx.s =3D self.declaration_specifiers() >=20 > + self.state =3D 201 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if ((((_la - 34)) & ~0x3f) =3D=3D 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__4= 1 - 34)) | (1 << (CParser.IDENTIFIER - 34)))) !=3D 0): >=20 > + self.state =3D 200 >=20 > + localctx.t =3D self.init_declarator_list() >=20 > + >=20 > + >=20 > + self.state =3D 203 >=20 > + localctx.e =3D self.match(CParser.T__1) >=20 > + >=20 > + if localctx.t is not None: >=20 > + 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.sta= rt).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)))) >=20 > + >=20 > + pass >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Init_declarator_listContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def init_declarator(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Init_declarator= Context) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Init_declaratorC= ontext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_init_declarator_list >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterInit_declarator_list" ): >=20 > + listener.enterInit_declarator_list(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitInit_declarator_list" ): >=20 > + listener.exitInit_declarator_list(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def init_declarator_list(self): >=20 > + >=20 > + localctx =3D CParser.Init_declarator_listContext(self, self._ctx= , self.state) >=20 > + self.enterRule(localctx, 10, self.RULE_init_declarator_list) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 208 >=20 > + self.init_declarator() >=20 > + self.state =3D 213 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while _la=3D=3DCParser.T__3: >=20 > + self.state =3D 209 >=20 > + self.match(CParser.T__3) >=20 > + self.state =3D 210 >=20 > + self.init_declarator() >=20 > + self.state =3D 215 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Init_declaratorContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def declarator(self): >=20 > + return self.getTypedRuleContext(CParser.DeclaratorContext,0) >=20 > + >=20 > + >=20 > + def initializer(self): >=20 > + return self.getTypedRuleContext(CParser.InitializerContext,0= ) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_init_declarator >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterInit_declarator" ): >=20 > + listener.enterInit_declarator(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitInit_declarator" ): >=20 > + listener.exitInit_declarator(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def init_declarator(self): >=20 > + >=20 > + localctx =3D CParser.Init_declaratorContext(self, self._ctx, sel= f.state) >=20 > + self.enterRule(localctx, 12, self.RULE_init_declarator) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 216 >=20 > + self.declarator() >=20 > + self.state =3D 219 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__4: >=20 > + self.state =3D 217 >=20 > + self.match(CParser.T__4) >=20 > + self.state =3D 218 >=20 > + self.initializer() >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Storage_class_specifierContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_storage_class_specifier >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterStorage_class_specifier" ): >=20 > + listener.enterStorage_class_specifier(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitStorage_class_specifier" ): >=20 > + listener.exitStorage_class_specifier(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def storage_class_specifier(self): >=20 > + >=20 > + localctx =3D CParser.Storage_class_specifierContext(self, self._= ctx, self.state) >=20 > + self.enterRule(localctx, 14, self.RULE_storage_class_specifier) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 221 >=20 > + _la =3D self._input.LA(1) >=20 > + if not((((_la) & ~0x3f) =3D=3D 0 and ((1 << _la) & ((1 << CP= arser.T__5) | (1 << CParser.T__6) | (1 << CParser.T__7) | (1 << > CParser.T__8) | (1 << CParser.T__9))) !=3D 0)): >=20 > + self._errHandler.recoverInline(self) >=20 > + else: >=20 > + self._errHandler.reportMatch(self) >=20 > + self.consume() >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Type_specifierContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + self.s =3D None # Struct_or_union_specifierContext >=20 > + self.e =3D None # Enum_specifierContext >=20 > + >=20 > + def struct_or_union_specifier(self): >=20 > + return self.getTypedRuleContext(CParser.Struct_or_union_spec= ifierContext,0) >=20 > + >=20 > + >=20 > + def enum_specifier(self): >=20 > + return self.getTypedRuleContext(CParser.Enum_specifierContex= t,0) >=20 > + >=20 > + >=20 > + def IDENTIFIER(self): >=20 > + return self.getToken(CParser.IDENTIFIER, 0) >=20 > + >=20 > + def declarator(self): >=20 > + return self.getTypedRuleContext(CParser.DeclaratorContext,0) >=20 > + >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def type_qualifier(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Type_qualifierC= ontext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Type_qualifierCo= ntext,i) >=20 > + >=20 > + >=20 > + def type_id(self): >=20 > + return self.getTypedRuleContext(CParser.Type_idContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_type_specifier >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterType_specifier" ): >=20 > + listener.enterType_specifier(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitType_specifier" ): >=20 > + listener.exitType_specifier(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def type_specifier(self): >=20 > + >=20 > + localctx =3D CParser.Type_specifierContext(self, self._ctx, self= .state) >=20 > + self.enterRule(localctx, 16, self.RULE_type_specifier) >=20 > + try: >=20 > + self.state =3D 247 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,16,self._ct= x) >=20 > + if la_ =3D=3D 1: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 223 >=20 > + self.match(CParser.T__10) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 224 >=20 > + self.match(CParser.T__11) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 3: >=20 > + self.enterOuterAlt(localctx, 3) >=20 > + self.state =3D 225 >=20 > + self.match(CParser.T__12) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 4: >=20 > + self.enterOuterAlt(localctx, 4) >=20 > + self.state =3D 226 >=20 > + self.match(CParser.T__13) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 5: >=20 > + self.enterOuterAlt(localctx, 5) >=20 > + self.state =3D 227 >=20 > + self.match(CParser.T__14) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 6: >=20 > + self.enterOuterAlt(localctx, 6) >=20 > + self.state =3D 228 >=20 > + self.match(CParser.T__15) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 7: >=20 > + self.enterOuterAlt(localctx, 7) >=20 > + self.state =3D 229 >=20 > + self.match(CParser.T__16) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 8: >=20 > + self.enterOuterAlt(localctx, 8) >=20 > + self.state =3D 230 >=20 > + self.match(CParser.T__17) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 9: >=20 > + self.enterOuterAlt(localctx, 9) >=20 > + self.state =3D 231 >=20 > + self.match(CParser.T__18) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 10: >=20 > + self.enterOuterAlt(localctx, 10) >=20 > + self.state =3D 232 >=20 > + localctx.s =3D self.struct_or_union_specifier() >=20 > + >=20 > + if localctx.s.stop is not None: >=20 > + 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.sto= p).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)))) >=20 > + >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 11: >=20 > + self.enterOuterAlt(localctx, 11) >=20 > + self.state =3D 235 >=20 > + localctx.e =3D self.enum_specifier() >=20 > + >=20 > + if localctx.e.stop is not None: >=20 > + 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,lo= calctx.e.stop)))) >=20 > + >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 12: >=20 > + self.enterOuterAlt(localctx, 12) >=20 > + self.state =3D 238 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + self.state =3D 242 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,15,sel= f._ctx) >=20 > + while _alt!=3D2 and _alt!=3DATN.INVALID_ALT_NUMBER: >=20 > + if _alt=3D=3D1: >=20 > + self.state =3D 239 >=20 > + self.type_qualifier() >=20 > + self.state =3D 244 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,15= ,self._ctx) >=20 > + >=20 > + self.state =3D 245 >=20 > + self.declarator() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 13: >=20 > + self.enterOuterAlt(localctx, 13) >=20 > + self.state =3D 246 >=20 > + self.type_id() >=20 > + pass >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Type_idContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def IDENTIFIER(self): >=20 > + return self.getToken(CParser.IDENTIFIER, 0) >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_type_id >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterType_id" ): >=20 > + listener.enterType_id(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitType_id" ): >=20 > + listener.exitType_id(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def type_id(self): >=20 > + >=20 > + localctx =3D CParser.Type_idContext(self, self._ctx, self.state) >=20 > + self.enterRule(localctx, 18, self.RULE_type_id) >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 249 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Struct_or_union_specifierContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def struct_or_union(self): >=20 > + return self.getTypedRuleContext(CParser.Struct_or_unionConte= xt,0) >=20 > + >=20 > + >=20 > + def struct_declaration_list(self): >=20 > + return self.getTypedRuleContext(CParser.Struct_declaration_l= istContext,0) >=20 > + >=20 > + >=20 > + def IDENTIFIER(self): >=20 > + return self.getToken(CParser.IDENTIFIER, 0) >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_struct_or_union_specifier >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterStruct_or_union_specifier" ): >=20 > + listener.enterStruct_or_union_specifier(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitStruct_or_union_specifier" ): >=20 > + listener.exitStruct_or_union_specifier(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def struct_or_union_specifier(self): >=20 > + >=20 > + localctx =3D CParser.Struct_or_union_specifierContext(self, self= ._ctx, self.state) >=20 > + self.enterRule(localctx, 20, self.RULE_struct_or_union_specifier= ) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.state =3D 262 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,18,self._ct= x) >=20 > + if la_ =3D=3D 1: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 251 >=20 > + self.struct_or_union() >=20 > + self.state =3D 253 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.IDENTIFIER: >=20 > + self.state =3D 252 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + >=20 > + >=20 > + self.state =3D 255 >=20 > + self.match(CParser.T__0) >=20 > + self.state =3D 256 >=20 > + self.struct_declaration_list() >=20 > + self.state =3D 257 >=20 > + self.match(CParser.T__19) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 259 >=20 > + self.struct_or_union() >=20 > + self.state =3D 260 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + pass >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Struct_or_unionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_struct_or_union >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterStruct_or_union" ): >=20 > + listener.enterStruct_or_union(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitStruct_or_union" ): >=20 > + listener.exitStruct_or_union(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def struct_or_union(self): >=20 > + >=20 > + localctx =3D CParser.Struct_or_unionContext(self, self._ctx, sel= f.state) >=20 > + self.enterRule(localctx, 22, self.RULE_struct_or_union) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 264 >=20 > + _la =3D self._input.LA(1) >=20 > + if not(_la=3D=3DCParser.T__20 or _la=3D=3DCParser.T__21): >=20 > + self._errHandler.recoverInline(self) >=20 > + else: >=20 > + self._errHandler.reportMatch(self) >=20 > + self.consume() >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Struct_declaration_listContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def struct_declaration(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Struct_declarat= ionContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Struct_declarati= onContext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_struct_declaration_list >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterStruct_declaration_list" ): >=20 > + listener.enterStruct_declaration_list(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitStruct_declaration_list" ): >=20 > + listener.exitStruct_declaration_list(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def struct_declaration_list(self): >=20 > + >=20 > + localctx =3D CParser.Struct_declaration_listContext(self, self._= ctx, self.state) >=20 > + self.enterRule(localctx, 24, self.RULE_struct_declaration_list) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 267 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while True: >=20 > + self.state =3D 266 >=20 > + self.struct_declaration() >=20 > + self.state =3D 269 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if not ((((_la) & ~0x3f) =3D=3D 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 << CPar= ser.T__16) | (1 << CParser.T__17) | (1 << CParser.T__18) | (1 << > CParser.T__20) | (1 << CParser.T__21) | (1 << CParser.T__23) | (1 << CPar= ser.T__24) | (1 << CParser.T__25) | (1 << CParser.T__26) | (1 << > CParser.T__27) | (1 << CParser.T__28) | (1 << CParser.T__29) | (1 << CPar= ser.T__30) | (1 << CParser.T__31) | (1 << CParser.T__32) | (1 << > CParser.T__33) | (1 << CParser.T__34) | (1 << CParser.T__35) | (1 << CPar= ser.T__36))) !=3D 0) or _la=3D=3DCParser.IDENTIFIER): >=20 > + break >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Struct_declarationContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def specifier_qualifier_list(self): >=20 > + return self.getTypedRuleContext(CParser.Specifier_qualifier_= listContext,0) >=20 > + >=20 > + >=20 > + def struct_declarator_list(self): >=20 > + return self.getTypedRuleContext(CParser.Struct_declarator_li= stContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_struct_declaration >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterStruct_declaration" ): >=20 > + listener.enterStruct_declaration(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitStruct_declaration" ): >=20 > + listener.exitStruct_declaration(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def struct_declaration(self): >=20 > + >=20 > + localctx =3D CParser.Struct_declarationContext(self, self._ctx, = self.state) >=20 > + self.enterRule(localctx, 26, self.RULE_struct_declaration) >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 271 >=20 > + self.specifier_qualifier_list() >=20 > + self.state =3D 272 >=20 > + self.struct_declarator_list() >=20 > + self.state =3D 273 >=20 > + self.match(CParser.T__1) >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Specifier_qualifier_listContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def type_qualifier(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Type_qualifierC= ontext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Type_qualifierCo= ntext,i) >=20 > + >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def type_specifier(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Type_specifierC= ontext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Type_specifierCo= ntext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_specifier_qualifier_list >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterSpecifier_qualifier_list" ): >=20 > + listener.enterSpecifier_qualifier_list(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitSpecifier_qualifier_list" ): >=20 > + listener.exitSpecifier_qualifier_list(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def specifier_qualifier_list(self): >=20 > + >=20 > + localctx =3D CParser.Specifier_qualifier_listContext(self, self.= _ctx, self.state) >=20 > + self.enterRule(localctx, 28, self.RULE_specifier_qualifier_list) >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 277 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D 1 >=20 > + while _alt!=3D2 and _alt!=3DATN.INVALID_ALT_NUMBER: >=20 > + if _alt =3D=3D 1: >=20 > + self.state =3D 277 >=20 > + self._errHandler.sync(self) >=20 > + token =3D self._input.LA(1) >=20 > + 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]: >=20 > + self.state =3D 275 >=20 > + self.type_qualifier() >=20 > + pass >=20 > + 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]: >=20 > + self.state =3D 276 >=20 > + self.type_specifier() >=20 > + pass >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + >=20 > + >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + self.state =3D 279 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,21,sel= f._ctx) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Struct_declarator_listContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def struct_declarator(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Struct_declarat= orContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Struct_declarato= rContext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_struct_declarator_list >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterStruct_declarator_list" ): >=20 > + listener.enterStruct_declarator_list(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitStruct_declarator_list" ): >=20 > + listener.exitStruct_declarator_list(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def struct_declarator_list(self): >=20 > + >=20 > + localctx =3D CParser.Struct_declarator_listContext(self, self._c= tx, self.state) >=20 > + self.enterRule(localctx, 30, self.RULE_struct_declarator_list) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 281 >=20 > + self.struct_declarator() >=20 > + self.state =3D 286 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while _la=3D=3DCParser.T__3: >=20 > + self.state =3D 282 >=20 > + self.match(CParser.T__3) >=20 > + self.state =3D 283 >=20 > + self.struct_declarator() >=20 > + self.state =3D 288 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Struct_declaratorContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def declarator(self): >=20 > + return self.getTypedRuleContext(CParser.DeclaratorContext,0) >=20 > + >=20 > + >=20 > + def constant_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Constant_expressionC= ontext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_struct_declarator >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterStruct_declarator" ): >=20 > + listener.enterStruct_declarator(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitStruct_declarator" ): >=20 > + listener.exitStruct_declarator(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def struct_declarator(self): >=20 > + >=20 > + localctx =3D CParser.Struct_declaratorContext(self, self._ctx, s= elf.state) >=20 > + self.enterRule(localctx, 32, self.RULE_struct_declarator) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.state =3D 296 >=20 > + self._errHandler.sync(self) >=20 > + token =3D self._input.LA(1) >=20 > + if token in [CParser.T__33, CParser.T__34, CParser.T__35, CP= arser.T__37, CParser.T__41, CParser.IDENTIFIER]: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 289 >=20 > + self.declarator() >=20 > + self.state =3D 292 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__22: >=20 > + self.state =3D 290 >=20 > + self.match(CParser.T__22) >=20 > + self.state =3D 291 >=20 > + self.constant_expression() >=20 > + >=20 > + >=20 > + pass >=20 > + elif token in [CParser.T__22]: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 294 >=20 > + self.match(CParser.T__22) >=20 > + self.state =3D 295 >=20 > + self.constant_expression() >=20 > + pass >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Enum_specifierContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def enumerator_list(self): >=20 > + return self.getTypedRuleContext(CParser.Enumerator_listConte= xt,0) >=20 > + >=20 > + >=20 > + def IDENTIFIER(self): >=20 > + return self.getToken(CParser.IDENTIFIER, 0) >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_enum_specifier >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterEnum_specifier" ): >=20 > + listener.enterEnum_specifier(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitEnum_specifier" ): >=20 > + listener.exitEnum_specifier(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def enum_specifier(self): >=20 > + >=20 > + localctx =3D CParser.Enum_specifierContext(self, self._ctx, self= .state) >=20 > + self.enterRule(localctx, 34, self.RULE_enum_specifier) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.state =3D 317 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,27,self._ct= x) >=20 > + if la_ =3D=3D 1: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 298 >=20 > + self.match(CParser.T__23) >=20 > + self.state =3D 299 >=20 > + self.match(CParser.T__0) >=20 > + self.state =3D 300 >=20 > + self.enumerator_list() >=20 > + self.state =3D 302 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__3: >=20 > + self.state =3D 301 >=20 > + self.match(CParser.T__3) >=20 > + >=20 > + >=20 > + self.state =3D 304 >=20 > + self.match(CParser.T__19) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 306 >=20 > + self.match(CParser.T__23) >=20 > + self.state =3D 307 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + self.state =3D 308 >=20 > + self.match(CParser.T__0) >=20 > + self.state =3D 309 >=20 > + self.enumerator_list() >=20 > + self.state =3D 311 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__3: >=20 > + self.state =3D 310 >=20 > + self.match(CParser.T__3) >=20 > + >=20 > + >=20 > + self.state =3D 313 >=20 > + self.match(CParser.T__19) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 3: >=20 > + self.enterOuterAlt(localctx, 3) >=20 > + self.state =3D 315 >=20 > + self.match(CParser.T__23) >=20 > + self.state =3D 316 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + pass >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Enumerator_listContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def enumerator(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.EnumeratorConte= xt) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.EnumeratorContex= t,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_enumerator_list >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterEnumerator_list" ): >=20 > + listener.enterEnumerator_list(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitEnumerator_list" ): >=20 > + listener.exitEnumerator_list(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def enumerator_list(self): >=20 > + >=20 > + localctx =3D CParser.Enumerator_listContext(self, self._ctx, sel= f.state) >=20 > + self.enterRule(localctx, 36, self.RULE_enumerator_list) >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 319 >=20 > + self.enumerator() >=20 > + self.state =3D 324 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,28,self._c= tx) >=20 > + while _alt!=3D2 and _alt!=3DATN.INVALID_ALT_NUMBER: >=20 > + if _alt=3D=3D1: >=20 > + self.state =3D 320 >=20 > + self.match(CParser.T__3) >=20 > + self.state =3D 321 >=20 > + self.enumerator() >=20 > + self.state =3D 326 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,28,sel= f._ctx) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class EnumeratorContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def IDENTIFIER(self): >=20 > + return self.getToken(CParser.IDENTIFIER, 0) >=20 > + >=20 > + def constant_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Constant_expressionC= ontext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_enumerator >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterEnumerator" ): >=20 > + listener.enterEnumerator(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitEnumerator" ): >=20 > + listener.exitEnumerator(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def enumerator(self): >=20 > + >=20 > + localctx =3D CParser.EnumeratorContext(self, self._ctx, self.sta= te) >=20 > + self.enterRule(localctx, 38, self.RULE_enumerator) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 327 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + self.state =3D 330 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__4: >=20 > + self.state =3D 328 >=20 > + self.match(CParser.T__4) >=20 > + self.state =3D 329 >=20 > + self.constant_expression() >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Type_qualifierContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_type_qualifier >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterType_qualifier" ): >=20 > + listener.enterType_qualifier(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitType_qualifier" ): >=20 > + listener.exitType_qualifier(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def type_qualifier(self): >=20 > + >=20 > + localctx =3D CParser.Type_qualifierContext(self, self._ctx, self= .state) >=20 > + self.enterRule(localctx, 40, self.RULE_type_qualifier) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 332 >=20 > + _la =3D self._input.LA(1) >=20 > + if not((((_la) & ~0x3f) =3D=3D 0 and ((1 << _la) & ((1 << CP= arser.T__24) | (1 << CParser.T__25) | (1 << CParser.T__26) | (1 << > CParser.T__27) | (1 << CParser.T__28) | (1 << CParser.T__29) | (1 << CPar= ser.T__30) | (1 << CParser.T__31) | (1 << CParser.T__32) | (1 << > CParser.T__33) | (1 << CParser.T__34) | (1 << CParser.T__35) | (1 << CPar= ser.T__36))) !=3D 0)): >=20 > + self._errHandler.recoverInline(self) >=20 > + else: >=20 > + self._errHandler.reportMatch(self) >=20 > + self.consume() >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class DeclaratorContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def direct_declarator(self): >=20 > + return self.getTypedRuleContext(CParser.Direct_declaratorCon= text,0) >=20 > + >=20 > + >=20 > + def pointer(self): >=20 > + return self.getTypedRuleContext(CParser.PointerContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_declarator >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterDeclarator" ): >=20 > + listener.enterDeclarator(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitDeclarator" ): >=20 > + listener.exitDeclarator(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def declarator(self): >=20 > + >=20 > + localctx =3D CParser.DeclaratorContext(self, self._ctx, self.sta= te) >=20 > + self.enterRule(localctx, 42, self.RULE_declarator) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.state =3D 348 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,34,self._ct= x) >=20 > + if la_ =3D=3D 1: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 335 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__41: >=20 > + self.state =3D 334 >=20 > + self.pointer() >=20 > + >=20 > + >=20 > + self.state =3D 338 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__33: >=20 > + self.state =3D 337 >=20 > + self.match(CParser.T__33) >=20 > + >=20 > + >=20 > + self.state =3D 341 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__34: >=20 > + self.state =3D 340 >=20 > + self.match(CParser.T__34) >=20 > + >=20 > + >=20 > + self.state =3D 344 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__35: >=20 > + self.state =3D 343 >=20 > + self.match(CParser.T__35) >=20 > + >=20 > + >=20 > + self.state =3D 346 >=20 > + self.direct_declarator() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 347 >=20 > + self.pointer() >=20 > + pass >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Direct_declaratorContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def IDENTIFIER(self): >=20 > + return self.getToken(CParser.IDENTIFIER, 0) >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def declarator_suffix(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Declarator_suff= ixContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Declarator_suffi= xContext,i) >=20 > + >=20 > + >=20 > + def declarator(self): >=20 > + return self.getTypedRuleContext(CParser.DeclaratorContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_direct_declarator >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterDirect_declarator" ): >=20 > + listener.enterDirect_declarator(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitDirect_declarator" ): >=20 > + listener.exitDirect_declarator(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def direct_declarator(self): >=20 > + >=20 > + localctx =3D CParser.Direct_declaratorContext(self, self._ctx, s= elf.state) >=20 > + self.enterRule(localctx, 44, self.RULE_direct_declarator) >=20 > + try: >=20 > + self.state =3D 368 >=20 > + self._errHandler.sync(self) >=20 > + token =3D self._input.LA(1) >=20 > + if token in [CParser.IDENTIFIER]: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 350 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + self.state =3D 354 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,35,sel= f._ctx) >=20 > + while _alt!=3D2 and _alt!=3DATN.INVALID_ALT_NUMBER: >=20 > + if _alt=3D=3D1: >=20 > + self.state =3D 351 >=20 > + self.declarator_suffix() >=20 > + self.state =3D 356 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,35= ,self._ctx) >=20 > + >=20 > + pass >=20 > + elif token in [CParser.T__37]: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 357 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 359 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,36,self= ._ctx) >=20 > + if la_ =3D=3D 1: >=20 > + self.state =3D 358 >=20 > + self.match(CParser.T__33) >=20 > + >=20 > + >=20 > + self.state =3D 361 >=20 > + self.declarator() >=20 > + self.state =3D 362 >=20 > + self.match(CParser.T__38) >=20 > + self.state =3D 364 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D 1 >=20 > + while _alt!=3D2 and _alt!=3DATN.INVALID_ALT_NUMBER: >=20 > + if _alt =3D=3D 1: >=20 > + self.state =3D 363 >=20 > + self.declarator_suffix() >=20 > + >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + self.state =3D 366 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,37= ,self._ctx) >=20 > + >=20 > + pass >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Declarator_suffixContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def constant_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Constant_expressionC= ontext,0) >=20 > + >=20 > + >=20 > + def parameter_type_list(self): >=20 > + return self.getTypedRuleContext(CParser.Parameter_type_listC= ontext,0) >=20 > + >=20 > + >=20 > + def identifier_list(self): >=20 > + return self.getTypedRuleContext(CParser.Identifier_listConte= xt,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_declarator_suffix >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterDeclarator_suffix" ): >=20 > + listener.enterDeclarator_suffix(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitDeclarator_suffix" ): >=20 > + listener.exitDeclarator_suffix(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def declarator_suffix(self): >=20 > + >=20 > + localctx =3D CParser.Declarator_suffixContext(self, self._ctx, s= elf.state) >=20 > + self.enterRule(localctx, 46, self.RULE_declarator_suffix) >=20 > + try: >=20 > + self.state =3D 386 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,39,self._ct= x) >=20 > + if la_ =3D=3D 1: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 370 >=20 > + self.match(CParser.T__39) >=20 > + self.state =3D 371 >=20 > + self.constant_expression() >=20 > + self.state =3D 372 >=20 > + self.match(CParser.T__40) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 374 >=20 > + self.match(CParser.T__39) >=20 > + self.state =3D 375 >=20 > + self.match(CParser.T__40) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 3: >=20 > + self.enterOuterAlt(localctx, 3) >=20 > + self.state =3D 376 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 377 >=20 > + self.parameter_type_list() >=20 > + self.state =3D 378 >=20 > + self.match(CParser.T__38) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 4: >=20 > + self.enterOuterAlt(localctx, 4) >=20 > + self.state =3D 380 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 381 >=20 > + self.identifier_list() >=20 > + self.state =3D 382 >=20 > + self.match(CParser.T__38) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 5: >=20 > + self.enterOuterAlt(localctx, 5) >=20 > + self.state =3D 384 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 385 >=20 > + self.match(CParser.T__38) >=20 > + pass >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class PointerContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def type_qualifier(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Type_qualifierC= ontext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Type_qualifierCo= ntext,i) >=20 > + >=20 > + >=20 > + def pointer(self): >=20 > + return self.getTypedRuleContext(CParser.PointerContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_pointer >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterPointer" ): >=20 > + listener.enterPointer(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitPointer" ): >=20 > + listener.exitPointer(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def pointer(self): >=20 > + >=20 > + localctx =3D CParser.PointerContext(self, self._ctx, self.state) >=20 > + self.enterRule(localctx, 48, self.RULE_pointer) >=20 > + try: >=20 > + self.state =3D 400 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,42,self._ct= x) >=20 > + if la_ =3D=3D 1: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 388 >=20 > + self.match(CParser.T__41) >=20 > + self.state =3D 390 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D 1 >=20 > + while _alt!=3D2 and _alt!=3DATN.INVALID_ALT_NUMBER: >=20 > + if _alt =3D=3D 1: >=20 > + self.state =3D 389 >=20 > + self.type_qualifier() >=20 > + >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + self.state =3D 392 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,40= ,self._ctx) >=20 > + >=20 > + self.state =3D 395 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,41,self= ._ctx) >=20 > + if la_ =3D=3D 1: >=20 > + self.state =3D 394 >=20 > + self.pointer() >=20 > + >=20 > + >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 397 >=20 > + self.match(CParser.T__41) >=20 > + self.state =3D 398 >=20 > + self.pointer() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 3: >=20 > + self.enterOuterAlt(localctx, 3) >=20 > + self.state =3D 399 >=20 > + self.match(CParser.T__41) >=20 > + pass >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Parameter_type_listContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def parameter_list(self): >=20 > + return self.getTypedRuleContext(CParser.Parameter_listContex= t,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_parameter_type_list >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterParameter_type_list" ): >=20 > + listener.enterParameter_type_list(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitParameter_type_list" ): >=20 > + listener.exitParameter_type_list(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def parameter_type_list(self): >=20 > + >=20 > + localctx =3D CParser.Parameter_type_listContext(self, self._ctx,= self.state) >=20 > + self.enterRule(localctx, 50, self.RULE_parameter_type_list) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 402 >=20 > + self.parameter_list() >=20 > + self.state =3D 408 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__3: >=20 > + self.state =3D 403 >=20 > + self.match(CParser.T__3) >=20 > + self.state =3D 405 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__28: >=20 > + self.state =3D 404 >=20 > + self.match(CParser.T__28) >=20 > + >=20 > + >=20 > + self.state =3D 407 >=20 > + self.match(CParser.T__42) >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Parameter_listContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def parameter_declaration(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Parameter_decla= rationContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Parameter_declar= ationContext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_parameter_list >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterParameter_list" ): >=20 > + listener.enterParameter_list(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitParameter_list" ): >=20 > + listener.exitParameter_list(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def parameter_list(self): >=20 > + >=20 > + localctx =3D CParser.Parameter_listContext(self, self._ctx, self= .state) >=20 > + self.enterRule(localctx, 52, self.RULE_parameter_list) >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 410 >=20 > + self.parameter_declaration() >=20 > + self.state =3D 418 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,46,self._c= tx) >=20 > + while _alt!=3D2 and _alt!=3DATN.INVALID_ALT_NUMBER: >=20 > + if _alt=3D=3D1: >=20 > + self.state =3D 411 >=20 > + self.match(CParser.T__3) >=20 > + self.state =3D 413 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,45,= self._ctx) >=20 > + if la_ =3D=3D 1: >=20 > + self.state =3D 412 >=20 > + self.match(CParser.T__28) >=20 > + >=20 > + >=20 > + self.state =3D 415 >=20 > + self.parameter_declaration() >=20 > + self.state =3D 420 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,46,sel= f._ctx) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Parameter_declarationContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def declaration_specifiers(self): >=20 > + return self.getTypedRuleContext(CParser.Declaration_specifie= rsContext,0) >=20 > + >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def declarator(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.DeclaratorConte= xt) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.DeclaratorContex= t,i) >=20 > + >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def abstract_declarator(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Abstract_declar= atorContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Abstract_declara= torContext,i) >=20 > + >=20 > + >=20 > + def IDENTIFIER(self): >=20 > + return self.getToken(CParser.IDENTIFIER, 0) >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def pointer(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.PointerContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.PointerContext,i= ) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_parameter_declaration >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterParameter_declaration" ): >=20 > + listener.enterParameter_declaration(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitParameter_declaration" ): >=20 > + listener.exitParameter_declaration(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def parameter_declaration(self): >=20 > + >=20 > + localctx =3D CParser.Parameter_declarationContext(self, self._ct= x, self.state) >=20 > + self.enterRule(localctx, 54, self.RULE_parameter_declaration) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.state =3D 439 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,51,self._ct= x) >=20 > + if la_ =3D=3D 1: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 421 >=20 > + self.declaration_specifiers() >=20 > + self.state =3D 426 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while ((((_la - 34)) & ~0x3f) =3D=3D 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__3= 9 - 34)) | (1 << (CParser.T__41 - 34)) | (1 << (CParser.IDENTIFIER - > 34)))) !=3D 0): >=20 > + self.state =3D 424 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,47,= self._ctx) >=20 > + if la_ =3D=3D 1: >=20 > + self.state =3D 422 >=20 > + self.declarator() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.state =3D 423 >=20 > + self.abstract_declarator() >=20 > + pass >=20 > + >=20 > + >=20 > + self.state =3D 428 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + self.state =3D 430 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__28: >=20 > + self.state =3D 429 >=20 > + self.match(CParser.T__28) >=20 > + >=20 > + >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 435 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while _la=3D=3DCParser.T__41: >=20 > + self.state =3D 432 >=20 > + self.pointer() >=20 > + self.state =3D 437 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + self.state =3D 438 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + pass >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Identifier_listContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def IDENTIFIER(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTokens(CParser.IDENTIFIER) >=20 > + else: >=20 > + return self.getToken(CParser.IDENTIFIER, i) >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_identifier_list >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterIdentifier_list" ): >=20 > + listener.enterIdentifier_list(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitIdentifier_list" ): >=20 > + listener.exitIdentifier_list(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def identifier_list(self): >=20 > + >=20 > + localctx =3D CParser.Identifier_listContext(self, self._ctx, sel= f.state) >=20 > + self.enterRule(localctx, 56, self.RULE_identifier_list) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 441 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + self.state =3D 446 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while _la=3D=3DCParser.T__3: >=20 > + self.state =3D 442 >=20 > + self.match(CParser.T__3) >=20 > + self.state =3D 443 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + self.state =3D 448 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Type_nameContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def specifier_qualifier_list(self): >=20 > + return self.getTypedRuleContext(CParser.Specifier_qualifier_= listContext,0) >=20 > + >=20 > + >=20 > + def abstract_declarator(self): >=20 > + return self.getTypedRuleContext(CParser.Abstract_declaratorC= ontext,0) >=20 > + >=20 > + >=20 > + def type_id(self): >=20 > + return self.getTypedRuleContext(CParser.Type_idContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_type_name >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterType_name" ): >=20 > + listener.enterType_name(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitType_name" ): >=20 > + listener.exitType_name(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def type_name(self): >=20 > + >=20 > + localctx =3D CParser.Type_nameContext(self, self._ctx, self.stat= e) >=20 > + self.enterRule(localctx, 58, self.RULE_type_name) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.state =3D 454 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,54,self._ct= x) >=20 > + if la_ =3D=3D 1: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 449 >=20 > + self.specifier_qualifier_list() >=20 > + self.state =3D 451 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if (((_la) & ~0x3f) =3D=3D 0 and ((1 << _la) & ((1 << CP= arser.T__37) | (1 << CParser.T__39) | (1 << CParser.T__41))) !=3D 0): >=20 > + self.state =3D 450 >=20 > + self.abstract_declarator() >=20 > + >=20 > + >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 453 >=20 > + self.type_id() >=20 > + pass >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Abstract_declaratorContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def pointer(self): >=20 > + return self.getTypedRuleContext(CParser.PointerContext,0) >=20 > + >=20 > + >=20 > + def direct_abstract_declarator(self): >=20 > + return self.getTypedRuleContext(CParser.Direct_abstract_decl= aratorContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_abstract_declarator >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterAbstract_declarator" ): >=20 > + listener.enterAbstract_declarator(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitAbstract_declarator" ): >=20 > + listener.exitAbstract_declarator(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def abstract_declarator(self): >=20 > + >=20 > + localctx =3D CParser.Abstract_declaratorContext(self, self._ctx,= self.state) >=20 > + self.enterRule(localctx, 60, self.RULE_abstract_declarator) >=20 > + try: >=20 > + self.state =3D 461 >=20 > + self._errHandler.sync(self) >=20 > + token =3D self._input.LA(1) >=20 > + if token in [CParser.T__41]: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 456 >=20 > + self.pointer() >=20 > + self.state =3D 458 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,55,self= ._ctx) >=20 > + if la_ =3D=3D 1: >=20 > + self.state =3D 457 >=20 > + self.direct_abstract_declarator() >=20 > + >=20 > + >=20 > + pass >=20 > + elif token in [CParser.T__37, CParser.T__39]: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 460 >=20 > + self.direct_abstract_declarator() >=20 > + pass >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Direct_abstract_declaratorContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def abstract_declarator(self): >=20 > + return self.getTypedRuleContext(CParser.Abstract_declaratorC= ontext,0) >=20 > + >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def abstract_declarator_suffix(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Abstract_declar= ator_suffixContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Abstract_declara= tor_suffixContext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_direct_abstract_declarator >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterDirect_abstract_declarator" ): >=20 > + listener.enterDirect_abstract_declarator(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitDirect_abstract_declarator" ): >=20 > + listener.exitDirect_abstract_declarator(self) >=20 > + >=20 > + >=20 > + >=20 > + def direct_abstract_declarator(self): >=20 > + >=20 > + localctx =3D CParser.Direct_abstract_declaratorContext(self, sel= f._ctx, self.state) >=20 > + self.enterRule(localctx, 62, self.RULE_direct_abstract_declarato= r) >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 468 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,57,self._ct= x) >=20 > + if la_ =3D=3D 1: >=20 > + self.state =3D 463 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 464 >=20 > + self.abstract_declarator() >=20 > + self.state =3D 465 >=20 > + self.match(CParser.T__38) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.state =3D 467 >=20 > + self.abstract_declarator_suffix() >=20 > + pass >=20 > + >=20 > + >=20 > + self.state =3D 473 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,58,self._c= tx) >=20 > + while _alt!=3D2 and _alt!=3DATN.INVALID_ALT_NUMBER: >=20 > + if _alt=3D=3D1: >=20 > + self.state =3D 470 >=20 > + self.abstract_declarator_suffix() >=20 > + self.state =3D 475 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,58,sel= f._ctx) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Abstract_declarator_suffixContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def constant_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Constant_expressionC= ontext,0) >=20 > + >=20 > + >=20 > + def parameter_type_list(self): >=20 > + return self.getTypedRuleContext(CParser.Parameter_type_listC= ontext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_abstract_declarator_suffix >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterAbstract_declarator_suffix" ): >=20 > + listener.enterAbstract_declarator_suffix(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitAbstract_declarator_suffix" ): >=20 > + listener.exitAbstract_declarator_suffix(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def abstract_declarator_suffix(self): >=20 > + >=20 > + localctx =3D CParser.Abstract_declarator_suffixContext(self, sel= f._ctx, self.state) >=20 > + self.enterRule(localctx, 64, self.RULE_abstract_declarator_suffi= x) >=20 > + try: >=20 > + self.state =3D 488 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,59,self._ct= x) >=20 > + if la_ =3D=3D 1: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 476 >=20 > + self.match(CParser.T__39) >=20 > + self.state =3D 477 >=20 > + self.match(CParser.T__40) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 478 >=20 > + self.match(CParser.T__39) >=20 > + self.state =3D 479 >=20 > + self.constant_expression() >=20 > + self.state =3D 480 >=20 > + self.match(CParser.T__40) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 3: >=20 > + self.enterOuterAlt(localctx, 3) >=20 > + self.state =3D 482 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 483 >=20 > + self.match(CParser.T__38) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 4: >=20 > + self.enterOuterAlt(localctx, 4) >=20 > + self.state =3D 484 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 485 >=20 > + self.parameter_type_list() >=20 > + self.state =3D 486 >=20 > + self.match(CParser.T__38) >=20 > + pass >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class InitializerContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def assignment_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Assignment_expressio= nContext,0) >=20 > + >=20 > + >=20 > + def initializer_list(self): >=20 > + return self.getTypedRuleContext(CParser.Initializer_listCont= ext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_initializer >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterInitializer" ): >=20 > + listener.enterInitializer(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitInitializer" ): >=20 > + listener.exitInitializer(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def initializer(self): >=20 > + >=20 > + localctx =3D CParser.InitializerContext(self, self._ctx, self.st= ate) >=20 > + self.enterRule(localctx, 66, self.RULE_initializer) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.state =3D 498 >=20 > + self._errHandler.sync(self) >=20 > + token =3D self._input.LA(1) >=20 > + if token in [CParser.T__37, CParser.T__41, CParser.T__43, CP= arser.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, CPar= ser.FLOATING_POINT_LITERAL]: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 490 >=20 > + self.assignment_expression() >=20 > + pass >=20 > + elif token in [CParser.T__0]: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 491 >=20 > + self.match(CParser.T__0) >=20 > + self.state =3D 492 >=20 > + self.initializer_list() >=20 > + self.state =3D 494 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__3: >=20 > + self.state =3D 493 >=20 > + self.match(CParser.T__3) >=20 > + >=20 > + >=20 > + self.state =3D 496 >=20 > + self.match(CParser.T__19) >=20 > + pass >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Initializer_listContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def initializer(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.InitializerCont= ext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.InitializerConte= xt,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_initializer_list >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterInitializer_list" ): >=20 > + listener.enterInitializer_list(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitInitializer_list" ): >=20 > + listener.exitInitializer_list(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def initializer_list(self): >=20 > + >=20 > + localctx =3D CParser.Initializer_listContext(self, self._ctx, se= lf.state) >=20 > + self.enterRule(localctx, 68, self.RULE_initializer_list) >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 500 >=20 > + self.initializer() >=20 > + self.state =3D 505 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,62,self._c= tx) >=20 > + while _alt!=3D2 and _alt!=3DATN.INVALID_ALT_NUMBER: >=20 > + if _alt=3D=3D1: >=20 > + self.state =3D 501 >=20 > + self.match(CParser.T__3) >=20 > + self.state =3D 502 >=20 > + self.initializer() >=20 > + self.state =3D 507 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,62,sel= f._ctx) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Argument_expression_listContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def assignment_expression(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Assignment_expr= essionContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Assignment_expre= ssionContext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_argument_expression_list >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterArgument_expression_list" ): >=20 > + listener.enterArgument_expression_list(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitArgument_expression_list" ): >=20 > + listener.exitArgument_expression_list(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def argument_expression_list(self): >=20 > + >=20 > + localctx =3D CParser.Argument_expression_listContext(self, self.= _ctx, self.state) >=20 > + self.enterRule(localctx, 70, self.RULE_argument_expression_list) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 508 >=20 > + self.assignment_expression() >=20 > + self.state =3D 510 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__28: >=20 > + self.state =3D 509 >=20 > + self.match(CParser.T__28) >=20 > + >=20 > + >=20 > + self.state =3D 519 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while _la=3D=3DCParser.T__3: >=20 > + self.state =3D 512 >=20 > + self.match(CParser.T__3) >=20 > + self.state =3D 513 >=20 > + self.assignment_expression() >=20 > + self.state =3D 515 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__28: >=20 > + self.state =3D 514 >=20 > + self.match(CParser.T__28) >=20 > + >=20 > + >=20 > + self.state =3D 521 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Additive_expressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def multiplicative_expression(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Multiplicative_= expressionContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Multiplicative_e= xpressionContext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_additive_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterAdditive_expression" ): >=20 > + listener.enterAdditive_expression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitAdditive_expression" ): >=20 > + listener.exitAdditive_expression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def additive_expression(self): >=20 > + >=20 > + localctx =3D CParser.Additive_expressionContext(self, self._ctx,= self.state) >=20 > + self.enterRule(localctx, 72, self.RULE_additive_expression) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 522 >=20 > + self.multiplicative_expression() >=20 > + self.state =3D 529 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while _la=3D=3DCParser.T__43 or _la=3D=3DCParser.T__44: >=20 > + self.state =3D 527 >=20 > + self._errHandler.sync(self) >=20 > + token =3D self._input.LA(1) >=20 > + if token in [CParser.T__43]: >=20 > + self.state =3D 523 >=20 > + self.match(CParser.T__43) >=20 > + self.state =3D 524 >=20 > + self.multiplicative_expression() >=20 > + pass >=20 > + elif token in [CParser.T__44]: >=20 > + self.state =3D 525 >=20 > + self.match(CParser.T__44) >=20 > + self.state =3D 526 >=20 > + self.multiplicative_expression() >=20 > + pass >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + >=20 > + self.state =3D 531 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Multiplicative_expressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def cast_expression(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Cast_expression= Context) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Cast_expressionC= ontext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_multiplicative_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterMultiplicative_expression" ): >=20 > + listener.enterMultiplicative_expression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitMultiplicative_expression" ): >=20 > + listener.exitMultiplicative_expression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def multiplicative_expression(self): >=20 > + >=20 > + localctx =3D CParser.Multiplicative_expressionContext(self, self= ._ctx, self.state) >=20 > + self.enterRule(localctx, 74, self.RULE_multiplicative_expression= ) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 532 >=20 > + self.cast_expression() >=20 > + self.state =3D 541 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while (((_la) & ~0x3f) =3D=3D 0 and ((1 << _la) & ((1 << CPa= rser.T__41) | (1 << CParser.T__45) | (1 << CParser.T__46))) !=3D 0): >=20 > + self.state =3D 539 >=20 > + self._errHandler.sync(self) >=20 > + token =3D self._input.LA(1) >=20 > + if token in [CParser.T__41]: >=20 > + self.state =3D 533 >=20 > + self.match(CParser.T__41) >=20 > + self.state =3D 534 >=20 > + self.cast_expression() >=20 > + pass >=20 > + elif token in [CParser.T__45]: >=20 > + self.state =3D 535 >=20 > + self.match(CParser.T__45) >=20 > + self.state =3D 536 >=20 > + self.cast_expression() >=20 > + pass >=20 > + elif token in [CParser.T__46]: >=20 > + self.state =3D 537 >=20 > + self.match(CParser.T__46) >=20 > + self.state =3D 538 >=20 > + self.cast_expression() >=20 > + pass >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + >=20 > + self.state =3D 543 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Cast_expressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def type_name(self): >=20 > + return self.getTypedRuleContext(CParser.Type_nameContext,0) >=20 > + >=20 > + >=20 > + def cast_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Cast_expressionConte= xt,0) >=20 > + >=20 > + >=20 > + def unary_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Unary_expressionCont= ext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_cast_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterCast_expression" ): >=20 > + listener.enterCast_expression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitCast_expression" ): >=20 > + listener.exitCast_expression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def cast_expression(self): >=20 > + >=20 > + localctx =3D CParser.Cast_expressionContext(self, self._ctx, sel= f.state) >=20 > + self.enterRule(localctx, 76, self.RULE_cast_expression) >=20 > + try: >=20 > + self.state =3D 550 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,70,self._ct= x) >=20 > + if la_ =3D=3D 1: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 544 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 545 >=20 > + self.type_name() >=20 > + self.state =3D 546 >=20 > + self.match(CParser.T__38) >=20 > + self.state =3D 547 >=20 > + self.cast_expression() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 549 >=20 > + self.unary_expression() >=20 > + pass >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Unary_expressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def postfix_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Postfix_expressionCo= ntext,0) >=20 > + >=20 > + >=20 > + def unary_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Unary_expressionCont= ext,0) >=20 > + >=20 > + >=20 > + def unary_operator(self): >=20 > + return self.getTypedRuleContext(CParser.Unary_operatorContex= t,0) >=20 > + >=20 > + >=20 > + def cast_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Cast_expressionConte= xt,0) >=20 > + >=20 > + >=20 > + def type_name(self): >=20 > + return self.getTypedRuleContext(CParser.Type_nameContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_unary_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterUnary_expression" ): >=20 > + listener.enterUnary_expression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitUnary_expression" ): >=20 > + listener.exitUnary_expression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def unary_expression(self): >=20 > + >=20 > + localctx =3D CParser.Unary_expressionContext(self, self._ctx, se= lf.state) >=20 > + self.enterRule(localctx, 78, self.RULE_unary_expression) >=20 > + try: >=20 > + self.state =3D 567 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,71,self._ct= x) >=20 > + if la_ =3D=3D 1: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 552 >=20 > + self.postfix_expression() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 553 >=20 > + self.match(CParser.T__47) >=20 > + self.state =3D 554 >=20 > + self.unary_expression() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 3: >=20 > + self.enterOuterAlt(localctx, 3) >=20 > + self.state =3D 555 >=20 > + self.match(CParser.T__48) >=20 > + self.state =3D 556 >=20 > + self.unary_expression() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 4: >=20 > + self.enterOuterAlt(localctx, 4) >=20 > + self.state =3D 557 >=20 > + self.unary_operator() >=20 > + self.state =3D 558 >=20 > + self.cast_expression() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 5: >=20 > + self.enterOuterAlt(localctx, 5) >=20 > + self.state =3D 560 >=20 > + self.match(CParser.T__49) >=20 > + self.state =3D 561 >=20 > + self.unary_expression() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 6: >=20 > + self.enterOuterAlt(localctx, 6) >=20 > + self.state =3D 562 >=20 > + self.match(CParser.T__49) >=20 > + self.state =3D 563 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 564 >=20 > + self.type_name() >=20 > + self.state =3D 565 >=20 > + self.match(CParser.T__38) >=20 > + pass >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Postfix_expressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + self.FuncCallText =3D '' >=20 > + self.p =3D None # Primary_expressionContext >=20 > + self.a =3D None # Token >=20 > + self.c =3D None # Argument_expression_listContext >=20 > + self.b =3D None # Token >=20 > + self.x =3D None # Token >=20 > + self.y =3D None # Token >=20 > + self.z =3D None # Token >=20 > + >=20 > + def primary_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Primary_expressionCo= ntext,0) >=20 > + >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def expression(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.ExpressionConte= xt) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.ExpressionContex= t,i) >=20 > + >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def macro_parameter_list(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Macro_parameter= _listContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Macro_parameter_= listContext,i) >=20 > + >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def argument_expression_list(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Argument_expres= sion_listContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Argument_express= ion_listContext,i) >=20 > + >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def IDENTIFIER(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTokens(CParser.IDENTIFIER) >=20 > + else: >=20 > + return self.getToken(CParser.IDENTIFIER, i) >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_postfix_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterPostfix_expression" ): >=20 > + listener.enterPostfix_expression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitPostfix_expression" ): >=20 > + listener.exitPostfix_expression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def postfix_expression(self): >=20 > + >=20 > + localctx =3D CParser.Postfix_expressionContext(self, self._ctx, = self.state) >=20 > + self.enterRule(localctx, 80, self.RULE_postfix_expression) >=20 > + >=20 > + self.FuncCallText=3D'' >=20 > + >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 569 >=20 > + localctx.p =3D self.primary_expression() >=20 > + self.FuncCallText +=3D (None if localctx.p is None else self= ._input.getText((localctx.p.start,localctx.p.stop))) >=20 > + self.state =3D 600 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,73,self._c= tx) >=20 > + while _alt!=3D2 and _alt!=3DATN.INVALID_ALT_NUMBER: >=20 > + if _alt=3D=3D1: >=20 > + self.state =3D 598 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,72,= self._ctx) >=20 > + if la_ =3D=3D 1: >=20 > + self.state =3D 571 >=20 > + self.match(CParser.T__39) >=20 > + self.state =3D 572 >=20 > + self.expression() >=20 > + self.state =3D 573 >=20 > + self.match(CParser.T__40) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.state =3D 575 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 576 >=20 > + localctx.a =3D self.match(CParser.T__38) >=20 > + 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, '') >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 3: >=20 > + self.state =3D 578 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 579 >=20 > + localctx.c =3D self.argument_expression_list() >=20 > + self.state =3D 580 >=20 > + localctx.b =3D self.match(CParser.T__38) >=20 > + 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)))) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 4: >=20 > + self.state =3D 583 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 584 >=20 > + self.macro_parameter_list() >=20 > + self.state =3D 585 >=20 > + self.match(CParser.T__38) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 5: >=20 > + self.state =3D 587 >=20 > + self.match(CParser.T__50) >=20 > + self.state =3D 588 >=20 > + localctx.x =3D self.match(CParser.IDENTIFIER) >=20 > + self.FuncCallText +=3D '.' + (None if localctx.x= is None else localctx.x.text) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 6: >=20 > + self.state =3D 590 >=20 > + self.match(CParser.T__41) >=20 > + self.state =3D 591 >=20 > + localctx.y =3D self.match(CParser.IDENTIFIER) >=20 > + self.FuncCallText =3D (None if localctx.y is Non= e else localctx.y.text) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 7: >=20 > + self.state =3D 593 >=20 > + self.match(CParser.T__51) >=20 > + self.state =3D 594 >=20 > + localctx.z =3D self.match(CParser.IDENTIFIER) >=20 > + self.FuncCallText +=3D '->' + (None if localctx.= z is None else localctx.z.text) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 8: >=20 > + self.state =3D 596 >=20 > + self.match(CParser.T__47) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 9: >=20 > + self.state =3D 597 >=20 > + self.match(CParser.T__48) >=20 > + pass >=20 > + >=20 > + >=20 > + self.state =3D 602 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,73,sel= f._ctx) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Macro_parameter_listContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def parameter_declaration(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Parameter_decla= rationContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Parameter_declar= ationContext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_macro_parameter_list >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterMacro_parameter_list" ): >=20 > + listener.enterMacro_parameter_list(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitMacro_parameter_list" ): >=20 > + listener.exitMacro_parameter_list(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def macro_parameter_list(self): >=20 > + >=20 > + localctx =3D CParser.Macro_parameter_listContext(self, self._ctx= , self.state) >=20 > + self.enterRule(localctx, 82, self.RULE_macro_parameter_list) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 603 >=20 > + self.parameter_declaration() >=20 > + self.state =3D 608 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while _la=3D=3DCParser.T__3: >=20 > + self.state =3D 604 >=20 > + self.match(CParser.T__3) >=20 > + self.state =3D 605 >=20 > + self.parameter_declaration() >=20 > + self.state =3D 610 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Unary_operatorContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_unary_operator >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterUnary_operator" ): >=20 > + listener.enterUnary_operator(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitUnary_operator" ): >=20 > + listener.exitUnary_operator(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def unary_operator(self): >=20 > + >=20 > + localctx =3D CParser.Unary_operatorContext(self, self._ctx, self= .state) >=20 > + self.enterRule(localctx, 84, self.RULE_unary_operator) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 611 >=20 > + _la =3D self._input.LA(1) >=20 > + if not((((_la) & ~0x3f) =3D=3D 0 and ((1 << _la) & ((1 << CP= arser.T__41) | (1 << CParser.T__43) | (1 << CParser.T__44) | (1 << > CParser.T__52) | (1 << CParser.T__53) | (1 << CParser.T__54))) !=3D 0)): >=20 > + self._errHandler.recoverInline(self) >=20 > + else: >=20 > + self._errHandler.reportMatch(self) >=20 > + self.consume() >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Primary_expressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def IDENTIFIER(self): >=20 > + return self.getToken(CParser.IDENTIFIER, 0) >=20 > + >=20 > + def constant(self): >=20 > + return self.getTypedRuleContext(CParser.ConstantContext,0) >=20 > + >=20 > + >=20 > + def expression(self): >=20 > + return self.getTypedRuleContext(CParser.ExpressionContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_primary_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterPrimary_expression" ): >=20 > + listener.enterPrimary_expression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitPrimary_expression" ): >=20 > + listener.exitPrimary_expression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def primary_expression(self): >=20 > + >=20 > + localctx =3D CParser.Primary_expressionContext(self, self._ctx, = self.state) >=20 > + self.enterRule(localctx, 86, self.RULE_primary_expression) >=20 > + try: >=20 > + self.state =3D 619 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,75,self._ct= x) >=20 > + if la_ =3D=3D 1: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 613 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 614 >=20 > + self.constant() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 3: >=20 > + self.enterOuterAlt(localctx, 3) >=20 > + self.state =3D 615 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 616 >=20 > + self.expression() >=20 > + self.state =3D 617 >=20 > + self.match(CParser.T__38) >=20 > + pass >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class ConstantContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def HEX_LITERAL(self): >=20 > + return self.getToken(CParser.HEX_LITERAL, 0) >=20 > + >=20 > + def OCTAL_LITERAL(self): >=20 > + return self.getToken(CParser.OCTAL_LITERAL, 0) >=20 > + >=20 > + def DECIMAL_LITERAL(self): >=20 > + return self.getToken(CParser.DECIMAL_LITERAL, 0) >=20 > + >=20 > + def CHARACTER_LITERAL(self): >=20 > + return self.getToken(CParser.CHARACTER_LITERAL, 0) >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def IDENTIFIER(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTokens(CParser.IDENTIFIER) >=20 > + else: >=20 > + return self.getToken(CParser.IDENTIFIER, i) >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def STRING_LITERAL(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTokens(CParser.STRING_LITERAL) >=20 > + else: >=20 > + return self.getToken(CParser.STRING_LITERAL, i) >=20 > + >=20 > + def FLOATING_POINT_LITERAL(self): >=20 > + return self.getToken(CParser.FLOATING_POINT_LITERAL, 0) >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_constant >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterConstant" ): >=20 > + listener.enterConstant(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitConstant" ): >=20 > + listener.exitConstant(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def constant(self): >=20 > + >=20 > + localctx =3D CParser.ConstantContext(self, self._ctx, self.state= ) >=20 > + self.enterRule(localctx, 88, self.RULE_constant) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.state =3D 647 >=20 > + self._errHandler.sync(self) >=20 > + token =3D self._input.LA(1) >=20 > + if token in [CParser.HEX_LITERAL]: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 621 >=20 > + self.match(CParser.HEX_LITERAL) >=20 > + pass >=20 > + elif token in [CParser.OCTAL_LITERAL]: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 622 >=20 > + self.match(CParser.OCTAL_LITERAL) >=20 > + pass >=20 > + elif token in [CParser.DECIMAL_LITERAL]: >=20 > + self.enterOuterAlt(localctx, 3) >=20 > + self.state =3D 623 >=20 > + self.match(CParser.DECIMAL_LITERAL) >=20 > + pass >=20 > + elif token in [CParser.CHARACTER_LITERAL]: >=20 > + self.enterOuterAlt(localctx, 4) >=20 > + self.state =3D 624 >=20 > + self.match(CParser.CHARACTER_LITERAL) >=20 > + pass >=20 > + elif token in [CParser.IDENTIFIER, CParser.STRING_LITERAL]: >=20 > + self.enterOuterAlt(localctx, 5) >=20 > + self.state =3D 636 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D 1 >=20 > + while _alt!=3D2 and _alt!=3DATN.INVALID_ALT_NUMBER: >=20 > + if _alt =3D=3D 1: >=20 > + self.state =3D 628 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while _la=3D=3DCParser.IDENTIFIER: >=20 > + self.state =3D 625 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + self.state =3D 630 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + self.state =3D 632 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D 1 >=20 > + while _alt!=3D2 and _alt!=3DATN.INVALID_ALT_NUMB= ER: >=20 > + if _alt =3D=3D 1: >=20 > + self.state =3D 631 >=20 > + self.match(CParser.STRING_LITERAL) >=20 > + >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + self.state =3D 634 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._= input,77,self._ctx) >=20 > + >=20 > + >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + self.state =3D 638 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,78= ,self._ctx) >=20 > + >=20 > + self.state =3D 643 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while _la=3D=3DCParser.IDENTIFIER: >=20 > + self.state =3D 640 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + self.state =3D 645 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + pass >=20 > + elif token in [CParser.FLOATING_POINT_LITERAL]: >=20 > + self.enterOuterAlt(localctx, 6) >=20 > + self.state =3D 646 >=20 > + self.match(CParser.FLOATING_POINT_LITERAL) >=20 > + pass >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class ExpressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def assignment_expression(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Assignment_expr= essionContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Assignment_expre= ssionContext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterExpression" ): >=20 > + listener.enterExpression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitExpression" ): >=20 > + listener.exitExpression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def expression(self): >=20 > + >=20 > + localctx =3D CParser.ExpressionContext(self, self._ctx, self.sta= te) >=20 > + self.enterRule(localctx, 90, self.RULE_expression) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 649 >=20 > + self.assignment_expression() >=20 > + self.state =3D 654 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while _la=3D=3DCParser.T__3: >=20 > + self.state =3D 650 >=20 > + self.match(CParser.T__3) >=20 > + self.state =3D 651 >=20 > + self.assignment_expression() >=20 > + self.state =3D 656 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Constant_expressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def conditional_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Conditional_expressi= onContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_constant_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterConstant_expression" ): >=20 > + listener.enterConstant_expression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitConstant_expression" ): >=20 > + listener.exitConstant_expression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def constant_expression(self): >=20 > + >=20 > + localctx =3D CParser.Constant_expressionContext(self, self._ctx,= self.state) >=20 > + self.enterRule(localctx, 92, self.RULE_constant_expression) >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 657 >=20 > + self.conditional_expression() >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Assignment_expressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def lvalue(self): >=20 > + return self.getTypedRuleContext(CParser.LvalueContext,0) >=20 > + >=20 > + >=20 > + def assignment_operator(self): >=20 > + return self.getTypedRuleContext(CParser.Assignment_operatorC= ontext,0) >=20 > + >=20 > + >=20 > + def assignment_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Assignment_expressio= nContext,0) >=20 > + >=20 > + >=20 > + def conditional_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Conditional_expressi= onContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_assignment_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterAssignment_expression" ): >=20 > + listener.enterAssignment_expression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitAssignment_expression" ): >=20 > + listener.exitAssignment_expression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def assignment_expression(self): >=20 > + >=20 > + localctx =3D CParser.Assignment_expressionContext(self, self._ct= x, self.state) >=20 > + self.enterRule(localctx, 94, self.RULE_assignment_expression) >=20 > + try: >=20 > + self.state =3D 664 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,82,self._ct= x) >=20 > + if la_ =3D=3D 1: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 659 >=20 > + self.lvalue() >=20 > + self.state =3D 660 >=20 > + self.assignment_operator() >=20 > + self.state =3D 661 >=20 > + self.assignment_expression() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 663 >=20 > + self.conditional_expression() >=20 > + pass >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class LvalueContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def unary_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Unary_expressionCont= ext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_lvalue >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterLvalue" ): >=20 > + listener.enterLvalue(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitLvalue" ): >=20 > + listener.exitLvalue(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def lvalue(self): >=20 > + >=20 > + localctx =3D CParser.LvalueContext(self, self._ctx, self.state) >=20 > + self.enterRule(localctx, 96, self.RULE_lvalue) >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 666 >=20 > + self.unary_expression() >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Assignment_operatorContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_assignment_operator >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterAssignment_operator" ): >=20 > + listener.enterAssignment_operator(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitAssignment_operator" ): >=20 > + listener.exitAssignment_operator(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def assignment_operator(self): >=20 > + >=20 > + localctx =3D CParser.Assignment_operatorContext(self, self._ctx,= self.state) >=20 > + self.enterRule(localctx, 98, self.RULE_assignment_operator) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 668 >=20 > + _la =3D self._input.LA(1) >=20 > + if not(((((_la - 5)) & ~0x3f) =3D=3D 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)))) !=3D 0)): >=20 > + self._errHandler.recoverInline(self) >=20 > + else: >=20 > + self._errHandler.reportMatch(self) >=20 > + self.consume() >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Conditional_expressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + self.e =3D None # Logical_or_expressionContext >=20 > + >=20 > + def logical_or_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Logical_or_expressio= nContext,0) >=20 > + >=20 > + >=20 > + def expression(self): >=20 > + return self.getTypedRuleContext(CParser.ExpressionContext,0) >=20 > + >=20 > + >=20 > + def conditional_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Conditional_expressi= onContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_conditional_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterConditional_expression" ): >=20 > + listener.enterConditional_expression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitConditional_expression" ): >=20 > + listener.exitConditional_expression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def conditional_expression(self): >=20 > + >=20 > + localctx =3D CParser.Conditional_expressionContext(self, self._c= tx, self.state) >=20 > + self.enterRule(localctx, 100, self.RULE_conditional_expression) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 670 >=20 > + localctx.e =3D self.logical_or_expression() >=20 > + self.state =3D 677 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__65: >=20 > + self.state =3D 671 >=20 > + self.match(CParser.T__65) >=20 > + self.state =3D 672 >=20 > + self.expression() >=20 > + self.state =3D 673 >=20 > + self.match(CParser.T__22) >=20 > + self.state =3D 674 >=20 > + self.conditional_expression() >=20 > + self.StorePredicateExpression((None if localctx.e is Non= e 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.sto= p).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)))) >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Logical_or_expressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def logical_and_expression(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Logical_and_exp= ressionContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Logical_and_expr= essionContext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_logical_or_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterLogical_or_expression" ): >=20 > + listener.enterLogical_or_expression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitLogical_or_expression" ): >=20 > + listener.exitLogical_or_expression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def logical_or_expression(self): >=20 > + >=20 > + localctx =3D CParser.Logical_or_expressionContext(self, self._ct= x, self.state) >=20 > + self.enterRule(localctx, 102, self.RULE_logical_or_expression) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 679 >=20 > + self.logical_and_expression() >=20 > + self.state =3D 684 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while _la=3D=3DCParser.T__66: >=20 > + self.state =3D 680 >=20 > + self.match(CParser.T__66) >=20 > + self.state =3D 681 >=20 > + self.logical_and_expression() >=20 > + self.state =3D 686 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Logical_and_expressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def inclusive_or_expression(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Inclusive_or_ex= pressionContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Inclusive_or_exp= ressionContext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_logical_and_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterLogical_and_expression" ): >=20 > + listener.enterLogical_and_expression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitLogical_and_expression" ): >=20 > + listener.exitLogical_and_expression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def logical_and_expression(self): >=20 > + >=20 > + localctx =3D CParser.Logical_and_expressionContext(self, self._c= tx, self.state) >=20 > + self.enterRule(localctx, 104, self.RULE_logical_and_expression) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 687 >=20 > + self.inclusive_or_expression() >=20 > + self.state =3D 692 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while _la=3D=3DCParser.T__67: >=20 > + self.state =3D 688 >=20 > + self.match(CParser.T__67) >=20 > + self.state =3D 689 >=20 > + self.inclusive_or_expression() >=20 > + self.state =3D 694 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Inclusive_or_expressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def exclusive_or_expression(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Exclusive_or_ex= pressionContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Exclusive_or_exp= ressionContext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_inclusive_or_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterInclusive_or_expression" ): >=20 > + listener.enterInclusive_or_expression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitInclusive_or_expression" ): >=20 > + listener.exitInclusive_or_expression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def inclusive_or_expression(self): >=20 > + >=20 > + localctx =3D CParser.Inclusive_or_expressionContext(self, self._= ctx, self.state) >=20 > + self.enterRule(localctx, 106, self.RULE_inclusive_or_expression) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 695 >=20 > + self.exclusive_or_expression() >=20 > + self.state =3D 700 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while _la=3D=3DCParser.T__68: >=20 > + self.state =3D 696 >=20 > + self.match(CParser.T__68) >=20 > + self.state =3D 697 >=20 > + self.exclusive_or_expression() >=20 > + self.state =3D 702 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Exclusive_or_expressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def and_expression(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.And_expressionC= ontext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.And_expressionCo= ntext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_exclusive_or_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterExclusive_or_expression" ): >=20 > + listener.enterExclusive_or_expression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitExclusive_or_expression" ): >=20 > + listener.exitExclusive_or_expression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def exclusive_or_expression(self): >=20 > + >=20 > + localctx =3D CParser.Exclusive_or_expressionContext(self, self._= ctx, self.state) >=20 > + self.enterRule(localctx, 108, self.RULE_exclusive_or_expression) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 703 >=20 > + self.and_expression() >=20 > + self.state =3D 708 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while _la=3D=3DCParser.T__69: >=20 > + self.state =3D 704 >=20 > + self.match(CParser.T__69) >=20 > + self.state =3D 705 >=20 > + self.and_expression() >=20 > + self.state =3D 710 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class And_expressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def equality_expression(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Equality_expres= sionContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Equality_express= ionContext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_and_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterAnd_expression" ): >=20 > + listener.enterAnd_expression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitAnd_expression" ): >=20 > + listener.exitAnd_expression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def and_expression(self): >=20 > + >=20 > + localctx =3D CParser.And_expressionContext(self, self._ctx, self= .state) >=20 > + self.enterRule(localctx, 110, self.RULE_and_expression) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 711 >=20 > + self.equality_expression() >=20 > + self.state =3D 716 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while _la=3D=3DCParser.T__52: >=20 > + self.state =3D 712 >=20 > + self.match(CParser.T__52) >=20 > + self.state =3D 713 >=20 > + self.equality_expression() >=20 > + self.state =3D 718 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Equality_expressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def relational_expression(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Relational_expr= essionContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Relational_expre= ssionContext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_equality_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterEquality_expression" ): >=20 > + listener.enterEquality_expression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitEquality_expression" ): >=20 > + listener.exitEquality_expression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def equality_expression(self): >=20 > + >=20 > + localctx =3D CParser.Equality_expressionContext(self, self._ctx,= self.state) >=20 > + self.enterRule(localctx, 112, self.RULE_equality_expression) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 719 >=20 > + self.relational_expression() >=20 > + self.state =3D 724 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while _la=3D=3DCParser.T__70 or _la=3D=3DCParser.T__71: >=20 > + self.state =3D 720 >=20 > + _la =3D self._input.LA(1) >=20 > + if not(_la=3D=3DCParser.T__70 or _la=3D=3DCParser.T__71)= : >=20 > + self._errHandler.recoverInline(self) >=20 > + else: >=20 > + self._errHandler.reportMatch(self) >=20 > + self.consume() >=20 > + self.state =3D 721 >=20 > + self.relational_expression() >=20 > + self.state =3D 726 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Relational_expressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def shift_expression(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Shift_expressio= nContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Shift_expression= Context,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_relational_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterRelational_expression" ): >=20 > + listener.enterRelational_expression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitRelational_expression" ): >=20 > + listener.exitRelational_expression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def relational_expression(self): >=20 > + >=20 > + localctx =3D CParser.Relational_expressionContext(self, self._ct= x, self.state) >=20 > + self.enterRule(localctx, 114, self.RULE_relational_expression) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 727 >=20 > + self.shift_expression() >=20 > + self.state =3D 732 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while ((((_la - 73)) & ~0x3f) =3D=3D 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)))) !=3D 0): >=20 > + self.state =3D 728 >=20 > + _la =3D self._input.LA(1) >=20 > + if not(((((_la - 73)) & ~0x3f) =3D=3D 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)))) !=3D 0)): >=20 > + self._errHandler.recoverInline(self) >=20 > + else: >=20 > + self._errHandler.reportMatch(self) >=20 > + self.consume() >=20 > + self.state =3D 729 >=20 > + self.shift_expression() >=20 > + self.state =3D 734 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Shift_expressionContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def additive_expression(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.Additive_expres= sionContext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.Additive_express= ionContext,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_shift_expression >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterShift_expression" ): >=20 > + listener.enterShift_expression(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitShift_expression" ): >=20 > + listener.exitShift_expression(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def shift_expression(self): >=20 > + >=20 > + localctx =3D CParser.Shift_expressionContext(self, self._ctx, se= lf.state) >=20 > + self.enterRule(localctx, 116, self.RULE_shift_expression) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 735 >=20 > + self.additive_expression() >=20 > + self.state =3D 740 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while _la=3D=3DCParser.T__76 or _la=3D=3DCParser.T__77: >=20 > + self.state =3D 736 >=20 > + _la =3D self._input.LA(1) >=20 > + if not(_la=3D=3DCParser.T__76 or _la=3D=3DCParser.T__77)= : >=20 > + self._errHandler.recoverInline(self) >=20 > + else: >=20 > + self._errHandler.reportMatch(self) >=20 > + self.consume() >=20 > + self.state =3D 737 >=20 > + self.additive_expression() >=20 > + self.state =3D 742 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class StatementContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def labeled_statement(self): >=20 > + return self.getTypedRuleContext(CParser.Labeled_statementCon= text,0) >=20 > + >=20 > + >=20 > + def compound_statement(self): >=20 > + return self.getTypedRuleContext(CParser.Compound_statementCo= ntext,0) >=20 > + >=20 > + >=20 > + def expression_statement(self): >=20 > + return self.getTypedRuleContext(CParser.Expression_statement= Context,0) >=20 > + >=20 > + >=20 > + def selection_statement(self): >=20 > + return self.getTypedRuleContext(CParser.Selection_statementC= ontext,0) >=20 > + >=20 > + >=20 > + def iteration_statement(self): >=20 > + return self.getTypedRuleContext(CParser.Iteration_statementC= ontext,0) >=20 > + >=20 > + >=20 > + def jump_statement(self): >=20 > + return self.getTypedRuleContext(CParser.Jump_statementContex= t,0) >=20 > + >=20 > + >=20 > + def macro_statement(self): >=20 > + return self.getTypedRuleContext(CParser.Macro_statementConte= xt,0) >=20 > + >=20 > + >=20 > + def asm2_statement(self): >=20 > + return self.getTypedRuleContext(CParser.Asm2_statementContex= t,0) >=20 > + >=20 > + >=20 > + def asm1_statement(self): >=20 > + return self.getTypedRuleContext(CParser.Asm1_statementContex= t,0) >=20 > + >=20 > + >=20 > + def asm_statement(self): >=20 > + return self.getTypedRuleContext(CParser.Asm_statementContext= ,0) >=20 > + >=20 > + >=20 > + def declaration(self): >=20 > + return self.getTypedRuleContext(CParser.DeclarationContext,0= ) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_statement >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterStatement" ): >=20 > + listener.enterStatement(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitStatement" ): >=20 > + listener.exitStatement(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def statement(self): >=20 > + >=20 > + localctx =3D CParser.StatementContext(self, self._ctx, self.stat= e) >=20 > + self.enterRule(localctx, 118, self.RULE_statement) >=20 > + try: >=20 > + self.state =3D 754 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,92,self._ct= x) >=20 > + if la_ =3D=3D 1: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 743 >=20 > + self.labeled_statement() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 744 >=20 > + self.compound_statement() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 3: >=20 > + self.enterOuterAlt(localctx, 3) >=20 > + self.state =3D 745 >=20 > + self.expression_statement() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 4: >=20 > + self.enterOuterAlt(localctx, 4) >=20 > + self.state =3D 746 >=20 > + self.selection_statement() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 5: >=20 > + self.enterOuterAlt(localctx, 5) >=20 > + self.state =3D 747 >=20 > + self.iteration_statement() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 6: >=20 > + self.enterOuterAlt(localctx, 6) >=20 > + self.state =3D 748 >=20 > + self.jump_statement() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 7: >=20 > + self.enterOuterAlt(localctx, 7) >=20 > + self.state =3D 749 >=20 > + self.macro_statement() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 8: >=20 > + self.enterOuterAlt(localctx, 8) >=20 > + self.state =3D 750 >=20 > + self.asm2_statement() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 9: >=20 > + self.enterOuterAlt(localctx, 9) >=20 > + self.state =3D 751 >=20 > + self.asm1_statement() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 10: >=20 > + self.enterOuterAlt(localctx, 10) >=20 > + self.state =3D 752 >=20 > + self.asm_statement() >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 11: >=20 > + self.enterOuterAlt(localctx, 11) >=20 > + self.state =3D 753 >=20 > + self.declaration() >=20 > + pass >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Asm2_statementContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def IDENTIFIER(self): >=20 > + return self.getToken(CParser.IDENTIFIER, 0) >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_asm2_statement >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterAsm2_statement" ): >=20 > + listener.enterAsm2_statement(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitAsm2_statement" ): >=20 > + listener.exitAsm2_statement(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def asm2_statement(self): >=20 > + >=20 > + localctx =3D CParser.Asm2_statementContext(self, self._ctx, self= .state) >=20 > + self.enterRule(localctx, 120, self.RULE_asm2_statement) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 757 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if _la=3D=3DCParser.T__78: >=20 > + self.state =3D 756 >=20 > + self.match(CParser.T__78) >=20 > + >=20 > + >=20 > + self.state =3D 759 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + self.state =3D 760 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 764 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,94,self._c= tx) >=20 > + while _alt!=3D2 and _alt!=3DATN.INVALID_ALT_NUMBER: >=20 > + if _alt=3D=3D1: >=20 > + self.state =3D 761 >=20 > + _la =3D self._input.LA(1) >=20 > + if _la <=3D 0 or _la=3D=3DCParser.T__1: >=20 > + self._errHandler.recoverInline(self) >=20 > + else: >=20 > + self._errHandler.reportMatch(self) >=20 > + self.consume() >=20 > + self.state =3D 766 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,94,sel= f._ctx) >=20 > + >=20 > + self.state =3D 767 >=20 > + self.match(CParser.T__38) >=20 > + self.state =3D 768 >=20 > + self.match(CParser.T__1) >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Asm1_statementContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_asm1_statement >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterAsm1_statement" ): >=20 > + listener.enterAsm1_statement(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitAsm1_statement" ): >=20 > + listener.exitAsm1_statement(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def asm1_statement(self): >=20 > + >=20 > + localctx =3D CParser.Asm1_statementContext(self, self._ctx, self= .state) >=20 > + self.enterRule(localctx, 122, self.RULE_asm1_statement) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 770 >=20 > + self.match(CParser.T__79) >=20 > + self.state =3D 771 >=20 > + self.match(CParser.T__0) >=20 > + self.state =3D 775 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while (((_la) & ~0x3f) =3D=3D 0 and ((1 << _la) & ((1 << CPa= rser.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 << C= Parser.T__20) | (1 << CParser.T__21) | (1 << CParser.T__22) | (1 << > CParser.T__23) | (1 << CParser.T__24) | (1 << CParser.T__25) | (1 << CPar= ser.T__26) | (1 << CParser.T__27) | (1 << CParser.T__28) | (1 << > CParser.T__29) | (1 << CParser.T__30) | (1 << CParser.T__31) | (1 << CPar= ser.T__32) | (1 << CParser.T__33) | (1 << CParser.T__34) | (1 << > CParser.T__35) | (1 << CParser.T__36) | (1 << CParser.T__37) | (1 << CPar= ser.T__38) | (1 << CParser.T__39) | (1 << CParser.T__40) | (1 << > CParser.T__41) | (1 << CParser.T__42) | (1 << CParser.T__43) | (1 << CPar= ser.T__44) | (1 << CParser.T__45) | (1 << CParser.T__46) | (1 << > CParser.T__47) | (1 << CParser.T__48) | (1 << CParser.T__49) | (1 << CPar= ser.T__50) | (1 << CParser.T__51) | (1 << CParser.T__52) | (1 << > CParser.T__53) | (1 << CParser.T__54) | (1 << CParser.T__55) | (1 << CPar= ser.T__56) | (1 << CParser.T__57) | (1 << CParser.T__58) | (1 << > CParser.T__59) | (1 << CParser.T__60) | (1 << CParser.T__61) | (1 << CPar= ser.T__62))) !=3D 0) or ((((_la - 64)) & ~0x3f) =3D=3D 0 and ((1 << (_la - = 64)) > & ((1 << (CParser.T__63 - 64)) | (1 << (CParser.T__64 - 64)) | (1 << (CPa= rser.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__7= 4 - 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 << (CParse= r.T__84 - 64)) | (1 << (CParser.T__85 - 64)) | (1 << (CParser.T__86 - 64)) > | (1 << (CParser.T__87 - 64)) | (1 << (CParser.T__88 - 64)) | (1 << (CPar= ser.T__89 - 64)) | (1 << (CParser.T__90 - 64)) | (1 << (CParser.T__91 - > 64)) | (1 << (CParser.IDENTIFIER - 64)) | (1 << (CParser.CHARACTER_LITERA= L - 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)))) !=3D 0): >=20 > + self.state =3D 772 >=20 > + _la =3D self._input.LA(1) >=20 > + if _la <=3D 0 or _la=3D=3DCParser.T__19: >=20 > + self._errHandler.recoverInline(self) >=20 > + else: >=20 > + self._errHandler.reportMatch(self) >=20 > + self.consume() >=20 > + self.state =3D 777 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + self.state =3D 778 >=20 > + self.match(CParser.T__19) >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Asm_statementContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_asm_statement >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterAsm_statement" ): >=20 > + listener.enterAsm_statement(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitAsm_statement" ): >=20 > + listener.exitAsm_statement(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def asm_statement(self): >=20 > + >=20 > + localctx =3D CParser.Asm_statementContext(self, self._ctx, self.= state) >=20 > + self.enterRule(localctx, 124, self.RULE_asm_statement) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 780 >=20 > + self.match(CParser.T__80) >=20 > + self.state =3D 781 >=20 > + self.match(CParser.T__0) >=20 > + self.state =3D 785 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + while (((_la) & ~0x3f) =3D=3D 0 and ((1 << _la) & ((1 << CPa= rser.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 << C= Parser.T__20) | (1 << CParser.T__21) | (1 << CParser.T__22) | (1 << > CParser.T__23) | (1 << CParser.T__24) | (1 << CParser.T__25) | (1 << CPar= ser.T__26) | (1 << CParser.T__27) | (1 << CParser.T__28) | (1 << > CParser.T__29) | (1 << CParser.T__30) | (1 << CParser.T__31) | (1 << CPar= ser.T__32) | (1 << CParser.T__33) | (1 << CParser.T__34) | (1 << > CParser.T__35) | (1 << CParser.T__36) | (1 << CParser.T__37) | (1 << CPar= ser.T__38) | (1 << CParser.T__39) | (1 << CParser.T__40) | (1 << > CParser.T__41) | (1 << CParser.T__42) | (1 << CParser.T__43) | (1 << CPar= ser.T__44) | (1 << CParser.T__45) | (1 << CParser.T__46) | (1 << > CParser.T__47) | (1 << CParser.T__48) | (1 << CParser.T__49) | (1 << CPar= ser.T__50) | (1 << CParser.T__51) | (1 << CParser.T__52) | (1 << > CParser.T__53) | (1 << CParser.T__54) | (1 << CParser.T__55) | (1 << CPar= ser.T__56) | (1 << CParser.T__57) | (1 << CParser.T__58) | (1 << > CParser.T__59) | (1 << CParser.T__60) | (1 << CParser.T__61) | (1 << CPar= ser.T__62))) !=3D 0) or ((((_la - 64)) & ~0x3f) =3D=3D 0 and ((1 << (_la - = 64)) > & ((1 << (CParser.T__63 - 64)) | (1 << (CParser.T__64 - 64)) | (1 << (CPa= rser.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__7= 4 - 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 << (CParse= r.T__84 - 64)) | (1 << (CParser.T__85 - 64)) | (1 << (CParser.T__86 - 64)) > | (1 << (CParser.T__87 - 64)) | (1 << (CParser.T__88 - 64)) | (1 << (CPar= ser.T__89 - 64)) | (1 << (CParser.T__90 - 64)) | (1 << (CParser.T__91 - > 64)) | (1 << (CParser.IDENTIFIER - 64)) | (1 << (CParser.CHARACTER_LITERA= L - 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)))) !=3D 0): >=20 > + self.state =3D 782 >=20 > + _la =3D self._input.LA(1) >=20 > + if _la <=3D 0 or _la=3D=3DCParser.T__19: >=20 > + self._errHandler.recoverInline(self) >=20 > + else: >=20 > + self._errHandler.reportMatch(self) >=20 > + self.consume() >=20 > + self.state =3D 787 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + >=20 > + self.state =3D 788 >=20 > + self.match(CParser.T__19) >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Macro_statementContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def IDENTIFIER(self): >=20 > + return self.getToken(CParser.IDENTIFIER, 0) >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def declaration(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.DeclarationCont= ext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.DeclarationConte= xt,i) >=20 > + >=20 > + >=20 > + def statement_list(self): >=20 > + return self.getTypedRuleContext(CParser.Statement_listContex= t,0) >=20 > + >=20 > + >=20 > + def expression(self): >=20 > + return self.getTypedRuleContext(CParser.ExpressionContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_macro_statement >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterMacro_statement" ): >=20 > + listener.enterMacro_statement(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitMacro_statement" ): >=20 > + listener.exitMacro_statement(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def macro_statement(self): >=20 > + >=20 > + localctx =3D CParser.Macro_statementContext(self, self._ctx, sel= f.state) >=20 > + self.enterRule(localctx, 126, self.RULE_macro_statement) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 790 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + self.state =3D 791 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 795 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,97,self._c= tx) >=20 > + while _alt!=3D2 and _alt!=3DATN.INVALID_ALT_NUMBER: >=20 > + if _alt=3D=3D1: >=20 > + self.state =3D 792 >=20 > + self.declaration() >=20 > + self.state =3D 797 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,97,sel= f._ctx) >=20 > + >=20 > + self.state =3D 799 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,98,self._ct= x) >=20 > + if la_ =3D=3D 1: >=20 > + self.state =3D 798 >=20 > + self.statement_list() >=20 > + >=20 > + >=20 > + self.state =3D 802 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if ((((_la - 38)) & ~0x3f) =3D=3D 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__4= 7 - 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)))) !=3D 0): >=20 > + self.state =3D 801 >=20 > + self.expression() >=20 > + >=20 > + >=20 > + self.state =3D 804 >=20 > + self.match(CParser.T__38) >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Labeled_statementContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def IDENTIFIER(self): >=20 > + return self.getToken(CParser.IDENTIFIER, 0) >=20 > + >=20 > + def statement(self): >=20 > + return self.getTypedRuleContext(CParser.StatementContext,0) >=20 > + >=20 > + >=20 > + def constant_expression(self): >=20 > + return self.getTypedRuleContext(CParser.Constant_expressionC= ontext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_labeled_statement >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterLabeled_statement" ): >=20 > + listener.enterLabeled_statement(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitLabeled_statement" ): >=20 > + listener.exitLabeled_statement(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def labeled_statement(self): >=20 > + >=20 > + localctx =3D CParser.Labeled_statementContext(self, self._ctx, s= elf.state) >=20 > + self.enterRule(localctx, 128, self.RULE_labeled_statement) >=20 > + try: >=20 > + self.state =3D 817 >=20 > + self._errHandler.sync(self) >=20 > + token =3D self._input.LA(1) >=20 > + if token in [CParser.IDENTIFIER]: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 806 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + self.state =3D 807 >=20 > + self.match(CParser.T__22) >=20 > + self.state =3D 808 >=20 > + self.statement() >=20 > + pass >=20 > + elif token in [CParser.T__81]: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 809 >=20 > + self.match(CParser.T__81) >=20 > + self.state =3D 810 >=20 > + self.constant_expression() >=20 > + self.state =3D 811 >=20 > + self.match(CParser.T__22) >=20 > + self.state =3D 812 >=20 > + self.statement() >=20 > + pass >=20 > + elif token in [CParser.T__82]: >=20 > + self.enterOuterAlt(localctx, 3) >=20 > + self.state =3D 814 >=20 > + self.match(CParser.T__82) >=20 > + self.state =3D 815 >=20 > + self.match(CParser.T__22) >=20 > + self.state =3D 816 >=20 > + self.statement() >=20 > + pass >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Compound_statementContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def declaration(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.DeclarationCont= ext) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.DeclarationConte= xt,i) >=20 > + >=20 > + >=20 > + def statement_list(self): >=20 > + return self.getTypedRuleContext(CParser.Statement_listContex= t,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_compound_statement >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterCompound_statement" ): >=20 > + listener.enterCompound_statement(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitCompound_statement" ): >=20 > + listener.exitCompound_statement(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def compound_statement(self): >=20 > + >=20 > + localctx =3D CParser.Compound_statementContext(self, self._ctx, = self.state) >=20 > + self.enterRule(localctx, 130, self.RULE_compound_statement) >=20 > + self._la =3D 0 # Token type >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 819 >=20 > + self.match(CParser.T__0) >=20 > + self.state =3D 823 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,101,self._= ctx) >=20 > + while _alt!=3D2 and _alt!=3DATN.INVALID_ALT_NUMBER: >=20 > + if _alt=3D=3D1: >=20 > + self.state =3D 820 >=20 > + self.declaration() >=20 > + self.state =3D 825 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,101,se= lf._ctx) >=20 > + >=20 > + self.state =3D 827 >=20 > + self._errHandler.sync(self) >=20 > + _la =3D self._input.LA(1) >=20 > + if (((_la) & ~0x3f) =3D=3D 0 and ((1 << _la) & ((1 << CParse= r.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 << C= Parser.T__9) | (1 << CParser.T__10) | (1 << CParser.T__11) | (1 << > CParser.T__12) | (1 << CParser.T__13) | (1 << CParser.T__14) | (1 << CPar= ser.T__15) | (1 << CParser.T__16) | (1 << CParser.T__17) | (1 << > CParser.T__18) | (1 << CParser.T__20) | (1 << CParser.T__21) | (1 << CPar= ser.T__23) | (1 << CParser.T__24) | (1 << CParser.T__25) | (1 << > CParser.T__26) | (1 << CParser.T__27) | (1 << CParser.T__28) | (1 << CPar= ser.T__29) | (1 << CParser.T__30) | (1 << CParser.T__31) | (1 << > CParser.T__32) | (1 << CParser.T__33) | (1 << CParser.T__34) | (1 << CPar= ser.T__35) | (1 << CParser.T__36) | (1 << CParser.T__37) | (1 << > CParser.T__41) | (1 << CParser.T__43) | (1 << CParser.T__44) | (1 << CPar= ser.T__47) | (1 << CParser.T__48) | (1 << CParser.T__49) | (1 << > CParser.T__52) | (1 << CParser.T__53) | (1 << CParser.T__54))) !=3D 0) or= ((((_la - 79)) & ~0x3f) =3D=3D 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__8= 6 - 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)))) !=3D 0): >=20 > + self.state =3D 826 >=20 > + self.statement_list() >=20 > + >=20 > + >=20 > + self.state =3D 829 >=20 > + self.match(CParser.T__19) >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Statement_listContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def statement(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.StatementContex= t) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.StatementContext= ,i) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_statement_list >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterStatement_list" ): >=20 > + listener.enterStatement_list(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitStatement_list" ): >=20 > + listener.exitStatement_list(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def statement_list(self): >=20 > + >=20 > + localctx =3D CParser.Statement_listContext(self, self._ctx, self= .state) >=20 > + self.enterRule(localctx, 132, self.RULE_statement_list) >=20 > + try: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 832 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D 1 >=20 > + while _alt!=3D2 and _alt!=3DATN.INVALID_ALT_NUMBER: >=20 > + if _alt =3D=3D 1: >=20 > + self.state =3D 831 >=20 > + self.statement() >=20 > + >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + self.state =3D 834 >=20 > + self._errHandler.sync(self) >=20 > + _alt =3D self._interp.adaptivePredict(self._input,103,se= lf._ctx) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Expression_statementContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def expression(self): >=20 > + return self.getTypedRuleContext(CParser.ExpressionContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_expression_statement >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterExpression_statement" ): >=20 > + listener.enterExpression_statement(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitExpression_statement" ): >=20 > + listener.exitExpression_statement(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def expression_statement(self): >=20 > + >=20 > + localctx =3D CParser.Expression_statementContext(self, self._ctx= , self.state) >=20 > + self.enterRule(localctx, 134, self.RULE_expression_statement) >=20 > + try: >=20 > + self.state =3D 840 >=20 > + self._errHandler.sync(self) >=20 > + token =3D self._input.LA(1) >=20 > + if token in [CParser.T__1]: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 836 >=20 > + self.match(CParser.T__1) >=20 > + pass >=20 > + 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, CPar= ser.FLOATING_POINT_LITERAL]: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 837 >=20 > + self.expression() >=20 > + self.state =3D 838 >=20 > + self.match(CParser.T__1) >=20 > + pass >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Selection_statementContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + self.e =3D None # ExpressionContext >=20 > + >=20 > + # @param i=3DNone Type: int >=20 > + def statement(self,i=3DNone): >=20 > + if i is None: >=20 > + return self.getTypedRuleContexts(CParser.StatementContex= t) >=20 > + else: >=20 > + return self.getTypedRuleContext(CParser.StatementContext= ,i) >=20 > + >=20 > + >=20 > + def expression(self): >=20 > + return self.getTypedRuleContext(CParser.ExpressionContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_selection_statement >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterSelection_statement" ): >=20 > + listener.enterSelection_statement(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitSelection_statement" ): >=20 > + listener.exitSelection_statement(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def selection_statement(self): >=20 > + >=20 > + localctx =3D CParser.Selection_statementContext(self, self._ctx,= self.state) >=20 > + self.enterRule(localctx, 136, self.RULE_selection_statement) >=20 > + try: >=20 > + self.state =3D 858 >=20 > + self._errHandler.sync(self) >=20 > + token =3D self._input.LA(1) >=20 > + if token in [CParser.T__83]: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 842 >=20 > + self.match(CParser.T__83) >=20 > + self.state =3D 843 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 844 >=20 > + localctx.e =3D self.expression() >=20 > + self.state =3D 845 >=20 > + self.match(CParser.T__38) >=20 > + self.StorePredicateExpression((None if localctx.e is Non= e 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.sto= p).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)))) >=20 > + self.state =3D 847 >=20 > + self.statement() >=20 > + self.state =3D 850 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,105,sel= f._ctx) >=20 > + if la_ =3D=3D 1: >=20 > + self.state =3D 848 >=20 > + self.match(CParser.T__84) >=20 > + self.state =3D 849 >=20 > + self.statement() >=20 > + >=20 > + >=20 > + pass >=20 > + elif token in [CParser.T__85]: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 852 >=20 > + self.match(CParser.T__85) >=20 > + self.state =3D 853 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 854 >=20 > + self.expression() >=20 > + self.state =3D 855 >=20 > + self.match(CParser.T__38) >=20 > + self.state =3D 856 >=20 > + self.statement() >=20 > + pass >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Iteration_statementContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + self.e =3D None # ExpressionContext >=20 > + >=20 > + def statement(self): >=20 > + return self.getTypedRuleContext(CParser.StatementContext,0) >=20 > + >=20 > + >=20 > + def expression(self): >=20 > + return self.getTypedRuleContext(CParser.ExpressionContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_iteration_statement >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterIteration_statement" ): >=20 > + listener.enterIteration_statement(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitIteration_statement" ): >=20 > + listener.exitIteration_statement(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def iteration_statement(self): >=20 > + >=20 > + localctx =3D CParser.Iteration_statementContext(self, self._ctx,= self.state) >=20 > + self.enterRule(localctx, 138, self.RULE_iteration_statement) >=20 > + try: >=20 > + self.state =3D 876 >=20 > + self._errHandler.sync(self) >=20 > + token =3D self._input.LA(1) >=20 > + if token in [CParser.T__86]: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 860 >=20 > + self.match(CParser.T__86) >=20 > + self.state =3D 861 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 862 >=20 > + localctx.e =3D self.expression() >=20 > + self.state =3D 863 >=20 > + self.match(CParser.T__38) >=20 > + self.state =3D 864 >=20 > + self.statement() >=20 > + self.StorePredicateExpression((None if localctx.e is Non= e 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.sto= p).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)))) >=20 > + pass >=20 > + elif token in [CParser.T__87]: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 867 >=20 > + self.match(CParser.T__87) >=20 > + self.state =3D 868 >=20 > + self.statement() >=20 > + self.state =3D 869 >=20 > + self.match(CParser.T__86) >=20 > + self.state =3D 870 >=20 > + self.match(CParser.T__37) >=20 > + self.state =3D 871 >=20 > + localctx.e =3D self.expression() >=20 > + self.state =3D 872 >=20 > + self.match(CParser.T__38) >=20 > + self.state =3D 873 >=20 > + self.match(CParser.T__1) >=20 > + self.StorePredicateExpression((None if localctx.e is Non= e 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.sto= p).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)))) >=20 > + pass >=20 > + else: >=20 > + raise NoViableAltException(self) >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + class Jump_statementContext(ParserRuleContext): >=20 > + >=20 > + # @param parent=3DNone Type: ParserRuleContext >=20 > + # @param invokingState=3D-1 Type: int >=20 > + def __init__(self,parser,parent=3DNone,invokingState=3D-1): >=20 > + super().__init__(parent, invokingState) >=20 > + self.parser =3D parser >=20 > + >=20 > + def IDENTIFIER(self): >=20 > + return self.getToken(CParser.IDENTIFIER, 0) >=20 > + >=20 > + def expression(self): >=20 > + return self.getTypedRuleContext(CParser.ExpressionContext,0) >=20 > + >=20 > + >=20 > + def getRuleIndex(self): >=20 > + return CParser.RULE_jump_statement >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def enterRule(self,listener): >=20 > + if hasattr( listener, "enterJump_statement" ): >=20 > + listener.enterJump_statement(self) >=20 > + >=20 > + # @param listener Type: ParseTreeListener >=20 > + def exitRule(self,listener): >=20 > + if hasattr( listener, "exitJump_statement" ): >=20 > + listener.exitJump_statement(self) >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + def jump_statement(self): >=20 > + >=20 > + localctx =3D CParser.Jump_statementContext(self, self._ctx, self= .state) >=20 > + self.enterRule(localctx, 140, self.RULE_jump_statement) >=20 > + try: >=20 > + self.state =3D 891 >=20 > + self._errHandler.sync(self) >=20 > + la_ =3D self._interp.adaptivePredict(self._input,108,self._c= tx) >=20 > + if la_ =3D=3D 1: >=20 > + self.enterOuterAlt(localctx, 1) >=20 > + self.state =3D 878 >=20 > + self.match(CParser.T__88) >=20 > + self.state =3D 879 >=20 > + self.match(CParser.IDENTIFIER) >=20 > + self.state =3D 880 >=20 > + self.match(CParser.T__1) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 2: >=20 > + self.enterOuterAlt(localctx, 2) >=20 > + self.state =3D 881 >=20 > + self.match(CParser.T__89) >=20 > + self.state =3D 882 >=20 > + self.match(CParser.T__1) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 3: >=20 > + self.enterOuterAlt(localctx, 3) >=20 > + self.state =3D 883 >=20 > + self.match(CParser.T__90) >=20 > + self.state =3D 884 >=20 > + self.match(CParser.T__1) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 4: >=20 > + self.enterOuterAlt(localctx, 4) >=20 > + self.state =3D 885 >=20 > + self.match(CParser.T__91) >=20 > + self.state =3D 886 >=20 > + self.match(CParser.T__1) >=20 > + pass >=20 > + >=20 > + elif la_ =3D=3D 5: >=20 > + self.enterOuterAlt(localctx, 5) >=20 > + self.state =3D 887 >=20 > + self.match(CParser.T__91) >=20 > + self.state =3D 888 >=20 > + self.expression() >=20 > + self.state =3D 889 >=20 > + self.match(CParser.T__1) >=20 > + pass >=20 > + >=20 > + >=20 > + except RecognitionException as re: >=20 > + localctx.exception =3D re >=20 > + self._errHandler.reportError(self, re) >=20 > + self._errHandler.recover(self, re) >=20 > + finally: >=20 > + self.exitRule() >=20 > + return localctx >=20 > + >=20 > + >=20 > + >=20 > + >=20 > + >=20 > 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/BaseT= ools/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 >=20 > import re >=20 > import Common.LongFilePathOs as os >=20 > import sys >=20 >=20 >=20 > -import antlr3 >=20 > -from .CLexer import CLexer >=20 > -from .CParser import CParser >=20 > +if sys.version_info.major =3D=3D 3: >=20 > + import antlr4 as antlr >=20 > + from Eot.CParser4.CLexer import CLexer >=20 > + from Eot.CParser4.CParser import CParser >=20 > +else: >=20 > + import antlr3 as antlr >=20 > + antlr.InputStream =3D antlr.StringStream >=20 > + from Eot.CParser3.CLexer import CLexer >=20 > + from Eot.CParser3.CParser import CParser >=20 >=20 >=20 > -from . import FileProfile >=20 > -from .CodeFragment import PP_Directive >=20 > -from .ParserWarning import Warning >=20 > +from Eot import FileProfile >=20 > +from Eot.CodeFragment import PP_Directive >=20 > +from Eot.ParserWarning import Warning >=20 >=20 >=20 >=20 >=20 > ##define T_CHAR_SPACE ' ' >=20 > ##define T_CHAR_NULL '\0' >=20 > ##define T_CHAR_CR '\r' >=20 > @@ -352,13 +358,13 @@ class CodeFragmentCollector: > # restore from ListOfList to ListOfString >=20 > self.Profile.FileLinesList =3D ["".join(list) for list in self.P= rofile.FileLinesList] >=20 > FileStringContents =3D '' >=20 > for fileLine in self.Profile.FileLinesList: >=20 > FileStringContents +=3D fileLine >=20 > - cStream =3D antlr3.StringStream(FileStringContents) >=20 > + cStream =3D antlr.InputStream(FileStringContents) >=20 > lexer =3D CLexer(cStream) >=20 > - tStream =3D antlr3.CommonTokenStream(lexer) >=20 > + tStream =3D antlr.CommonTokenStream(lexer) >=20 > parser =3D CParser(tStream) >=20 > parser.translation_unit() >=20 >=20 >=20 > ## CleanFileProfileBuffer() method >=20 > # >=20 > -- > 2.20.1.windows.1