Bottom-up Parser-II Stack parser using SLR

Bottom-up Parser-II Stack parser using SLR in Compiler Construction

A parser or syntax analyzer is a compiler component that breaks data into smaller elements for easy translation into another language. A parser takes input in the form of a sequence of tokens or program instructions, validates sentence sequence and usually builds a data structure in the form of a parse tree or abstract syntax tree

Syntax analyzers follow production rules defined by means of context-free grammar. The way the production rules are implemented (derivation) divides parsing into two types: top- down parsing and bottom-up parsing.

Activity Outcomes:

This lab teaches you

  • Implementation of SLR for a bottom up parser

Instructor Note:

Student should have prior knowledge regarding SLR

1)                        Stage J (Journey) Introduction

A Simple LR or SLR parser is a type of LR parser with small parse tables and a relatively simple parser generator algorithm. As with other types of LR(1) parser, an SLR parser is quite efficient at finding the single correct bottom-up parse in a single left-to-right scan over the input stream, without guesswork or backtracking. The parser is mechanically generated from a formal grammar for the language.

Lab Activities:

Activity 1:

Design SLR for the CFG of TINY C.

 

TINY C

Keywords: begin(){, }end, int, float, if, for, else, then, print

Operators: +, =, <

Variables: same criterion as that of C language

Constants: digits and floating point numbers

Punctuation Symbols: {, }, (, ), ;

Input string for making SLR

Begin(){

int a=5;

int b=10;

int c=0;

c=a+b;

if(c>a)

print a;

else print c;

}end

 

Solution:

  1. Store the input in an array named finalArray having an index named
    1. //Initializations

ArrayList States = new ArrayList();

Stack<String> Stack = new Stack<String>(); String Parser;

String[] Col = { “begin” ,”(“,”)”,”{“,”int”,”a”,”b”,

“c”,”=”,”5″,”10″,”0″,”;”,”if”,”>”,”print”,

“else”,”$”,”}”,”+”,”end”,”Program”,”DecS”,”AssS”,”IffS”,”PriS”,”Var”,”Const”

};

#region Bottom Up Parser

States.Add(“Program_begin ( ) { DecS Decs Decs AssS IffS } end”); States.Add(“DecS_int Var = Const ;”);

States.Add(“AssS_Var = Var + Var ;”);

States.Add(“IffS_if ( Var > Var ) { PriS } else { PriS }”); States.Add(“PriS_print Var ;”);

States.Add(“Var_a”); States.Add(“Var_b”); States.Add(“Var_c”); States.Add(“Const_5”); States.Add(“Const_10”); States.Add(“Const_0”); Stack.Push(“0”); finalArray.Add(“$”); int pointer = 0; #region ParseTable

var dict = new Dictionary<string, Dictionary<String, object>>(); dict.Add(“0”, new Dictionary<String, object>()

{

{ “begin”, “S2” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “1” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“1”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “Accept” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“2”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “S3” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“3”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “S4” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“4”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “S5” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“5”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “S13” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “6” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“6”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “S13” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “7” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“7”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “S13” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “8” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“8”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “S40” },

{ “b”, “S42” },

{ “c”, “S44” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “9” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “18” },

{ “Const”, “” }

});

dict.Add(“9”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “S24” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “10” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“10”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “S11” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“11”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “S12” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“12”, new Dictionary<String, object>()

{

{ “begin”, “R1” },

{ “(“, “R1” },

{ “)”, “R1” },

{ “{“, “R1” },

{ “int”, “R1” },

{ “a”, “R1” },

{ “b”, “R1” },

{ “c”, “R1” },

{ “=”, “R1” },

{ “5”, “R1” },

{ “10”, “R1” },

{ “0”, “R1” },

{ “;”, “R1” },

{ “if”, “R1” },

{ “>”, “R1” },

{ “print”, “R1” },

{ “else”, “R1” },

{ “$”, “R1” },

{ “}”, “R1” },

{ “+”, “R1” },

{ “end”, “R1” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“13”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “S40” },

{ “b”, “S42” },

{ “c”, “S44” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “14” },

{ “Const”, “” }

});

dict.Add(“14”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “S15” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “2” },

{ “IffS”, “1” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“15”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “S41” },

{ “10”, “S43” },

{ “0”, “S45” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “16” }

});

dict.Add(“16”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “S17” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“17”, new Dictionary<String, object>()

{

{ “begin”, “R2” },

{ “(“, “R2” },

{ “)”, “R2” },

{ “{“, “R2” },

{ “int”, “R2” },

{ “a”, “R2” },

{ “b”, “R2” },

{ “c”, “R2” },

{ “=”, “R2” },

{ “5”, “R2” },

{ “10”, “R2” },

{ “0”, “R2” },

{ “;”, “R2” },

{ “if”, “R2” },

{ “>”, “R2” },

{ “print”, “R2” },

{ “else”, “R2” },

{ “$”, “R2” },

{ “}”, “R2” },

{ “+”, “R2” },

{ “end”, “R2” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“18”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “S19” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“19”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “S40” },

{ “b”, “S42” },

{ “c”, “S44” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “20” },

{ “Const”, “” }

});

