%{
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int line_num = 1;
int col_num = 1;
int token_count = 0;
int keyword_count = 0;
int identifier_count = 0;
int number_count = 0;
int relop_count = 0;
int unknown_count = 0;
typedef struct {
char token_type[20];
char value[100];
int line;
int column;
} TokenInfo;
TokenInfo tokens[1000];
void add_token(const char* type, const char* value, int line, int col) {
strcpy(tokens[token_count].token_type, type);
strcpy(tokens[token_count].value, value);
tokens[token_count].line = line;
tokens[token_count].column = col;
token_count++;
}
void print_statistics() {
printf("\n=================== STATISTICS ===================\n");
printf("Total Tokens: %d\n", token_count);
printf("Keywords: %d\n", keyword_count);
printf("Identifiers: %d\n", identifier_count);
printf("Numbers: %d\n", number_count);
printf("Relational Operators: %d\n", relop_count);
printf("Unknown Tokens: %d\n", unknown_count);
printf("Total Lines: %d\n", line_num);
printf("==================================================\n");
}
void print_token_table() {
printf("\n=================== TOKEN TABLE ===================\n");
printf("%-4s %-15s %-15s %-6s %-6s\n", "No.", "Type", "Value", "Line", "Col");
printf("----------------------------------------------------\n");
for(int i = 0; i < token_count; i++) {
printf("%-4d %-15s %-15s %-6d %-6d\n",
i+1, tokens[i].token_type, tokens[i].value,
tokens[i].line, tokens[i].column);
}
printf("====================================================\n");
}
void save_to_file() {
FILE *fp = fopen("token_analysis.txt", "w");
if(!fp) {
printf("Error creating output file!\n");
return;
}
fprintf(fp, "LEXICAL ANALYSIS REPORT\n");
fprintf(fp, "=======================\n\n");
fprintf(fp, "TOKEN TABLE:\n");
fprintf(fp, "%-4s %-15s %-15s %-6s %-6s\n", "No.", "Type", "Value", "Line", "Col");
fprintf(fp, "----------------------------------------------------\n");
for(int i = 0; i < token_count; i++) {
fprintf(fp, "%-4d %-15s %-15s %-6d %-6d\n",
i+1, tokens[i].token_type, tokens[i].value,
tokens[i].line, tokens[i].column);
}
fprintf(fp, "\nSTATISTICS:\n");
fprintf(fp, "Total Tokens: %d\n", token_count);
fprintf(fp, "Keywords: %d\n", keyword_count);
fprintf(fp, "Identifiers: %d\n", identifier_count);
fprintf(fp, "Numbers: %d\n", number_count);
fprintf(fp, "Relational Operators: %d\n", relop_count);
fprintf(fp, "Unknown Tokens: %d\n", unknown_count);
fprintf(fp, "Total Lines: %d\n", line_num);
fclose(fp);
printf("Analysis saved to: token_analysis.txt\n");
}
%}
DIGIT [0-9]
LETTER [a-zA-Z]
IDENTIFIER {LETTER}({LETTER}|{DIGIT}|_)*
WHITESPACE [ \t]+
%%
"int"|"float"|"char"|"double"|"void"|"if"|"else"|"while"|"for"|"do"|"break"|"continue"|"return"|"switch"|"case"|"default"|"struct"|"union"|"typedef"|"static"|"extern"|"auto"|"register"|"const"|"volatile"|"sizeof"|"long"|"short"|"signed"|"unsigned"|"enum"|"goto" {
printf("Token %-3d: %-15s Value: %-12s Line: %-3d Col: %-3d\n",
token_count + 1, "KEYWORD", yytext, line_num, col_num);
add_token("KEYWORD", yytext, line_num, col_num);
keyword_count++;
col_num += yyleng;
}
{IDENTIFIER} {
printf("Token %-3d: %-15s Value: %-12s Line: %-3d Col: %-3d\n",
token_count + 1, "IDENTIFIER", yytext, line_num, col_num);
add_token("IDENTIFIER", yytext, line_num, col_num);
identifier_count++;
col_num += yyleng;
}
printf("Token %-3d: %-15s Value: %-12s Line: %-3d Col: %-3d\n",
token_count + 1, "NUMBER", yytext, line_num, col_num);
add_token("NUMBER", yytext, line_num, col_num);
number_count++;
col_num += yyleng;
}
"<="|">="|"=="|"!="|"<"|">" {
printf("Token %-3d: %-15s Value: %-12s Line: %-3d Col: %-3d\n",
token_count + 1, "RELATIONAL_OP", yytext, line_num, col_num);
add_token("RELATIONAL_OP", yytext, line_num, col_num);
relop_count++;
col_num += yyleng;
}
{WHITESPACE} {
col_num += yyleng;
}
\n {
line_num++;
col_num = 1;
}
"//".*$ {
col_num += yyleng;
}
"/*"([^*]|\*+[^*/])*\*+"/" {
for(int i = 0; i < yyleng; i++) {
if(yytext[i] == '\n') {
line_num++;
col_num = 1;
} else {
col_num++;
}
}
}
. {
printf("Token %-3d: %-15s Value: %-12s Line: %-3d Col: %-3d\n",
token_count + 1, "UNKNOWN", yytext, line_num, col_num);
add_token("UNKNOWN", yytext, line_num, col_num);
unknown_count++;
col_num += yyleng;
}
%%
int yywrap() {
return 1;
}
void print_menu() {
printf("\n=============== MENU OPTIONS ===============\n");
printf("1. Show Token Table\n");
printf("2. Show Statistics\n");
printf("3. Save Analysis to File\n");
printf("4. Exit\n");
printf("===========================================\n");
printf("Enter your choice: ");
}
int main(int argc, char *argv[]) {
printf("======================================\n");
printf(" ADVANCED LEX TOKENIZER v2.0\n");
printf("======================================\n");
printf("Features: Keywords, Identifiers, Numbers,\n");
printf(" Relational Operators, Comments\n");
printf("======================================\n\n");
if(argc > 1) {
FILE *input_file = fopen(argv[1], "r");
if(!input_file) {
printf
("Error
: Cannot
open file
'%s'\n"
, argv
[1]); printf("Usage: %s [input_file.c]\n", argv[0]);
return 1;
}
yyin = input_file;
printf("Analyzing file: %s\n", argv[1]);
printf("======================================\n");
} else {
printf("Enter source code (Ctrl+D to finish):\n");
printf("======================================\n");
}
yylex();
if(argc > 1) {
fclose(yyin);
}
printf("\n======================================\n");
printf(" LEXICAL ANALYSIS COMPLETE\n");
printf("======================================\n");
int choice;
do {
print_menu();
scanf("%d", &choice);
switch(choice) {
case 1:
print_token_table();
break;
case 2:
print_statistics();
break;
case 3:
save_to_file();
break;
case 4:
printf("Thank you for using Advanced LEX Tokenizer!\n");
break;
default:
printf("Invalid choice! Please try again.\n");
}
} while(choice != 4);
return 0;
}
%{
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int line_num = 1;
int col_num = 1;
int token_count = 0;
int keyword_count = 0;
int identifier_count = 0;
int number_count = 0;
int relop_count = 0;
int unknown_count = 0;

typedef struct {
    char token_type[20];
    char value[100];
    int line;
    int column;
} TokenInfo;

TokenInfo tokens[1000];

void add_token(const char* type, const char* value, int line, int col) {
    strcpy(tokens[token_count].token_type, type);
    strcpy(tokens[token_count].value, value);
    tokens[token_count].line = line;
    tokens[token_count].column = col;
    token_count++;
}

void print_statistics() {
    printf("\n=================== STATISTICS ===================\n");
    printf("Total Tokens: %d\n", token_count);
    printf("Keywords: %d\n", keyword_count);
    printf("Identifiers: %d\n", identifier_count);
    printf("Numbers: %d\n", number_count);
    printf("Relational Operators: %d\n", relop_count);
    printf("Unknown Tokens: %d\n", unknown_count);
    printf("Total Lines: %d\n", line_num);
    printf("==================================================\n");
}

void print_token_table() {
    printf("\n=================== TOKEN TABLE ===================\n");
    printf("%-4s %-15s %-15s %-6s %-6s\n", "No.", "Type", "Value", "Line", "Col");
    printf("----------------------------------------------------\n");
    for(int i = 0; i < token_count; i++) {
        printf("%-4d %-15s %-15s %-6d %-6d\n", 
               i+1, tokens[i].token_type, tokens[i].value, 
               tokens[i].line, tokens[i].column);
    }
    printf("====================================================\n");
}

void save_to_file() {
    FILE *fp = fopen("token_analysis.txt", "w");
    if(!fp) {
        printf("Error creating output file!\n");
        return;
    }
    
    fprintf(fp, "LEXICAL ANALYSIS REPORT\n");
    fprintf(fp, "=======================\n\n");
    
    fprintf(fp, "TOKEN TABLE:\n");
    fprintf(fp, "%-4s %-15s %-15s %-6s %-6s\n", "No.", "Type", "Value", "Line", "Col");
    fprintf(fp, "----------------------------------------------------\n");
    
    for(int i = 0; i < token_count; i++) {
        fprintf(fp, "%-4d %-15s %-15s %-6d %-6d\n", 
                i+1, tokens[i].token_type, tokens[i].value, 
                tokens[i].line, tokens[i].column);
    }
    
    fprintf(fp, "\nSTATISTICS:\n");
    fprintf(fp, "Total Tokens: %d\n", token_count);
    fprintf(fp, "Keywords: %d\n", keyword_count);
    fprintf(fp, "Identifiers: %d\n", identifier_count);
    fprintf(fp, "Numbers: %d\n", number_count);
    fprintf(fp, "Relational Operators: %d\n", relop_count);
    fprintf(fp, "Unknown Tokens: %d\n", unknown_count);
    fprintf(fp, "Total Lines: %d\n", line_num);
    
    fclose(fp);
    printf("Analysis saved to: token_analysis.txt\n");
}

%}

