reindentert til 4 mellomrom

This commit is contained in:
Øystein Ingmar Skartsæterhagen 2008-10-08 17:25:20 +00:00
parent 9ab50fbd9b
commit f4fa43c695
2 changed files with 162 additions and 159 deletions

106
src/net.c
View File

@ -1,3 +1,5 @@
/* -*- c-basic-offset: 4 -*- */
#include <sys/types.h> #include <sys/types.h>
#include <sys/socket.h> #include <sys/socket.h>
#include <netinet/in.h> #include <netinet/in.h>
@ -18,69 +20,69 @@ int nclients = 0;
int int
errx(int eval, const char *fmt, ...) { errx(int eval, const char *fmt, ...) {
va_list ap; va_list ap;
vfprintf(stderr, fmt, ap); vfprintf(stderr, fmt, ap);
exit(eval); exit(eval);
} }
void void
net_server(int port) { net_server(int port) {
struct sockaddr_in serveraddr; struct sockaddr_in serveraddr;
serveraddr.sin_family = AF_INET; serveraddr.sin_family = AF_INET;
serveraddr.sin_addr.s_addr = htonl(INADDR_ANY); serveraddr.sin_addr.s_addr = htonl(INADDR_ANY);
serveraddr.sin_port = htons(port); serveraddr.sin_port = htons(port);
servsock=socket(PF_INET, SOCK_STREAM, IPPROTO_TCP); servsock=socket(PF_INET, SOCK_STREAM, IPPROTO_TCP);
if (servsock<0) if (servsock<0)
errx(1, "socket: %s", strerror(errno)); errx(1, "socket: %s", strerror(errno));
if (bind(servsock, (struct sockaddr *)&serveraddr, sizeof(serveraddr)) < 0) if (bind(servsock, (struct sockaddr *)&serveraddr, sizeof(serveraddr)) < 0)
errx(1, "bind port %d: %s", port, strerror(errno)); errx(1, "bind port %d: %s", port, strerror(errno));
if (listen(servsock, 10) < 0) if (listen(servsock, 10) < 0)
errx(1, "listen: %s", strerror(errno)); errx(1, "listen: %s", strerror(errno));
pollfds[0].fd=servsock; pollfds[0].fd=servsock;
pollfds[0].events=POLLIN|POLLERR|POLLHUP; pollfds[0].events=POLLIN|POLLERR|POLLHUP;
for (int i=SRV_FDS; i<(SRV_FDS+MAX_CLIENTS); i++) { for (int i=SRV_FDS; i<(SRV_FDS+MAX_CLIENTS); i++) {
pollfds[0].fd=-1; pollfds[0].fd=-1;
pollfds[0].events=0; pollfds[0].events=0;
} }
} }
void void
net_poll() { net_poll() {
int npoll; int npoll;
npoll=poll(pollfds, SRV_FDS+MAX_CLIENTS, -1); npoll=poll(pollfds, SRV_FDS+MAX_CLIENTS, -1);
if (npoll<0) if (npoll<0)
errx(1, "poll: %s", strerror(errno)); errx(1, "poll: %s", strerror(errno));
if (pollfds[0].revents) { if (pollfds[0].revents) {
struct sockaddr_in clientaddr; struct sockaddr_in clientaddr;
int cfd; int cfd;
socklen_t slen; socklen_t slen;
cfd=accept(servsock, (struct sockaddr *)&clientaddr, &slen); cfd=accept(servsock, (struct sockaddr *)&clientaddr, &slen);
if (cfd<0) if (cfd<0)
errx(1, "accept: %s", strerror(errno)); errx(1, "accept: %s", strerror(errno));
// FIXME log, shout, or something // FIXME log, shout, or something
if (nclients>MAX_CLIENTS) { if (nclients>MAX_CLIENTS) {
#define STR_SERVER_FULL "Sorry, the server is full" #define STR_SERVER_FULL "Sorry, the server is full"
write(cfd, STR_SERVER_FULL, sizeof(STR_SERVER_FULL)-1); write(cfd, STR_SERVER_FULL, sizeof(STR_SERVER_FULL)-1);
close(cfd); close(cfd);
} else { } else {
int i; int i;
for (i=SRV_FDS; i<(SRV_FDS+MAX_CLIENTS); i++) for (i=SRV_FDS; i<(SRV_FDS+MAX_CLIENTS); i++)
if (pollfds[i].fd==-1) break; if (pollfds[i].fd==-1) break;
pollfds[i].fd=cfd; pollfds[i].fd=cfd;
pollfds[i].events=POLLIN|POLLERR|POLLHUP; pollfds[i].events=POLLIN|POLLERR|POLLHUP;
nclients++; nclients++;
}
npoll--;
} }
npoll--; for (int i=SRV_FDS; npoll && i<(SRV_FDS+MAX_CLIENTS); i++) {
} if (pollfds[SRV_FDS+i].revents) {
for (int i=SRV_FDS; npoll && i<(SRV_FDS+MAX_CLIENTS); i++) { int n;
if (pollfds[SRV_FDS+i].revents) { char buf[100];
int n; n=read(pollfds[SRV_FDS+i].fd, &buf, sizeof(buf));
char buf[100]; // parse buf
n=read(pollfds[SRV_FDS+i].fd, &buf, sizeof(buf)); // handle disconnections
// parse buf }
// handle disconnections
} }
}
} }

View File

@ -1,3 +1,4 @@
/* -*- c-basic-offset: 4 -*- */
#define NONE 0 #define NONE 0
#define PHARAO 1 #define PHARAO 1
@ -11,140 +12,140 @@
#define F_SPLIT 2 #define F_SPLIT 2
struct square { struct square {
int piece : 4; int piece : 4;
int side : 1; int side : 1;
int dir : 2; int dir : 2;
} board[10][8]; } board[10][8];
/* /*
struct pieceinfo { struct pieceinfo {
char ascii[]; char ascii[];
} pieceinfo[] = { } pieceinfo[] = {
{ //NONE { //NONE
.ascii = { ' ' } } .ascii = { ' ' } }
{ //PHARAO { //PHARAO
.ascii = { '=' } } .ascii = { '=' } }
{ //DJHED { //DJHED
.ascii = { '/', '\\' } } .ascii = { '/', '\\' } }
{ //PYRAMID { //PYRAMID
.ascii = { 'd', 'b', 'p', 'q' } } .ascii = { 'd', 'b', 'p', 'q' } }
{ //OBELISK { //OBELISK
.ascii = { 'o' } } .ascii = { 'o' } }
{ //OBELISK2 { //OBELISK2
.ascii = { '@' } } .ascii = { '@' } }
}; };
*/ */
/* /*
void void
print_board() { print_board() {
for (int y=0; y<8; y++) for (int y=0; y<8; y++)
for (int x=0; x<10; x++) for (int x=0; x<10; x++)
; ;
} }
*/ */
int int
laser(int side) { laser(int side) {
int x, y, dir; int x, y, dir;
int ddir; int ddir;
switch (side) { switch (side) {
case 0: case 0:
x=9; y=0; dir=0; x=9; y=0; dir=0;
break; break;
case 1: case 1:
x=0; y=7; dir=2; x=0; y=7; dir=2;
break; break;
default: default:
return 0; return 0;
} }
for (;;) { for (;;) {
switch (board[x][y].piece) { switch (board[x][y].piece) {
case NONE: case NONE:
break; break;
case PHARAO: case PHARAO:
return 2 + board[x][y].side; /* GAME OVER */ return 2 + board[x][y].side; /* GAME OVER */
case OBELISK2: case OBELISK2:
board[x][y].piece = OBELISK; board[x][y].piece = OBELISK;
return 1; return 1;
case OBELISK: case OBELISK:
board[x][y].piece = NONE; board[x][y].piece = NONE;
return 1; return 1;
case DJHED: case DJHED:
ddir = board[x][y].dir - dir; ddir = board[x][y].dir - dir;
dir=(dir + 1 - 2*(ddir & 1)) & 3; dir=(dir + 1 - 2*(ddir & 1)) & 3;
break; break;
case PYRAMID: case PYRAMID:
ddir = board[x][y].dir - dir; ddir = board[x][y].dir - dir;
if (ddir & 2) { if (ddir & 2) {
board[x][y].piece = NONE; board[x][y].piece = NONE;
return 1; return 1;
} }
dir=(dir + 1 - 2*(ddir & 1)) & 3; dir=(dir + 1 - 2*(ddir & 1)) & 3;
break; break;
}
switch (dir & 3) {
case 0: y++; if (y>7) return 0; break;
case 1: x++; if (x>9) return 0; break;
case 2: y--; if (y<0) return 0; break;
case 3: x--; if (x<0) return 0; break;
}
} }
switch (dir & 3) {
case 0: y++; if (y>7) return 0; break;
case 1: x++; if (x>9) return 0; break;
case 2: y--; if (y<0) return 0; break;
case 3: x--; if (x<0) return 0; break;
}
}
} }
int int
move(int side, int x, int y, int dir, int flags) { move(int side, int x, int y, int dir, int flags) {
if ((x<0) || (x>9) || (y<0) || (y>7)) if ((x<0) || (x>9) || (y<0) || (y>7))
return 0; return 0;
if (!board[x][y].piece) if (!board[x][y].piece)
return 0; return 0;
if ((board[x][y].side != side)) if ((board[x][y].side != side))
return 0; return 0;
if (flags & F_ROTATE) { if (flags & F_ROTATE) {
if ( !((dir==1) || (dir==-1))) if ( !((dir==1) || (dir==-1)))
return 0; return 0;
board[x][y].dir = (board[x][y].dir + dir) & 3; board[x][y].dir = (board[x][y].dir + dir) & 3;
return 1;
}
/* dir =
0 1 2
7 X 3
6 5 4
*/
if ((dir<0) || (dir>7))
return 0;
int ny = y - (dir<3) + ((dir>3) && (dir<7));
int nx = x + ((dir>1) && (dir<5)) - ((dir<1) || (dir>5));
if ((nx<0) || (nx>9) || (ny<0) || (ny>7))
return 0;
if (flags & F_SPLIT) {
if (board[nx][ny].piece || (board[x][y].piece != OBELISK2))
return 0;
board[x][y].piece = OBELISK;
board[nx][ny].piece = OBELISK;
board[nx][ny].side = board[x][y].side;
return 1;
}
if (board[nx][ny].piece &&
!((board[x][y].piece == DJHED) &&
((board[nx][ny].piece != DJHED) &&
(board[nx][ny].piece != PHARAO))))
return 0;
struct square tmp;
tmp = board[nx][ny];
board[nx][ny] = board[x][y];
board[x][y] = tmp;
return 1; return 1;
}
/* dir =
0 1 2
7 X 3
6 5 4
*/
if ((dir<0) || (dir>7))
return 0;
int ny = y - (dir<3) + ((dir>3) && (dir<7));
int nx = x + ((dir>1) && (dir<5)) - ((dir<1) || (dir>5));
if ((nx<0) || (nx>9) || (ny<0) || (ny>7))
return 0;
if (flags & F_SPLIT) {
if (board[nx][ny].piece || (board[x][y].piece != OBELISK2))
return 0;
board[x][y].piece = OBELISK;
board[nx][ny].piece = OBELISK;
board[nx][ny].side = board[x][y].side;
return 1;
}
if (board[nx][ny].piece &&
!((board[x][y].piece == DJHED) &&
((board[nx][ny].piece != DJHED) &&
(board[nx][ny].piece != PHARAO))))
return 0;
struct square tmp;
tmp = board[nx][ny];
board[nx][ny] = board[x][y];
board[x][y] = tmp;
return 1;
} }