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