Смекни!
smekni.com

Синтаксический распознаватель арифметического оператора условного перехода языка FORTRAN (стр. 3 из 4)

УНИВЕРСИТЕТ\n\n\r");

cprintf(" КАФЕДРА АСУ\n\n\r");

cprintf(" Курсовая работа по системному программированию на тему:\n\r");

cprintf(" \"Арифметический оператор условного перехода языка FORTRAN\".\n\n\r");

cprintf(" Студента группы А-513\n\n\r");

cprintf(" Бойко Константина Анатольевича.\n\n\r");

cprintf("В программе использованы клавиши:\n\r");

cprintf(" F1 - данный Help.\n\r");

cprintf(" F2 - грамматика языка.\n\r");

cprintf(" F3 - язык оператора.\n\r");

cprintf(" F4 - компиляция файла.\n\r");

cprintf(" ESC - выход из программы.\n\n\r");

cprintf(" Для выхода из Help нажмите любую клавишу.");

getch();

}

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

// Грамматика.

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

void Grammar(void)

{

window(10,2,70,23);

textattr(46);

clrscr();

Windows(10,2,70,23,"Grammar");

window(12,4,68,22);

cprintf(" 1. <Оператор> -> IF(<АВ>)<LABEL>,<LABEL>,<LABEL>&bsol;n&bsol;r");

cprintf(" 2. <LABEL> -> <ЦБЗ>&bsol;n&bsol;r");

cprintf(" 3. <АВ> -> T | <АВ>+T | <АВ>-T&bsol;n&bsol;r");

cprintf(" 4. T -> O | T*O | T/O | T**O&bsol;n&bsol;r");

cprintf(" 5. O -> (<АВ>) | <Идентификатор> | <ЧПЗ>&bsol;n&bsol;r");

cprintf(" 6. <Идентификатор> -> Б{Б|Ц}&bsol;n&bsol;r");

cprintf(" 7. <ЦБЗ> -> Ц{Ц}&bsol;n&bsol;r");

cprintf(" 8. <ЧПЗ> -> Ц{Ц}[.Ц{Ц}]&bsol;n&bsol;n&bsol;r");

cprintf(" Условные обозначения:&bsol;n&bsol;r");

cprintf(" T - терм.&bsol;n&bsol;r");

cprintf(" O - операнд.&bsol;n&bsol;r");

cprintf(" Б - буква.&bsol;n&bsol;r");

cprintf(" Ц - цифра.&bsol;n&bsol;r");

cprintf(" ЦБЗ - целое без знака.&bsol;n&bsol;r");

cprintf(" ЧПЗ - число с плавающей запятой.&bsol;n&bsol;r");

cprintf(" ** - возведение в степень.&bsol;n&bsol;r");

cprintf(" <LABEL> - метка.&bsol;n&bsol;r");

cprintf(" <АВ> - арифметическое выражение.");

getch();

}

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

// Язык.

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

void Language(void)

{

window(20,7,60,17);

textattr(62);

clrscr();

Windows(20,7,60,17,"Language");

window(22,9,58,16);

cprintf(" IF(<АВ>) LABEL1,LABEL2,LABEL3&bsol;n&bsol;n&bsol;r");

cprintf(" АВ - Арифметическое Выражение.&bsol;n&bsol;r");

cprintf(" LABEL1,LABEL2,LABEL3 - первая,вторая и третья метки соответственно.&bsol;n&bsol;r");

getch();

}

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

// Компиляция программы.

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

void Compile(void)

{

window(20,7,55,13);

textattr(94);

clrscr();

Windows(20,7,55,13,"Compile");

window(22,8,58,16);

gotoxy(1,1);

if(com!=0)

{

cprintf("&bsol;n&bsol;n Файл откомпилирован!");

Beep(900,1000);

return;

}

cputs("&bsol;n Идет компиляция файла.&bsol;r&bsol;n&bsol;n Пожалуйста, подождите...");

#ifdef TEST

window(1,1,80,25);

clrscr();

#endif

for(int i=0;file1[i][0]!=NULL;i++)

{

Operator(file1[i]);

if(l!=3 && l!=0)

Error(11);

e1++;

e2=0;

}

com++;

delay(300);

Beep(1000,200);

}

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

// Оператор.

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

void Operator(char* str)

