shithub: cflood

Download patch

ref: ea2033bc08e7a9b5ab4e8afe0609a61fa4ff098c
parent: 8d4482800b46dbcdb67d49d9ba35bf0a03aa205c
author: Sigrid Solveig Haflínudóttir <[email protected]>
date: Thu Dec 13 13:29:30 EST 2012

remove garbage

--- a/games/cflood.c
+++ b/games/cflood.c
@@ -1,205 +1,205 @@
-#include <u.h>
-#include <libc.h>
-#include <draw.h>
-#include <event.h>
-
-enum {
-	Ssmall,
-	Snormal,
-	Slarge,
-
-	Flood = 1<<7,
-	ColorMask = 0x0f,
-
-	NumColors = 6,
-
-	ButtonSize = 32
-};
-
-const int sizes[] = {14, 21, 28};
-const int turns[] = {25, 35, 50};
-const ulong srccolors[NumColors] = {
-	0x6060a8ff,
-	0xf6f61dff,
-	0x46b0e0ff,
-	0x7ea020ff,
-	0xf070a0ff,
-	0xdc4a20ff
-};
-char *mstr[] = {
-	"14x14 / 25",
-	"25x25 / 35",
-	"28x28 / 50",
-	"exit",
-	0
-};
-
-static int size;
-static int wait4click;
-static int turnsleft;
-static uchar cells[28*28]; // enough for maximal size
-static Image *colors[NumColors];
-static Rectangle buttons[NumColors];
-
-static void
-floodneighbours(uchar color, int x, int y);
-
-static void
-redraw(Image *screen) {
-	Rectangle r = screen->r;
-	draw(screen, r, display->white, nil, ZP);
-
-	const uchar *cell = &cells[0];
-	int w = Dx(r), h = Dy(r) - ButtonSize - 2;
-	int c = (w < h ? w : h) / size;
-	w = c*size;
-
-	// cells
-	for(int x = r.min.x; x < r.min.x+size*c; x+=c) {
-		for(int y = r.min.y; y < r.min.y+size*c; y+=c) {
-			Rectangle r = Rect(x, y, x+c, y+c);
-			draw(screen, r, colors[*cell & ColorMask], nil, ZP);
-			cell++;
-		}
-	}
-
-	// buttons
-	int startx = r.min.x + (w/2) - NumColors*ButtonSize/2;
-	int y = r.min.y + h;
-	for(int i = 0, x = startx; i < NumColors; i++, x += ButtonSize) {
-		buttons[i] = Rect(x, y, x+ButtonSize, y+ButtonSize);
-		draw(screen, buttons[i], colors[i], nil, ZP);
-	}
-
-	flushimage(display, 1);
-}
-
-static void
-floodrecurse(uchar color, int x, int y) {
-	uchar *c = &cells[x + y*size];
-	if((*c & Flood) == 0 && (*c & ColorMask) == color) {
-		*c = color | Flood;
-		floodneighbours(color, x, y);
-	}
-}
-
-static void
-floodneighbours(uchar color, int x, int y) {
-	cells[x + y*size] = color | Flood;
-
-	if(x > 0)
-		floodrecurse(color, x-1, y);
-	if(x < size-1)
-		floodrecurse(color, x+1, y);
-	if(y > 0)
-		floodrecurse(color, x, y-1);
-	if(y < size-1)
-		floodrecurse(color, x, y+1);
-}
-
-static int
-reflood(uchar color) {
-	color &= ColorMask;
-
-	int n = 0;
-	for(int x = 0; x < size; x++)
-		for(int y = 0; y < size; y++)
-			if(cells[x + y*size] & Flood) {
-				floodneighbours(color, x, y);
-				n++;
-			}
-	return n;
-}
-
-static void
-flood(uchar color) {
-	if((cells[0] & Flood) != 0 && (cells[0] & ColorMask) == color)
-		return;
-
-	if(!turnsleft)
-		return;
-
-	int n = reflood(color);
-	redraw(screen);
-
-	if(n == size*size) {
-		// win
-		wait4click = 1;
-	} else if(--turnsleft == 0) {
-		// fail
-		wait4click = 1;
-	}
-}
-
-static void
-newgame(int sid) {
-	size = sizes[sid];
-	turnsleft = turns[sid];
-
-	// randomize
-	uchar *c = &cells[0];
-	for(int i = 0; i < size*size; i++) {
-		*c++ = nrand(NumColors);
-	}
-
-	cells[0] |= Flood;
-	reflood(cells[0]);
-	redraw(screen);
-}
-
-void
-eresized(int new)
-{
-	if(new && getwindow(display, Refnone) < 0)
-		fprint(2, "can't reattach to window");
-	redraw(screen);
-}
-
-void main(int, char**) {
-	Menu menu;
-
-	if(initdraw(0, 0, "cflood") < 0)
-		sysfatal("initdraw failed");
-
-	Rectangle r = Rect(0, 0, 1, 1);
-	for(int i = 0; i < NumColors; i++) {
-		colors[i] = allocimage(display, r, CMAP8, 1, srccolors[i]);
-	}
-
-	einit(Emouse);
-	menu.item = mstr;
-	menu.lasthit = 0;
-	srand(time(0));
-
-	int sid = Snormal;
-	newgame(sid);
-
-	for(int mold = 0;;) {
-		Event e;
-		int key = event(&e);
-		Mouse m = e.mouse;
-
-		if(key != Emouse)
-			continue;
-
-		if(m.buttons & 4) {
-			int p = emenuhit(3, &m, &menu);
-			if(p >= Ssmall && p <= Slarge)
-				newgame(sid = p);
-			else if(p > 0)
-				break;
-		} else if(wait4click && !mold && m.buttons != mold) {
-			wait4click = 0;
-			newgame(sid);
-		} else if(m.buttons & 1) {
-			for(int i = 0; i < NumColors; i++) {
-				if(ptinrect(m.xy, buttons[i])) {
-					flood(i);
-					break;
-				}
-			}
-		}
-
-		mold = m.buttons;
-	}
-}
+#include <u.h>
+#include <libc.h>
+#include <draw.h>
+#include <event.h>
+
+enum {
+	Ssmall,
+	Snormal,
+	Slarge,
+
+	Flood = 1<<7,
+	ColorMask = 0x0f,
+
+	NumColors = 6,
+
+	ButtonSize = 32
+};
+
+const int sizes[] = {14, 21, 28};
+const int turns[] = {25, 35, 50};
+const ulong srccolors[NumColors] = {
+	0x6060a8ff,
+	0xf6f61dff,
+	0x46b0e0ff,
+	0x7ea020ff,
+	0xf070a0ff,
+	0xdc4a20ff
+};
+char *mstr[] = {
+	"14x14 / 25",
+	"25x25 / 35",
+	"28x28 / 50",
+	"exit",
+	0
+};
+
+static int size;
+static int wait4click;
+static int turnsleft;
+static uchar cells[28*28]; // enough for maximal size
+static Image *colors[NumColors];
+static Rectangle buttons[NumColors];
+
+static void
+floodneighbours(uchar color, int x, int y);
+
+static void
+redraw(Image *screen) {
+	Rectangle r = screen->r;
+	draw(screen, r, display->white, nil, ZP);
+
+	const uchar *cell = &cells[0];
+	int w = Dx(r), h = Dy(r) - ButtonSize - 2;
+	int c = (w < h ? w : h) / size;
+	w = c*size;
+
+	// cells
+	for(int x = r.min.x; x < r.min.x+size*c; x+=c) {
+		for(int y = r.min.y; y < r.min.y+size*c; y+=c) {
+			Rectangle r = Rect(x, y, x+c, y+c);
+			draw(screen, r, colors[*cell & ColorMask], nil, ZP);
+			cell++;
+		}
+	}
+
+	// buttons
+	int startx = r.min.x + (w/2) - NumColors*ButtonSize/2;
+	int y = r.min.y + h;
+	for(int i = 0, x = startx; i < NumColors; i++, x += ButtonSize) {
+		buttons[i] = Rect(x, y, x+ButtonSize, y+ButtonSize);
+		draw(screen, buttons[i], colors[i], nil, ZP);
+	}
+
+	flushimage(display, 1);
+}
+
+static void
+floodrecurse(uchar color, int x, int y) {
+	uchar *c = &cells[x + y*size];
+	if((*c & Flood) == 0 && (*c & ColorMask) == color) {
+		*c = color | Flood;
+		floodneighbours(color, x, y);
+	}
+}
+
+static void
+floodneighbours(uchar color, int x, int y) {
+	cells[x + y*size] = color | Flood;
+
+	if(x > 0)
+		floodrecurse(color, x-1, y);
+	if(x < size-1)
+		floodrecurse(color, x+1, y);
+	if(y > 0)
+		floodrecurse(color, x, y-1);
+	if(y < size-1)
+		floodrecurse(color, x, y+1);
+}
+
+static int
+reflood(uchar color) {
+	color &= ColorMask;
+
+	int n = 0;
+	for(int x = 0; x < size; x++)
+		for(int y = 0; y < size; y++)
+			if(cells[x + y*size] & Flood) {
+				floodneighbours(color, x, y);
+				n++;
+			}
+	return n;
+}
+
+static void
+flood(uchar color) {
+	if((cells[0] & Flood) != 0 && (cells[0] & ColorMask) == color)
+		return;
+
+	if(!turnsleft)
+		return;
+
+	int n = reflood(color);
+	redraw(screen);
+
+	if(n == size*size) {
+		// win
+		wait4click = 1;
+	} else if(--turnsleft == 0) {
+		// fail
+		wait4click = 1;
+	}
+}
+
+static void
+newgame(int sid) {
+	size = sizes[sid];
+	turnsleft = turns[sid];
+
+	// randomize
+	uchar *c = &cells[0];
+	for(int i = 0; i < size*size; i++) {
+		*c++ = nrand(NumColors);
+	}
+
+	cells[0] |= Flood;
+	reflood(cells[0]);
+	redraw(screen);
+}
+
+void
+eresized(int new)
+{
+	if(new && getwindow(display, Refnone) < 0)
+		fprint(2, "can't reattach to window");
+	redraw(screen);
+}
+
+void main(int, char**) {
+	Menu menu;
+
+	if(initdraw(0, 0, "cflood") < 0)
+		sysfatal("initdraw failed");
+
+	Rectangle r = Rect(0, 0, 1, 1);
+	for(int i = 0; i < NumColors; i++) {
+		colors[i] = allocimage(display, r, CMAP8, 1, srccolors[i]);
+	}
+
+	einit(Emouse);
+	menu.item = mstr;
+	menu.lasthit = 0;
+	srand(time(0));
+
+	int sid = Snormal;
+	newgame(sid);
+
+	for(int mold = 0;;) {
+		Event e;
+		int key = event(&e);
+		Mouse m = e.mouse;
+
+		if(key != Emouse)
+			continue;
+
+		if(m.buttons & 4) {
+			int p = emenuhit(3, &m, &menu);
+			if(p >= Ssmall && p <= Slarge)
+				newgame(sid = p);
+			else if(p > 0)
+				break;
+		} else if(wait4click && !mold && m.buttons != mold) {
+			wait4click = 0;
+			newgame(sid);
+		} else if(m.buttons & 1) {
+			for(int i = 0; i < NumColors; i++) {
+				if(ptinrect(m.xy, buttons[i])) {
+					flood(i);
+					break;
+				}
+			}
+		}
+
+		mold = m.buttons;
+	}
+}
--- a/games/mkfile
+++ b/games/mkfile
@@ -1,7 +1,7 @@
-</$objtype/mkfile
-
-TARG=cflood
-OFILES=cflood.$O
-BIN=/$objtype/bin
-
-</sys/src/cmd/mkone
+</$objtype/mkfile
+
+TARG=cflood
+OFILES=cflood.$O
+BIN=/$objtype/bin
+
+</sys/src/cmd/mkone