2021-01-08 17:37:10 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdlib.h>
|
2021-01-08 23:44:49 +00:00
|
|
|
#include <stdbool.h>
|
2021-01-08 17:37:10 +00:00
|
|
|
|
2021-01-08 19:03:11 +00:00
|
|
|
typedef enum {
|
|
|
|
INK, DEK,
|
|
|
|
BREK, GLEK,
|
2021-01-08 23:44:49 +00:00
|
|
|
PUK, KUK,
|
|
|
|
LP, RP,
|
|
|
|
TUK, FUK
|
|
|
|
}inst;
|
|
|
|
|
|
|
|
char dtape[30000] = {0};//hlava dh
|
|
|
|
inst ptape[30000] = {0};//hlava ph
|
|
|
|
size_t loops[2][15000] = {{0},{0}};
|
|
|
|
size_t loopscount=0;
|
|
|
|
char* dhead = dtape;
|
|
|
|
inst* phead = ptape;
|
2021-01-08 19:03:11 +00:00
|
|
|
|
2021-01-08 23:44:49 +00:00
|
|
|
void run_tukafuk(const char* code) {//
|
2021-01-08 17:37:10 +00:00
|
|
|
char current_char;
|
2021-01-08 23:44:49 +00:00
|
|
|
bool running = false;
|
2021-01-08 17:37:10 +00:00
|
|
|
size_t i;
|
2021-01-08 23:44:49 +00:00
|
|
|
//bolo pozadovane zistit, kdd su skoky a teda som ich ulozil
|
|
|
|
//(tie adresy skokov)
|
|
|
|
for (i = 0; code[i] != 0; i++) {
|
|
|
|
current_char = code[i];
|
|
|
|
size_t j;
|
|
|
|
size_t loop;
|
|
|
|
switch(current_char){
|
|
|
|
case 'T':
|
|
|
|
if(code[i+1]=='U')
|
|
|
|
if(code[i+2]=='K'){
|
|
|
|
*phead = TUK;
|
|
|
|
phead++;
|
|
|
|
i+=2;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'I':
|
|
|
|
if(code[i+1]=='N')
|
|
|
|
if(code[i+2]=='K'){
|
|
|
|
*phead = INK;
|
|
|
|
phead++;
|
|
|
|
i+=2;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'D':
|
|
|
|
if(code[i+1]=='E')
|
|
|
|
if(code[i+2]=='K'){
|
|
|
|
*phead = DEK;
|
|
|
|
phead++;
|
|
|
|
i+=2;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'B':
|
|
|
|
if(code[i+1]=='R')
|
|
|
|
if(code[i+2]=='E')
|
|
|
|
if(code[i+3] =='K'){
|
|
|
|
*phead = BREK;
|
|
|
|
phead++;
|
|
|
|
i+=3;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'G':
|
|
|
|
if(code[i+1]=='L')
|
|
|
|
if(code[i+2]=='E')
|
|
|
|
if(code[i+3] =='K'){
|
|
|
|
*phead = GLEK;
|
|
|
|
phead++;
|
|
|
|
i+=3;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'P':
|
|
|
|
if(code[i+1]=='U')
|
|
|
|
if(code[i+2]=='K'){
|
|
|
|
*phead = PUK;
|
|
|
|
phead++;
|
|
|
|
i+=2;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'K':
|
|
|
|
if(code[i+1]=='U')
|
|
|
|
if(code[i+2]=='K'){
|
|
|
|
*phead = KUK;
|
|
|
|
phead++;
|
|
|
|
i+=2;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'F':
|
|
|
|
if(code[i+1]=='U')
|
|
|
|
if(code[i+2]=='K'){
|
|
|
|
*phead = FUK;
|
|
|
|
phead++;
|
|
|
|
i+=2;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case ']':
|
|
|
|
for(size_t k=0;k<loopscount;k++){
|
|
|
|
if(loops[1][k]==i){
|
|
|
|
*phead = RP;
|
|
|
|
phead++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case '[':
|
|
|
|
j = i;
|
|
|
|
loop = 1;
|
|
|
|
while (loop > 0){//aby J nepreslo von.
|
|
|
|
current_char = code[++j];//
|
|
|
|
if (current_char==0){
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
if (current_char == ']'){
|
|
|
|
loop--;
|
|
|
|
} else if (current_char == '['){
|
|
|
|
loop++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if(loop==0){
|
|
|
|
*phead = LP;
|
|
|
|
phead++;
|
|
|
|
loops[0][loopscount] = i;
|
|
|
|
loops[1][loopscount++] = j;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
/*if (current_char == 'INK') {//>
|
2021-01-08 17:37:10 +00:00
|
|
|
++ptr;
|
2021-01-08 23:44:49 +00:00
|
|
|
} else if (current_char == 'DEK') {//<
|
2021-01-08 17:37:10 +00:00
|
|
|
--ptr;
|
2021-01-08 19:03:11 +00:00
|
|
|
} else if (current_char == 'BREK') {// +
|
2021-01-08 17:37:10 +00:00
|
|
|
++*ptr;
|
2021-01-08 19:03:11 +00:00
|
|
|
} else if (current_char == 'GLEK') {// -
|
2021-01-08 17:37:10 +00:00
|
|
|
--*ptr;
|
2021-01-08 19:03:11 +00:00
|
|
|
} else if (current_char == 'PUK' ) {// .
|
2021-01-08 17:37:10 +00:00
|
|
|
putchar(*ptr);
|
2021-01-08 19:03:11 +00:00
|
|
|
} else if (current_char == 'KUK') {// ,
|
2021-01-08 17:37:10 +00:00
|
|
|
*ptr = getchar();
|
2021-01-08 19:03:11 +00:00
|
|
|
} else if (current_char == '[') {//start loop
|
2021-01-08 17:37:10 +00:00
|
|
|
continue;
|
2021-01-08 23:44:49 +00:00
|
|
|
} else if (current_char == ']' && *ptr) {stop loop
|
|
|
|
loop = 1;
|
2021-01-08 17:37:10 +00:00
|
|
|
while (loop > 0) {
|
|
|
|
current_char = input[--i];
|
|
|
|
if (current_char == '[') {
|
|
|
|
loop--;
|
|
|
|
} else if (current_char == ']') {
|
|
|
|
loop++;
|
|
|
|
}
|
2021-01-08 23:44:49 +00:00
|
|
|
*/
|
2021-01-08 17:37:10 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
int main() {
|
2021-01-09 10:23:46 +00:00
|
|
|
char buff[30000];
|
|
|
|
FILE *fp;
|
|
|
|
fp = fopen("kod.txt","r");
|
|
|
|
|
|
|
|
memset(buff,0,sizeof(buff));
|
|
|
|
printf("buffer:\n %s\n",buff);
|
|
|
|
fread(buff,1,30000,fp);
|
|
|
|
|
|
|
|
printf("buffer:\n %s\n",buff);
|
|
|
|
run_tukafuk(buff);
|
|
|
|
fclose(fp);
|
2021-01-08 23:44:49 +00:00
|
|
|
printf("Programova Paska: \n");
|
2021-01-09 10:23:46 +00:00
|
|
|
|
2021-01-08 23:44:49 +00:00
|
|
|
for(inst *ptr=ptape;ptr<phead;ptr++){
|
|
|
|
switch (*ptr){
|
|
|
|
case TUK:printf("TUK ");
|
|
|
|
break;
|
|
|
|
case INK:printf("INK ");
|
|
|
|
break;
|
|
|
|
case DEK:printf("DEK ");
|
|
|
|
break;
|
|
|
|
case BREK:printf("BREK ");
|
|
|
|
break;
|
|
|
|
case GLEK:printf("GLEK ");
|
|
|
|
break;
|
|
|
|
case PUK:printf("PUK ");
|
|
|
|
break;
|
|
|
|
case KUK:printf("KUK ");
|
|
|
|
break;
|
|
|
|
case FUK:printf("FUK ");
|
|
|
|
break;
|
|
|
|
case LP:printf("LP ");
|
|
|
|
break;
|
|
|
|
case RP:printf("RP ");
|
|
|
|
break;
|
|
|
|
default:printf("NULL ");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
printf("\n");
|
2021-01-08 17:37:10 +00:00
|
|
|
return 0;
|
|
|
|
}
|