{

pos=2;

l=0;

string[0]=NULL;

strcpy(string,str);

string[strlen(string)-1]=NULL;

char temp[3];

temp[0]=str[0];

temp[1]=str[1];

temp[2]=NULL;

#ifdef TEST

puts(string);

puts(temp);

getch();

#endif

fprintf(fl," ¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾&bsol;n");

fprintf(fl,"%s&bsol;n",string);

if(strcmp(temp,"IF")!=0)

{

#ifdef TEST

printf("Не найден оператор IF.&bsol;n");

#endif

Error(10);

return;

}

Scan();

if(nx==' ')

Scan();

if(nx!='(')

Error(7);

if(nx==NULL)

{

Error(12);

Error(9);

return;

}

AB();

while(nx!=')' && nx!=NULL && nx!=' ')

Scan();

if(nx!=')')

Error(3);

if(nx==NULL)

{

Error(9);

return;

}

Scan();

if(nx==NULL)

{

Error(9);

return;

}

if(nx==' ')

Scan();

Label();

if(nx!=',')

{

Error(5);

Scan();

}

else

Scan();

if(nx==NULL)

return;

Label();

if(nx!=',')

{

Error(5);

Scan();

}

else

Scan();

if(nx==NULL)

return;

Label();

if(nx!=NULL)

{

Error(6);

Scan();

}

return;

}

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

// Scan.

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

void Scan(void)

{

nx=string[pos++];

#ifdef TEST

printf("Текущий символ %c - %d.&bsol;n",nx,nx);

#endif

fprintf(fl,"Текущий символ %c - %d.&bsol;n",nx,nx);

}

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

// Метка.

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

void Label(void)

{

if(ABS() == NO)

{

Error(8);

Scan();

}

else

l++;

}

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

// Целое Без Знака.

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

int ABS(void)

{

#ifdef TEST

cprintf("ABS - проверка на Целое Без Знака с цифры %c.&bsol;r&bsol;n",nx);

#endif

fprintf(fl,"ABS - проверка на Целое Без Знака с цифры %c.&bsol;n",nx);

if(isdigit(nx))

{

while(isdigit(nx))

Scan();

return(YES);

}

return(NO);

}

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

// Арифметическое Выражение.

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

int AB(void)

{

#ifdef TEST

cprintf("AB - Проверка на Арифметическое Выражение.&bsol;r&bsol;n");

#endif

fprintf(fl,"AB - Проверка на Арифметическое Выражение.&bsol;n");

Scan();

if(nx==')')

{

Error(12);

return(NO);

}

Term();

if(nx=='+')

{

AB();

}

else if(nx=='-')

{

AB();

}

if(nx==NULL)

return(OK);

else if(nx!='*' && nx!='/' && nx!=')')

Error(1);

return(YES);

}

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

// Терм.

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

int Term(void)

{

#ifdef TEST

cprintf("Term - Проверка на Терм.&bsol;r&bsol;n");

#endif

fprintf(fl,"Term - Проверка на Терм.&bsol;n");

Operand();

if(nx=='/')

{

Scan();

Term();

}

else if(nx=='*')

{

Scan();

if(nx=='*')

{

Scan();

Term();

}

else Term();

}

if(nx==NULL)

return(OK);

else if(nx!='+' && nx!='-' && nx!=')')

Error(2);

return(OK);

}

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

// Операнд.

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

int Operand(void)

{

#ifdef TEST

cprintf("Operand - Проверка на Операнд.&bsol;r&bsol;n");

#endif

fprintf(fl,"Operand - Проверка на Операнд.&bsol;n");

if(nx=='(')

{

AB();

if(nx!=')')

Error(3);

else

{

Scan();

return(OK);

}

}

else if(IDENT() == NO)

{

if(Float() == NO)

Error(4);

}

return(OK);

}

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

// Идентификатор.

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

int IDENT(void)

{

#ifdef TEST

cprintf("IDENT - Проверка на Идентификатор с символа %c.&bsol;r&bsol;n",nx);

#endif

fprintf(fl,"IDENT - Проверка на Идентификатор с символа %c.&bsol;n",nx);

if(isalpha(nx))

{

while(isalpha(nx) || isdigit(nx))

Scan();

return(YES);

}

return(NO);

}

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

// Ошибки.

//¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾¾

void Error(int num)

{

char *E[]={

"Ожидается '+' или '-'.",

"Ожидается '*','/' или '**'.",

"Ожидается ).",

"Ожидается идентификатор или целое без знака.",

"Отсутствует ','.",

"Не конец строки.",

"Ожидается (.",

"Метка - не целое без знака.",

"Отсутствуют метки.",

"Не найден оператор IF.",

"Отсутствует метка.",