DIGIT [0-9]
LETTER [a-zA-Z]
IDENTIFIER {LETTER}({LETTER}|{DIGIT}|_)*
INTEGER {DIGIT}+
FLOAT {DIGIT}*\.{DIGIT}+
NUMBER {INTEGER}|{FLOAT}
WHITESPACE [ \t]+

%%

"int"|"float"|"char"|"double"|"void"|"if"|"else"|"while"|"for"|"do"|"break"|"continue"|"return"|"switch"|"case"|"default"|"struct"|"union"|"typedef"|"static"|"extern"|"auto"|"register"|"const"|"volatile"|"sizeof"|"long"|"short"|"signed"|"unsigned"|"enum"|"goto" {
    printf("Token %-3d: %-15s Value: %-12s Line: %-3d Col: %-3d\n", 
           token_count + 1, "KEYWORD", yytext, line_num, col_num);
    add_token("KEYWORD", yytext, line_num, col_num);
    keyword_count++;
    col_num += yyleng;
}

{IDENTIFIER} {
    printf("Token %-3d: %-15s Value: %-12s Line: %-3d Col: %-3d\n", 
           token_count + 1, "IDENTIFIER", yytext, line_num, col_num);
    add_token("IDENTIFIER", yytext, line_num, col_num);
    identifier_count++;
    col_num += yyleng;
}

