Skip to main content

4. Lex and Yacc Program to detect errors in a 'C' Language Program


Lex and Yacc Program to detect errors in a 'C' Language Program 
 
Lex Code:

%{
#include"y.tab.h"
#include<stdio.h>
int LineNo=1;
%}

identifier[a-zA-Z][_a-zA-Z0-9]*

number [0-9]+|([0-9]*\.[0-9]+)

%%

main\(\) return MAIN;
if return IF;
else return ELSE;

while return WHILE;

int |
char |
flaot return TYPE;

{identifier} return VAR;
{number} return NUM;
\> |
\< |
\<= |
\>= |
== return RELOP;
[\t] ;
[\n] LineNo++;
. return yytext[0];
%%


Yacc Code:

%{
#include<string.h>
#include<stdio.h>

extern int LineNo;

int errno=0;
%}

%token NUM VAR RELOP
%token MAIN IF ELSE WHILE TYPE

%left '-' '+'

%left '*' '/'

%%
PROGRAM: MAIN BLOCK
;
BLOCK: '{'CODE'}'

;

CODE: BLOCK
|STATEMENT CODE
|STATEMENT
;

STATEMENT:DECST';'
|DECST {printf("\nLine number %d:syntax error",lineNo);errno++;}
|ASSIGNMENT ';'

|ASSIGNMENT {printf("\nLine number %d:syntax error",lineNo);errno++;}
|CONDST
|WHILEST

;

DECST: TYPE VARLIST
;
VARLIST: VAR ','VARLIST

| VAR
;
ASSIGNMENT:VAR'='EXPR
;

EXPR: EXPR '+' EXPR

| EXPR '-' EXPR
| EXPR '*' EXPR
| EXPR '/' EXPR

| '-' EXPR
| '(' EXPR ')'
| VAR

| NUM
;

CONDST: IFST
| IFST ELSEST
;

IFST: IF '(' CONDITION ')'
 BLOCK
;

ELSEST: ELSE
 BLOCK
;

CONDITION: VAR RELOP VAR
| VAR

| NUM
;

WHILEST: WHILELOOP
;

WHILELOOP: WHILE '(' CONDITION ')'

 BLOCK
;
%%
extern FILE *yyin;

int main(int argc, char *argv[])
{

 FILE *fp;
 int i;
 /*Check for cmd line args*/
 if(argc>1)
 {

 /*open file in read mode*/ 
 fp = fopen(argv[1],"r");
 if(!fp)
 {

  printf("\n File not found");  
  exit(0);
 }//end if
 yyin = fp;
 }//end if

 yyparse();
 /*
 check for the number of errors present and display
 the read message
 */
 if(errno==0)
  printf("\nNo errors found!\n");

 else
  printf("\n%d error(s) found!\n",errno);
 return(0);
}//End main


/* error handling routine which gets called if a statement cannot be
 parsed with the grammer defined */
 yyerror()
 {
  printf("\nSyntax Error on line %d\n",LineNo);
  errno++;
 }//End yyerror




Comments

Post a Comment

Popular posts from this blog

Selenium + Python + UnexpectedAlertPresentException: Dealing with annoying alerts

Handling  UnexpectedAlertPresentException   Alerts who hates them? I Do!  Who doesn't hate an annoying alert causing your tests / scraping job to fail? I must say they are pretty much on point on the Unexpected part!  Fortunately, there are easy ways to mitigate the issue. 1. Disable alerts completely: driver . execute_script( 'window.alert = function(){};' ); execute this script just before where you anticipate the alert and you're golden. 2. You want to see the alert text but not disturb the execution flow. driver . execute_script( 'window.alert = console.info;' ); Now the alerts have been redirected to the console and you don't have to worry about them. (Unless you have to - then you'd have to monitor the console) 3. You know exactly when it comes and want to accept the alert and move on. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 from selenium import webdriver from selenium.webdriver.s

Python Program for Soundex Algorithm

This is a python implementation for Soundex Algorithm. This Program builds a JSON document as a dictionary and is kept on building at every execution. Its constantly appended and referenced while the program  is executed. Program: from re import sub def remove_symbols (input_string): #Convert the characters to lower case and then use #Regular expressions to remove non a-z chars return sub( '[^A-Z]+' , '' , input_string) def clean (input_string): #Convert the characters to lower case and then use #Regular expressions to remove non a-z chars return sub( '[^a-z]+' , '' , input_string . lower()) word = "Input" def soundex (word): #Step 1: Capitalize all letters in the word and drop all punctuation marks. word = remove_symbols(word . upper()) #Step 2: Retain the first letter of the word. first_letter = word[ 0 ] word = word[ 1 :] #Step 3 & 4: Change ( 'A&#

How to convert a Helium Wallet Address to Solana Wallet address?

Helium went to Solana Blockchain, on April 18, 2023. Helium addresses are not available on the Solana blockchain as addresses on the Solana blockchain are base-58 encoded. Here is a quick snippet on how to translate an existing Helium wallet address to a Solana wallet address using Python. You will need the base58 module for this, get it here: pip install base58 Code Chunk: def convert_hnt_wallet_addr_to_sol ( helium_wallet_address ) : return base58. b58encode ( base58. b58decode ( hnt_wallet_address ) [ 2 :- 4 ] ) . decode ( ) Using this convert your Helium wallet address to a Solana address! You can further explore our blog for interesting reads  OR   - you can contact us to learn a bit more over a FREE personal Skype coaching session. Just click on "Leave a message" and reach out to us. We get a lot of volume these days so FREE Sessions won't be here for a long time, Grab this opportunity while you can!