From 67fe91ce74f49d7ea1640b38d84d0469a4a7b9f6 Mon Sep 17 00:00:00 2001 From: Carlos Israel Orta Orta Date: Fri, 26 Apr 2024 00:22:05 -0600 Subject: [PATCH] Remove print dependencies and leave only base functions and phantom piece --- a.out | Bin 22616 -> 0 bytes tetris.c | 144 ++++++++++++++++++++++++++++++++++++------------------- 2 files changed, 96 insertions(+), 48 deletions(-) delete mode 100755 a.out diff --git a/a.out b/a.out deleted file mode 100755 index 7d993a56023658de53072c4f130834ecb4d27b9b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 22616 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 E07}C?Z2$lO diff --git a/tetris.c b/tetris.c index c970e13..36ed591 100644 --- a/tetris.c +++ b/tetris.c @@ -3,6 +3,7 @@ #include #include #include +#include #define ROWS 20 // you can change height and width of table with ROWS and COLS #define COLS 10 @@ -10,21 +11,25 @@ #define FALSE 0 #define MAXSHAPES 7 #define MAXNEXTPIECES 6 +#define MAXWIDTH 4 char table[ROWS][COLS] = {0}; char *Table[ROWS] = {0}; +char Buffer[ROWS][COLS] = {0}; +char NextPzBuffer[MAXNEXTPIECES][MAXWIDTH*MAXWIDTH] = {0}; int score = 0; char GameOn = TRUE; suseconds_t timer = 400000; // decrease this to make it faster int decrease = 1000; int newLines = 0; +char TSpin = 0; typedef struct { - char array[4][4]; + char array[MAXWIDTH][MAXWIDTH]; char wasHold; int width, row, col; } Shape; -Shape current, pieceHold, *hold = NULL; +Shape current, pieceHold; Shape nextPiece[MAXNEXTPIECES]; int iNextPiece = 0, jNextPiece = MAXNEXTPIECES - 1; @@ -41,29 +46,57 @@ Shape ShapesArray[MAXSHAPES]= { // you can add any shape like it's done above. Don't be naughty. }; -char CopyMemShape(Shape *dst, Shape *org){ - int i; +void increaseNewLines(int lines){ + newLines += lines; +} +int getNewLines(){ + return newLines; +} +char getGameOn(){ + return GameOn; +} +int getScore(){ + return score; +} +char** getBuffer(){ + return (char**)Buffer; +} +char** getNextPzBuffer(){ + return (char**)NextPzBuffer; +} + +char **getHoldPiece(){ + return (char**)pieceHold.array; +} + +char CopyMem(char *dst, char *org, unsigned int size){ + int i, j; long long *orgL = (long long*)org, *dstL = (long long*)dst; - if (dst == NULL || org == NULL) + int *orgI = (int*)org, *dstI = (int*)dst; + short *orgS = (short*)org, *dstS = (short*)dst; + if (dst == NULL) return 0; - for (i = 0; i < sizeof(Shape) / sizeof(long long); i++) - dstL[i] = orgL[i]; - i = i * sizeof(long long); - for (i = i; i < sizeof(Shape); i++) - dst[i] = org[i]; + for (i = 0; i < size / sizeof(long long); i++) + dstL[i] = org != NULL ? orgL[i] : 0; + i = i * 2; + for (i = i; i < size / sizeof(int); i++) + dstI[i] = org != NULL ? orgI[i] : 0; + i = i * 2; + for (i = i; i < size / sizeof(short); i++) + dstS[i] = org != NULL ? orgS[i] : 0; + i = i * 2; + for (i = i; i < size; i++) + dst[i] = org != NULL ? org[i] : 0; return 1; } +char CopyMemShape(Shape *dst, Shape *org){ + return CopyMem((char*)dst, (char*)org, sizeof(Shape)); +} + Shape CopyShape(Shape shape){ Shape new_shape = {0}; - int i; - char *org = (char*)&shape, *dst = (char*)&new_shape; - long long *orgL = (long long*)org, *dstL = (long long*)dst; - for (i = 0; i < sizeof(Shape) / sizeof(long long); i++) - dstL[i] = orgL[i]; - i = i * sizeof(long long); - for (i = i; i < sizeof(Shape); i++) - dst[i] = org[i]; + CopyMem((char*)&new_shape, (char*)&shape, sizeof(Shape)); return new_shape; } @@ -140,16 +173,10 @@ void RemoveFullRowsAndUpdateScore(){ count++; int l, k; char *cleanRow = Table[i]; - long long *erase = (long long*)cleanRow; for (k = i; k >= 1; k--) Table[k] = Table[k-1]; Table[0] = cleanRow; - for (k = 0; k < COLS/sizeof(long long); k++) - erase[k] = 0; - k = k * sizeof(long long); - for (k = k; k < COLS; k++) - cleanRow[k] = 0; - timer-=decrease--; + CopyMem(cleanRow, NULL, sizeof(char)*COLS); } } score += 100*count; @@ -174,28 +201,42 @@ void AddPendingLines(){ } } -void PrintTable(){ - char Buffer[ROWS][COLS] = {0}; +void FillOutput(){ + Shape temp = CopyShape(current); + while (CheckPosition(temp)) + temp.row++; + temp.row--; int i, j; - for(i = 0; i < current.width ;i++){ - for(j = 0; j < current.width ; j++){ - if(current.array[i][j]) + CopyMem((char*)Buffer, NULL, sizeof(char)*ROWS*COLS); + for(i = 0; i < ROWS ;i++){ + if (i < MAXNEXTPIECES){ + char *oOutput = (char*)nextPiece[(iNextPiece + i) % MAXNEXTPIECES].array; + CopyMem((char*)NextPzBuffer[i],oOutput,sizeof(char)*MAXWIDTH*MAXWIDTH); + } + for(j = 0; j < COLS ; j++){ + if((i < MAXWIDTH && j < MAXWIDTH) && current.row >=0 && current.array[i][j]) Buffer[current.row+i][current.col+j] = current.array[i][j]; + if((i < MAXWIDTH && j < MAXWIDTH) && temp.row >=0 && temp.row - 1 > current.row && temp.array[i][j]) + Buffer[temp.row+i][temp.col+j] = tolower(temp.array[i][j]); + Buffer[i][j] = (Table[i][j] + Buffer[i][j]) ? (Buffer[i][j]?Buffer[i][j]:Table[i][j]): '.'; } } +} + +void PrintTable(){ + int i, j; clear(); for(i=0; i ", nextPiece[j].array[1][1]); - j = (j + 1) % MAXNEXTPIECES == 0 ? 0 : j + 1; + printw("%c -> ", NextPzBuffer[i][1*MAXWIDTH+1]); } - printw(" HOLD: %c \n", hold == NULL ? ' ' : hold->array[1][1]); + printw(" HOLD: %c \n", pieceHold.wasHold == 0 ? ' ' : pieceHold.array[1][1]); for(i = 0; i < ROWS ;i++){ for(j = 0; j < COLS ; j++){ - printw("%c ", (Table[i][j] + Buffer[i][j])? (Buffer[i][j]?Buffer[i][j]:Table[i][j]): '.'); + printw("%c ", Buffer[i][j]); } printw("\n"); } @@ -216,6 +257,7 @@ void ManipulateCurrent(int action){ RemoveFullRowsAndUpdateScore(); SetNewRandomShape(); AddPendingLines(); + TSpin = 0; break; case 's': if (newLines < 0) @@ -224,10 +266,13 @@ void ManipulateCurrent(int action){ if(CheckPosition(temp)) current.row++; else { - WriteToTable(); - RemoveFullRowsAndUpdateScore(); - SetNewRandomShape(); - AddPendingLines(); + if (TSpin > 2){ + WriteToTable(); + RemoveFullRowsAndUpdateScore(); + SetNewRandomShape(); + AddPendingLines(); + TSpin = 0; + } else TSpin++; } break; case 'd': @@ -243,18 +288,18 @@ void ManipulateCurrent(int action){ case 'r': if (current.wasHold) break; - if (hold == NULL){ - hold = &pieceHold; - CopyMemShape(hold,¤t); + if (pieceHold.wasHold == 0){ + CopyMemShape(&pieceHold,¤t); SetNewRandomShape(); current.wasHold = 1; + pieceHold.wasHold = 1; } else{ + current.wasHold = 1; CopyMemShape(&temp,¤t); - CopyMemShape(¤t,hold); - CopyMemShape(hold,&temp); + CopyMemShape(¤t,&pieceHold); + CopyMemShape(&pieceHold,&temp); current.col = rand()%(COLS-current.width+1); current.row = 0; - current.wasHold = 1; // DeleteShape(current); if(!CheckPosition(current)){ GameOn = FALSE; @@ -273,7 +318,7 @@ void ManipulateCurrent(int action){ break; } // DeleteShape(temp); - PrintTable(); + FillOutput(); } struct timeval before_now, now; @@ -282,7 +327,7 @@ int hasToUpdate(){ } int main() { - srand(time(0)); + srand(time(0)); for (int i = 0; i < ROWS; i++) Table[i] = table[i]; for (int i = 0; i < MAXNEXTPIECES; i++){ @@ -295,18 +340,21 @@ int main() { gettimeofday(&before_now, NULL); timeout(1); SetNewRandomShape(); + FillOutput(); PrintTable(); - int wait = 5; + int wait = 10; while(GameOn){ if ((c = getch()) != ERR) { ManipulateCurrent(c); + PrintTable(); } gettimeofday(&now, NULL); if (hasToUpdate()) { //time difference in microsec accuracy ManipulateCurrent('s'); + PrintTable(); gettimeofday(&before_now, NULL); if (wait == 0){ - wait = 5; + wait = 10; newLines += 1; } else wait--; }