{NUMBER} {
    printf("Token %-3d: %-15s Value: %-12s Line: %-3d Col: %-3d\n", 
           token_count + 1, "NUMBER", yytext, line_num, col_num);
    add_token("NUMBER", yytext, line_num, col_num);
    number_count++;
    col_num += yyleng;
}

"<="|">="|"=="|"!="|"<"|">" {
    printf("Token %-3d: %-15s Value: %-12s Line: %-3d Col: %-3d\n", 
           token_count + 1, "RELATIONAL_OP", yytext, line_num, col_num);
    add_token("RELATIONAL_OP", yytext, line_num, col_num);
    relop_count++;
    col_num += yyleng;
}

{WHITESPACE} {
    col_num += yyleng;
}

\n {
    line_num++;
    col_num = 1;
}

"//".*$ {
    col_num += yyleng;
}

"/*"([^*]|\*+[^*/])*\*+"/" {
    for(int i = 0; i < yyleng; i++) {
        if(yytext[i] == '\n') {
            line_num++;
            col_num = 1;
        } else {
            col_num++;
        }
    }
}

. {
    printf("Token %-3d: %-15s Value: %-12s Line: %-3d Col: %-3d\n", 
           token_count + 1, "UNKNOWN", yytext, line_num, col_num);
    add_token("UNKNOWN", yytext, line_num, col_num);
    unknown_count++;
    col_num += yyleng;
}

%%

int yywrap() {
    return 1;
}

void print_menu() {
    printf("\n=============== MENU OPTIONS ===============\n");
    printf("1. Show Token Table\n");
    printf("2. Show Statistics\n");
    printf("3. Save Analysis to File\n");
    printf("4. Exit\n");
    printf("===========================================\n");
    printf("Enter your choice: ");
}

int main(int argc, char *argv[]) {
    printf("======================================\n");
    printf("    ADVANCED LEX TOKENIZER v2.0\n");
    printf("======================================\n");
    printf("Features: Keywords, Identifiers, Numbers,\n");
    printf("          Relational Operators, Comments\n");
    printf("======================================\n\n");
    
    if(argc > 1) {
        FILE *input_file = fopen(argv[1], "r");
        if(!input_file) {
            printf("Error: Cannot open file '%s'\n", argv[1]);
            printf("Usage: %s [input_file.c]\n", argv[0]);
            return 1;
        }
        yyin = input_file;
        printf("Analyzing file: %s\n", argv[1]);
        printf("======================================\n");
    } else {
        printf("Enter source code (Ctrl+D to finish):\n");
        printf("======================================\n");
    }
    
    yylex();
    
    if(argc > 1) {
        fclose(yyin);
    }
    
    printf("\n======================================\n");
    printf("    LEXICAL ANALYSIS COMPLETE\n");
    printf("======================================\n");
    
    int choice;
    do {
        print_menu();
        scanf("%d", &choice);
        
        switch(choice) {
            case 1:
                print_token_table();
                break;
            case 2:
                print_statistics();
                break;
            case 3:
                save_to_file();
                break;
            case 4:
                printf("Thank you for using Advanced LEX Tokenizer!\n");
                break;
            default:
                printf("Invalid choice! Please try again.\n");
        }
    } while(choice != 4);
    
    return 0;
}
