aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNathan Vance <nathav63@gmail.com>2015-05-03 21:15:05 -0400
committerNathan Vance <nathav63@gmail.com>2015-05-03 21:15:05 -0400
commit3e9f426d734a559ead5e1b087fb02cab31811e95 (patch)
tree2ed86d1d5b3203f91baf85c6a15afea69b197fee
parentFixed bug causing array content to be overwritten (diff)
download7w-3e9f426d734a559ead5e1b087fb02cab31811e95.tar.gz
7w-3e9f426d734a559ead5e1b087fb02cab31811e95.tar.bz2
7w-3e9f426d734a559ead5e1b087fb02cab31811e95.zip
Added basic view of game results
-rw-r--r--data.c12
-rw-r--r--endgame.c96
2 files changed, 108 insertions, 0 deletions
diff --git a/data.c b/data.c
index aa08fda..f69a87b 100644
--- a/data.c
+++ b/data.c
@@ -26,6 +26,7 @@ void write_trade(int player, int tradel, int trader);
void player_turn(int player);
void haltError(char *message, int num);
void arraycpy(int *from, int *to, int len);
+void endgame();
#define MISC 3
#define DATAGOLD 0
@@ -284,6 +285,11 @@ void data_addvictory(int p)
player[p][3][4] += amnt;
}
+int data_getvictories(int p)
+{
+ return player[p][3][4];
+}
+
int data_getgold(int p)
{
return player[p][3][3] + turngoldbuffer[p];
@@ -617,6 +623,11 @@ int data_gettotvps(int p)
return tot;
}
+int* data_getplayerdat(int p)
+{
+ return player[p][3];
+}
+
int data_potentialvps(int p, int era, int card)
{
int i;
@@ -655,5 +666,6 @@ void data_endgame()
}
io_printborder(x, y++, width);
io_getkey();
+ endgame();
halt();
}
diff --git a/endgame.c b/endgame.c
new file mode 100644
index 0000000..81ee2f9
--- /dev/null
+++ b/endgame.c
@@ -0,0 +1,96 @@
+#include "7w.h"
+#include <stdio.h>
+
+int io_getkey();
+int data_numplayers();
+int postyn(int x, int y, char *message);
+void halt();
+void io_clearscreen();
+void io_printborder(int x, int y, int width);
+int io_printtext(int xorigin, int y, int width, char* text);
+int* print_wonder(int x, int y, int player, int cursor);
+int print_wondersmall(int x, int y, int player, int selected, int dir);
+int* data_getplayerdat(int p);
+int* data_getbuilt(int p);
+int science(int player);
+int* get_special(int era, int card, int player);
+
+int endgame_printscorebreakdown(int p)
+{
+ int* playerdat = data_getplayerdat(p);
+ int gold = playerdat[3] / 3;
+ int military = playerdat[4] - playerdat[5];
+ int vps = playerdat[6];
+ int special = 0;
+ int *built = data_getbuilt(p);
+ int i;
+ for(i = 0; built[i] != -1; i += 2) {
+ special += get_special(built[i], built[i+1], p)[0];
+ }
+ int sci = science(p);
+ int x = 61;
+ int y = 0;
+ int width = 28;
+ io_printborder(x, y++, width);
+ y = io_printtext(x, y, width, " Score breakdown:");
+ char s[40];
+ y = io_printtext(x, y, width, "Category | Score");
+ sprintf(s, " Gold | %d", gold);
+ y = io_printtext(x, y, width, s);
+ sprintf(s, " Military | %d", military);
+ y = io_printtext(x, y, width, s);
+ sprintf(s, " Cards | %d", vps);
+ y = io_printtext(x, y, width, s);
+ sprintf(s, " Guilds | %d", special);
+ y = io_printtext(x, y, width, s);
+ sprintf(s, " Science | %d", sci);
+ y = io_printtext(x, y, width, s);
+ sprintf(s, " Total: %d", gold + military + vps + special + sci);
+ y = io_printtext(x, y, width, s);
+ io_printborder(x, y, width);
+ return y;
+}
+
+int endgame_refresh(int focus)
+{
+ io_clearscreen();
+ int num = data_numplayers();
+ int x, y, i;
+ print_wonder(34, 0, focus, -1);
+ x = y = 0;
+ for(i = 0; i < num; i++) {
+ y = print_wondersmall(x, y, i, focus == i, 0);
+ }
+ printmessage(x, y+2, 35);
+ return endgame_printscorebreakdown(focus);
+}
+
+void endgame()
+{
+ int focus = 0;
+ int bottomy;
+ while(1) {
+ bottomy = endgame_refresh(focus);
+ switch(io_getkey()) {
+ case UP: focus--;
+ break;
+ case DOWN: focus++;
+ break;
+ case RIGHT: focus++;
+ break;
+ case LEFT: focus--;
+ break;
+ case ENTER:
+ if(postyn(61, bottomy, "Are you sure you want to quit?")) halt();
+ break;
+ case '\t': focus = (focus+1)%(data_numplayers()+1);
+ break;
+ case 'q':
+ if(postyn(61, bottomy, "Are you sure you want to quit?")) halt();
+ break;
+ default: break;
+ }
+ if(focus < 0) focus = data_numplayers()-1;
+ focus = focus%data_numplayers();
+ }
+}
bgstack15