diff --git a/README.md b/README.md index 48def19..d559aa3 100644 --- a/README.md +++ b/README.md @@ -1,5 +1,5 @@ # New BSD Games - + *You have a computing machine from 1980's and you wonder how you can use it?
You deal with a GUI-less machine at work and are looking for ways to kill time?
You have to make a Reversi AI for your homework and you don't know where to copy it from?
@@ -8,8 +8,7 @@ **Don't worry** anymore as you've got nbsdgames now! -I originally made these to be added to NetBSD ( but the few i talked with preferred to have games in the repositories rather than in /usr/games itself) . - +I originally made these in hope of them being added to NetBSD ( but the few i talked with preferred to have games in the repositories rather than in /usr/games itself) . These include: @@ -22,7 +21,8 @@ These include: * SOS * Rabbithole (A maze-exploring game where you have to gather items from all around the maze rather than reaching an end, the idea maybe mine) * Pipes (Same as the famous Pipe Mania, unplayable on the environments that don't support the line characters) - +* Fifteen +* Memoblocks (or Memory blocks. A similar game was included in Windows 7) ## Prerequisites * git (optional) @@ -41,7 +41,7 @@ These include: Like this: ``` sh - git clone https://github.com/untakenstupidnick/nbsdgames + git clone https://github.com/untakenstupidnick/nbsdgames cd ~/nbsdgames/sources export PREFIX= ~/bin make install @@ -58,8 +58,8 @@ It's been made available for openSUSE thanks to Zinjanthropus: https://build.ope ## How to contribute -Thanks for your generousity! You can... +Oh, You are so kind! You can... * Share these with your friends -* Tell me your suggestions, bug reports, games you want to be added etc. -* Make a package for your distro ( This additional repo is made to make it easier https://github.com/untakenstupidnick/nbsdgames-sources ) -* Port it to other OSes with help from PDcurses (Not very hard, but there are incompatibilities between PDcurses and ncurses) +* Tell me your feature requests, bug reports, games you want to be added etc. +* Make a package for your distro +* Tell me if you're interested in porting it to non-Unix (Possible in theory since there is PDCurses for SDL, and SDL for everything) diff --git a/sources/.fifteen.c.swp b/sources/.fifteen.c.swp new file mode 100644 index 0000000..f286022 Binary files /dev/null and b/sources/.fifteen.c.swp differ diff --git a/sources/Makefile b/sources/Makefile index 841cc8d..cada0cd 100644 --- a/sources/Makefile +++ b/sources/Makefile @@ -1,6 +1,6 @@ # -*- Makefile -*- -all: jewels sudoku mines reversi checkers battleship rabbithole sos pipes +all: jewels sudoku mines reversi checkers battleship rabbithole sos pipes fifteen memoblocks jewels: jewels.c config.h $(CC) jewels.c -lncurses -o ./jewels @@ -20,12 +20,16 @@ sos: sos.c $(CC) sos.c -lncurses -o ./sos pipes: pipes.c config.h $(CC) pipes.c -lncurses -o ./pipes +fifteen: fifteen.c + $(CC) fifteen.c -lncurses -o ./fifteen +memoblocks: memoblocks.c + $(CC) memoblocks.c -lncurses -o ./memoblocks clean: - rm ./jewels ./sudoku ./checkers ./mines ./reversi ./battleship ./rabbithole ./sos ./pipes + rm ./jewels ./sudoku ./checkers ./mines ./reversi ./battleship ./rabbithole ./sos ./pipes ./fifteen ./memoblocks uninstall: - rm $(PREFIX)/jewels $(PREFIX)/sudoku $(PREFIX)/checkers $(PREFIX)/mines $(PREFIX)/reversi $(PREFIX)/battleship $(PREFIX)/rabbithole $(PREFIX)/sos $(PREFIX)/pipes + rm $(PREFIX)/jewels $(PREFIX)/sudoku $(PREFIX)/checkers $(PREFIX)/mines $(PREFIX)/reversi $(PREFIX)/battleship $(PREFIX)/rabbithole $(PREFIX)/sos $(PREFIX)/pipes $(PREFIX)/fifteen $(PREFIX)/memoblocks copy_sources: - cp Makefile config.h jewels.c sudoku.c mines.c reversi.c checkers.c battleship.c rabbithole.c sos.c pipes.c $(PREFIX) -install: jewels sudoku mines reversi checkers battleship rabbithole sos pipes - cp jewels sudoku mines reversi checkers battleship rabbithole sos pipes $(PREFIX) + cp Makefile config.h jewels.c sudoku.c mines.c reversi.c checkers.c battleship.c rabbithole.c sos.c pipes.c fifteen.c memoblocks.c $(PREFIX) +install: jewels sudoku mines reversi checkers battleship rabbithole sos pipes fifteen memoblocks + cp jewels sudoku mines reversi checkers battleship rabbithole sos pipes fifteen memoblocks $(PREFIX) diff --git a/sources/checkers.c b/sources/checkers.c index c3ddc8e..8d004a5 100644 --- a/sources/checkers.c +++ b/sources/checkers.c @@ -552,6 +552,7 @@ int main(int argc,char** argv){ double adv = 1;//used to determine when the game is a draw double previousadv =1; Turn: + curs_set(0); jumpagainy=jumpagainx=-1; kinged=0; turn =-turn; @@ -577,7 +578,7 @@ int main(int argc,char** argv){ result=-1; goto End; } - else if(todraw==50){ // 50 turns without any gains for each side + else if(todraw==50){ // 50 turns without any gain for either side result=0; goto End; } diff --git a/sources/fifteen.c b/sources/fifteen.c new file mode 100644 index 0000000..82bc96e --- /dev/null +++ b/sources/fifteen.c @@ -0,0 +1,247 @@ +#include +#include +#include +#include +#include +#include +/* +.-- +|__ +| IFTEEN + +Authored by Hossein Bakhtiarifar +No rights are reserved and this software comes with no warranties of any kind to the extent permitted by law. + +compile with -lncurses +*/ +typedef signed char byte; +byte size; +byte py,px; +byte ey,ex; //the empty tile +chtype green=A_BOLD; //bold when there is no color +void rectangle(byte sy,byte sx){ + for(byte y=0;y<=size+1;y++){ + mvaddch(sy+y,sx,ACS_VLINE); + mvaddch(sy+y,sx+size*2,ACS_VLINE); + } + for(byte x=0;x<=size*2;x++){ + mvaddch(sy,sx+x,ACS_HLINE); + mvaddch(sy+size+1,sx+x,ACS_HLINE); + } + mvaddch(sy,sx,ACS_ULCORNER); + mvaddch(sy+size+1,sx,ACS_LLCORNER); + mvaddch(sy,sx+size*2,ACS_URCORNER); + mvaddch(sy+size+1,sx+size*2,ACS_LRCORNER); +} +void logo(byte sy,byte sx){ + mvaddstr(sy,sx, ".--"); + mvaddstr(sy+1,sx,"|__"); + mvaddstr(sy+2,sx,"| IFTEEN"); +} +//convert integer to representing sign +char int2sgn(byte num){ + if(!num) + return ' '; + else if(0< num && num <= 9) + return num+'0'; + else if(10<=num && num <=35) + return num-10+'a'; + else if(36<=num && num <=51) + return num-36+'A'; + return 0; +} +/*bool isinorder(byte board[size][size],byte y,byte x){ using check[][] is much cheaper + return (board[y][x] == y*size+x+1); +} */ + +//display +void draw(byte sy,byte sx,char board[size][size],char check[size][size]){ + rectangle(sy,sx); + chtype prnt; + byte y,x; + for(y=0;y=0 && y=0 && x7){ + fprintf(stderr,"3<=size<=7\n"); + return EXIT_FAILURE; + } + } + signal(SIGINT,sigint_handler); + srandom(time(NULL)%UINT_MAX); + initscr(); + mousemask(ALL_MOUSE_EVENTS,NULL); + noecho(); + cbreak(); + keypad(stdscr,1); + if(has_colors()){ + start_color(); + use_default_colors(); + init_pair(1,COLOR_GREEN,-1); + green=COLOR_PAIR(1); + } + char board[size][size]; + char check[size][size]; + fill(check); + int input; + Start: + py=px=0; + ey=ex=size-1; + curs_set(0); + fill(board); + shuffle(board); + while(1){ + erase(); + logo(0,0); + draw(3,0,board,check); + refresh(); + if(issolved(board,check)) + break; + input = getch(); + if( input==KEY_F(1) || input=='?' ) + help(); + if( input==KEY_F(2) ) + gameplay(); + if( input==KEY_MOUSE ) + mouseinput(); + if( (input=='k' || input==KEY_UP) && py>0) + py--; + if( (input=='j' || input==KEY_DOWN) && py0) + px--; + if( (input=='l' || input==KEY_RIGHT) && px +#include +#include +#include +#include +#include +/* +. . _ +|\/| |_) +| |EMORY|_)LOCKS + +Authored by Hossein Bakhtiarifar +No rights are reserved and this software comes with no warranties of any kind to the extent permitted by law. + +compile with -lncurses +*/ +typedef signed char byte; +typedef unsigned char ubyte; +byte size,size2;//size2 is there to avoid a lot of multiplications +byte py,px; +byte fy,fx; //the first tile +chtype colors[6]={0}; +void rectangle(byte sy,byte sx){ + for(byte y=0;y<=size+1;y++){ + mvaddch(sy+y,sx,ACS_VLINE); + mvaddch(sy+y,sx+size2+1,ACS_VLINE); + } + for(byte x=0;x<=size2+1;x++){ + mvaddch(sy,sx+x,ACS_HLINE); + mvaddch(sy+size+1,sx+x,ACS_HLINE); + } + mvaddch(sy,sx,ACS_ULCORNER); + mvaddch(sy+size+1,sx,ACS_LLCORNER); + mvaddch(sy,sx+size2+1,ACS_URCORNER); + mvaddch(sy+size+1,sx+size2+1,ACS_LRCORNER); +} +void logo(byte sy,byte sx){ + mvaddstr(sy,sx, ". . _"); + mvaddstr(sy+1,sx,"|\\/| |_)"); + mvaddstr(sy+2,sx,"| |EMORY|_)LOCKS"); +} +//convert integer to representing sign +char int2sgn(byte num){ + if(0< num && num <= 9) + return num+'0'; + else if(10<=num && num <=35) + return num-10+'a'; + else if(36<=num && num <=51) + return num-36+'A'; + else if(52<=num && num<=64) + return num-52+'!'; + return 0; +} +//display +void draw(byte sy,byte sx,chtype board[size][size2],bool show[size][size2]){ + rectangle(sy,sx); + byte y,x; + chtype prnt; + for(y=0;y=2){ + size=atoi(argv[1]); + if(size<3 || size>19){ + fprintf(stderr,"3<=size<=19\n"); + return EXIT_FAILURE; + } + if(!strcmp("help",argv[1])){ + printf("Usage: %s [size]\n",argv[0]); + return EXIT_SUCCESS; + } + } + signal(SIGINT,sigint_handler); + srandom(time(NULL)%UINT_MAX); + initscr(); + mousemask(ALL_MOUSE_EVENTS,NULL); + noecho(); + cbreak(); + keypad(stdscr,1); + if(has_colors()){ + start_color(); + use_default_colors(); + if( has_colors() ){ + start_color(); + use_default_colors(); + init_pair(1,COLOR_YELLOW,-1); + init_pair(2,COLOR_GREEN,-1); + init_pair(3,COLOR_BLUE,-1); + init_pair(4,COLOR_CYAN,-1); + init_pair(5,COLOR_MAGENTA,-1); + init_pair(6,COLOR_RED,-1); + for(byte b=0;b<6;b++){ + colors[b]=COLOR_PAIR(b+1); + } + } + } + else if(size>8)//big sizes depend on color display + size=8; + size2=size*2; + chtype board[size][size2]; + bool show[size][size2]; + int input; + time_t tstart,now; + Start: + tstart=time(NULL); + py=px=0; + fy=fx=-1; + curs_set(0); + memset(show,0,size*size2); + fill(board); + shuffle(board); + while(1){ + erase(); + logo(0,0); + draw(3,0,board,show); + refresh(); + if(issolved(show)) + break; + input = getch(); + if( input==KEY_F(1) || input=='?' ) + help(); + if( input==KEY_F(2) ) + gameplay(); + if( input==KEY_MOUSE ) + mouseinput(); + if( (input=='k' || input==KEY_UP) && py>0) + py--; + if( (input=='j' || input==KEY_DOWN) && py0) + px--; + if( (input=='l' || input==KEY_RIGHT) && px