dict.Add(“20”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “S21” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“21”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “S40” },

{ “b”, “S42” },

{ “c”, “S44” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “22” },

{ “Const”, “” }

});

dict.Add(“22”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “S23” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“23”, new Dictionary<String, object>()

{

{ “begin”, “R3” },

{ “(“, “R3” },

{ “)”, “R3” },

{ “{“, “R3” },

{ “int”, “R3” },

{ “a”, “R3” },

{ “b”, “R3” },

{ “c”, “R3” },

{ “=”, “R3” },

{ “5”, “R3” },

{ “10”, “R3” },

{ “0”, “R3” },

{ “;”, “R3” },

{ “if”, “R3” },

{ “>”, “R3” },

{ “print”, “R3” },

{ “else”, “R3” },

{ “$”, “R3” },

{ “}”, “R3” },

{ “+”, “R3” },

{ “end”, “R3” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“24”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “S25” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“25”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “S40” },

{ “b”, “S42” },

{ “c”, “S44” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “26” },

{ “Const”, “” }

});

dict.Add(“26”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “S27” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“27”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “S40” },

{ “b”, “S42” },

{ “c”, “S44” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “28” },

{ “Const”, “” }

});

dict.Add(“28”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “S29” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “2” },

{ “IffS”, “1” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“29”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “S30” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “2” },

{ “IffS”, “1” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“30”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “S37” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “31” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“31”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “S32” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“32”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “S33” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“33”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “S34” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“34”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “S37” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “35” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“35”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “S36” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “2” },

{ “IffS”, “1” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“36”, new Dictionary<String, object>()

{

{ “begin”, “R4” },

{ “(“, “R4” },

{ “)”, “R4” },

{ “{“, “R4” },

{ “int”, “R4” },

{ “a”, “R4” },

{ “b”, “R4” },

{ “c”, “R4” },

{ “=”, “R4” },

{ “5”, “R4” },

{ “10”, “R4” },

{ “0”, “R4” },

{ “;”, “R4” },

{ “if”, “R4” },

{ “>”, “R4” },

{ “print”, “R4” },

{ “else”, “R4” },

{ “$”, “R4” },

{ “}”, “R4” },

{ “+”, “R4” },

{ “end”, “R4” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“37”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “S40” },

{ “b”, “S42” },

{ “c”, “S44” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “38” },

{ “Const”, “” }

});

