Blame examples/manual/string1.lex

Packit f00812
/* 
Packit f00812
 * string1.lex: Handling strings by using input()
Packit f00812
 */
Packit f00812
Packit f00812
%{
Packit f00812
#include <ctype.h>
Packit f00812
#include <malloc.h>
Packit f00812
Packit f00812
#define ALLOC_SIZE 32 /* for (re)allocating the buffer */                   
Packit f00812
Packit f00812
#define isodigit(x) ((x) >= '0' && (x) <= '7') 
Packit f00812
#define hextoint(x) (isdigit((x)) ? (x) - '0' : ((x) - 'A') + 10)  
Packit f00812
Packit f00812
void yyerror(char *message)
Packit f00812
{
Packit f00812
  printf("\nError: %s\n",message);
Packit f00812
}
Packit f00812
Packit f00812
%}
Packit f00812
Packit f00812
%%
Packit f00812
Packit f00812
\" {
Packit f00812
     int  inch,count,max_size;
Packit f00812
     char *buffer;
Packit f00812
     int  temp;
Packit f00812
Packit f00812
     buffer   = malloc(ALLOC_SIZE);
Packit f00812
     max_size = ALLOC_SIZE;
Packit f00812
     inch     = input();
Packit f00812
     count    = 0;
Packit f00812
     while(inch != EOF && inch != '"' && inch != '\n'){
Packit f00812
        if(inch == '\\'){
Packit f00812
          inch = input();
Packit f00812
          switch(inch){
Packit f00812
          case '\n': inch = input(); break;
Packit f00812
          case 'b' : inch = '\b';    break;
Packit f00812
          case 't' : inch = '\t';    break;
Packit f00812
          case 'n' : inch = '\n';    break;
Packit f00812
          case 'v' : inch = '\v';    break;
Packit f00812
          case 'f' : inch = '\f';    break;
Packit f00812
          case 'r' : inch = '\r';    break;
Packit f00812
          case 'X' :
Packit f00812
          case 'x' : inch = input();
Packit f00812
                     if(isxdigit(inch)){
Packit f00812
                       temp = hextoint(toupper(inch));
Packit f00812
                       inch = input();
Packit f00812
                       if(isxdigit(inch)){
Packit f00812
                         temp = (temp << 4) + hextoint(toupper(inch));
Packit f00812
                       } else {
Packit f00812
                         unput(inch);
Packit f00812
                       }
Packit f00812
                       inch = temp; 
Packit f00812
                     } else {
Packit f00812
                       unput(inch);
Packit f00812
                       inch = 'x';
Packit f00812
                     }
Packit f00812
             break;
Packit f00812
          default:
Packit f00812
             if(isodigit(inch)){
Packit f00812
                temp = inch - '0';
Packit f00812
                inch = input();
Packit f00812
                if(isodigit(inch)){
Packit f00812
                  temp = (temp << 3) + (inch - '0');
Packit f00812
                } else {
Packit f00812
                  unput(inch);
Packit f00812
                  goto done;
Packit f00812
                }
Packit f00812
                inch = input();
Packit f00812
                if(isodigit(inch)){
Packit f00812
                  temp = (temp << 3) + (inch - '0');
Packit f00812
                } else {
Packit f00812
                  unput(inch);
Packit f00812
                }
Packit f00812
             done:
Packit f00812
                inch = temp; 
Packit f00812
             }
Packit f00812
          } 
Packit f00812
        }
Packit f00812
        buffer[count++] = inch;
Packit f00812
        if(count >= max_size){
Packit f00812
           buffer = realloc(buffer,max_size + ALLOC_SIZE);
Packit f00812
           max_size += ALLOC_SIZE;
Packit f00812
        }           
Packit f00812
        inch = input();
Packit f00812
     }
Packit f00812
     if(inch == EOF || inch == '\n'){
Packit f00812
       yyerror("Unterminated string.");
Packit f00812
     }
Packit f00812
     buffer[count] = '\0';
Packit f00812
     printf("String = \"%s\"\n",buffer);
Packit f00812
     free(buffer);
Packit f00812
   }
Packit f00812
.
Packit f00812
\n
Packit f00812
%%
Packit f00812
Packit f00812