dict.Add(“38”, new Dictionary<String, object>()

{

{ “begin”, “” },

{ “(“, “” },

{ “)”, “” },

{ “{“, “” },

{ “int”, “” },

{ “a”, “” },

{ “b”, “” },

{ “c”, “” },

{ “=”, “” },

{ “5”, “” },

{ “10”, “” },

{ “0”, “” },

{ “;”, “S39” },

{ “if”, “” },

{ “>”, “” },

{ “print”, “” },

{ “else”, “” },

{ “$”, “” },

{ “}”, “” },

{ “+”, “” },

{ “end”, “” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“39”, new Dictionary<String, object>()

{

{ “begin”, “R5” },

{ “(“, “R5” },

{ “)”, “R5” },

{ “{“, “R5” },

{ “int”, “R5” },

{ “a”, “R5” },

{ “b”, “R5” },

{ “c”, “R5” },

{ “=”, “R5” },

{ “5”, “R5” },

{ “10”, “R5” },

{ “0”, “R5” },

{ “;”, “R5” },

{ “if”, “R5” },

{ “>”, “R5” },

{ “print”, “R5” },

{ “else”, “R5” },

{ “$”, “R5” },

{ “}”, “R5” },

{ “+”, “R5” },

{ “end”, “R5” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“40”, new Dictionary<String, object>()

{

{ “begin”, “R6” },

{ “(“, “R6” },

{ “)”, “R6” },

{ “{“, “R6” },

{ “int”, “R6” },

{ “a”, “R6” },

{ “b”, “R6” },

{ “c”, “R6” },

{ “=”, “R6” },

{ “5”, “R6” },

{ “10”, “R6” },

{ “0”, “R6” },

{ “;”, “R6” },

{ “if”, “R6” },

{ “>”, “R6” },

{ “print”, “R6” },

{ “else”, “R6” },

{ “$”, “R6” },

{ “}”, “R6” },

{ “+”, “R6” },

{ “end”, “R6” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“41”, new Dictionary<String, object>()

{

{ “begin”, “R9” },

{ “(“, “R9” },

{ “)”, “R9” },

{ “{“, “R9” },

{ “int”, “R9” },

{ “a”, “R9” },

{ “b”, “R9” },

{ “c”, “R9” },

{ “=”, “R9” },

{ “5”, “R9” },

{ “10”, “R9” },

{ “0”, “R9” },

{ “;”, “R9” },

{ “if”, “R9” },

{ “>”, “R9” },

{ “print”, “R9” },

{ “else”, “R9” },

{ “$”, “R9” },

{ “}”, “R9” },

{ “+”, “R9” },

{ “end”, “R9” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“42”, new Dictionary<String, object>()

{

{ “begin”, “R7” },

{ “(“, “R7” },

{ “)”, “R7” },

{ “{“, “R7” },

{ “int”, “R7” },

{ “a”, “R7” },

{ “b”, “R7” },

{ “c”, “R7” },

{ “=”, “R7” },

{ “5”, “R7” },

{ “10”, “R7” },

{ “0”, “R7” },

{ “;”, “R7” },

{ “if”, “R7” },

{ “>”, “R7” },

{ “print”, “R7” },

{ “else”, “R7” },

{ “$”, “R7” },

{ “}”, “R7” },

{ “+”, “R7” },

{ “end”, “R7” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“43”, new Dictionary<String, object>()

{

{ “begin”, “R10” },

{ “(“, “R10” },

{ “)”, “R10” },

{ “{“, “R10” },

{ “int”, “R10” },

{ “a”, “R10” },

{ “b”, “R10” },

{ “c”, “R10” },

{ “=”, “R10” },

{ “5”, “R10” },

{ “10”, “R10” },

{ “0”, “R10” },

{ “;”, “R10” },

{ “if”, “R10” },

{ “>”, “R10” },

{ “print”, “R10” },

{ “else”, “R10” },

{ “$”, “R10” },

{ “}”, “R10” },

{ “+”, “R10” },

{ “end”, “R10” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“44”, new Dictionary<String, object>()

{

{ “begin”, “R8” },

{ “(“, “R8” },

{ “)”, “R8” },

{ “{“, “R8” },

{ “int”, “R8” },

{ “a”, “R8” },

{ “b”, “R8” },

{ “c”, “R8” },

{ “=”, “R8” },

{ “5”, “R8” },

{ “10”, “R8” },

{ “0”, “R8” },

{ “;”, “R8” },

{ “if”, “R8” },

{ “>”, “R8” },

{ “print”, “R8” },

{ “else”, “R8” },

{ “$”, “R8” },

{ “}”, “R8” },

{ “+”, “R8” },

{ “end”, “R8” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

dict.Add(“45”, new Dictionary<String, object>()

{

{ “begin”, “R11” },

{ “(“, “R11” },

{ “)”, “R11” },

{ “{“, “R11” },

{ “int”, “R11” },

{ “a”, “R11” },

{ “b”, “R11” },

{ “c”, “R11” },

{ “=”, “R11” },

{ “5”, “R11” },

{ “10”, “R11” },

{ “0”, “R11” },

{ “;”, “R11” },

{ “if”, “R11” },

{ “>”, “R11” },

{ “print”, “R11” },

{ “else”, “R11” },

{ “$”, “R11” },

{ “}”, “R11” },

{ “+”, “R11” },

{ “end”, “R11” },

{ “Program”, “” },

{ “DecS”, “” },

{ “AssS”, “” },

{ “IffS”, “” },

{ “PriS”, “” },

{ “Var”, “” },

{ “Const”, “” }

});

#endregion

while (true)

{

if (!Col.Contains(finalArray[pointer]))

{

Output.AppendText(“Unable to Parse Unknown Input”); break;

}

Parser = dict[Stack.Peek() + “”][finalArray[pointer] + “”] + “”; if (Parser.Contains(“S”))

{

Stack.Push(finalArray[pointer] + “”); Parser = Parser.TrimStart(‘S’); Stack.Push(Parser);

pointer++; Print_Stack();

}

if (Parser.Contains(“R”))

{

Parser = Parser.TrimStart(‘R’);

String get = States[Convert.ToInt32(Parser) – 1] + “”; String[] Splitted = get.Split(‘_’);

String[] Final_ = Splitted[1].Split(‘ ‘); int test = Final_.Length;

for (int i = 0; i < test * 2; i++)

{ Stack.Pop(); }

String row = Stack.Peek() + “”; Stack.Push(Splitted[0]); Stack.Push(dict[row][Stack.Peek()] + “”); Print_Stack();

}

if (Parser.Contains(“Accept”))

{

Output.AppendText(“Parsed”); break;

}

if (Parser.Equals(“”))

{

Output.AppendText(“Unable to Parse”); break;

}

}

finalArray.Remove(“$”); finalArray.Remove(“begin”); #endregion

1)               Home Activities:

Activity 1:

Understand the SLR code, mentioned in lab activity 1, written with the help of dictionary and stack classes of C#.

1)               Assignment:

Complete the home activity before next lab.

Related Links

#Compiler Construction complete course # Compiler Construction past paper # Compiler Construction project #Computer Science all courses  #University Past Paper #Programming language #Introduction to C# #Lexical Analyzer Recognition of operators/variables #Recognition of keywords/constants #Lexical Analyzer Input Buffering scheme #Symbol Table in Compiler Construction #First set of a given grammar using Array #Follow set of a given grammar using Array #Bottom-up Parser-I DFA Implementation #Bottom-up Parser-II Stack parser using SLR #Semantic Analyzer

Search within CuiTutorial