garten
changeset 17:5e6c9260913a
lots of cleanups and small fixes
author | meillo@marmaro.de |
---|---|
date | Wed, 23 Jul 2008 17:14:38 +0200 (2008-07-23) |
parents | 3c104b5f5158 |
children | 5937504619f2 |
files | clock.c db.c db.h environment.c game.h growth.c weather.c |
diffstat | 7 files changed, 50 insertions(+), 44 deletions(-) [+] |
line diff
1.1 --- a/clock.c Wed Jul 23 16:49:10 2008 +0200 1.2 +++ b/clock.c Wed Jul 23 17:14:38 2008 +0200 1.3 @@ -1,29 +1,29 @@ 1.4 #include <stdio.h> 1.5 #include <stdlib.h> 1.6 - 1.7 #include "db.h" 1.8 #include "game.h" 1.9 1.10 1.11 - 1.12 - 1.13 void inc_time() { 1.14 /* get current time */ 1.15 sprintf(query, "select time from game;"); 1.16 - db_query(query); 1.17 + stmt = db_query(query); 1.18 if (sqlite3_step(stmt) == SQLITE_ROW) { 1.19 gametime = sqlite3_column_int(stmt, 0); 1.20 } else { 1.21 - fprintf(stderr, "error: %s\n", sqlite3_errmsg(db)); 1.22 + db_error("get current time"); 1.23 } 1.24 sqlite3_finalize(stmt); 1.25 1.26 /* increment time */ 1.27 - sprintf(query, " update game set time = '%d';", ++gametime); 1.28 + sprintf(query, 1.29 + "update game" 1.30 + "set time = '%d';" 1.31 + , ++gametime 1.32 + ); 1.33 if (!db_update(query)) { 1.34 - printf("error: time update failed: %s\n", sqlite3_errmsg(db)); 1.35 + db_error("time update"); 1.36 } 1.37 - sqlite3_finalize(stmt); 1.38 } 1.39 1.40
2.1 --- a/db.c Wed Jul 23 16:49:10 2008 +0200 2.2 +++ b/db.c Wed Jul 23 17:14:38 2008 +0200 2.3 @@ -45,6 +45,18 @@ 2.4 } 2.5 2.6 2.7 +int db_rows(sqlite3_stmt* stmt) { 2.8 + int i = 0; 2.9 + 2.10 + sqlite3_reset(stmt); 2.11 + while (sqlite3_step(stmt) == SQLITE_ROW) { 2.12 + i++; 2.13 + } 2.14 + sqlite3_reset(stmt); 2.15 + return i; 2.16 +} 2.17 + 2.18 + 2.19 int read_time() { 2.20 sprintf(query, "select time from game;"); 2.21 stmt = db_query(query); 2.22 @@ -57,3 +69,7 @@ 2.23 return gametime; 2.24 } 2.25 2.26 + 2.27 +void db_error(char* info) { 2.28 + fprintf(stderr, "%s%sSQL error: %s\n", (info) ? info : "", (info) ? ": " : "", sqlite3_errmsg(db)); 2.29 +}
3.1 --- a/db.h Wed Jul 23 16:49:10 2008 +0200 3.2 +++ b/db.h Wed Jul 23 17:14:38 2008 +0200 3.3 @@ -1,12 +1,16 @@ 3.4 #include <sqlite3.h> 3.5 3.6 char* database; 3.7 +int gametime; 3.8 char query[1024]; 3.9 sqlite3* db; 3.10 sqlite3_stmt* stmt; 3.11 3.12 +int read_time(); 3.13 3.14 void db_connect(); 3.15 void db_close(); 3.16 sqlite3_stmt* db_query(char* query); 3.17 int db_update(char* query); 3.18 +int db_rows(sqlite3_stmt* stmt); 3.19 +void db_error(char* info);
4.1 --- a/environment.c Wed Jul 23 16:49:10 2008 +0200 4.2 +++ b/environment.c Wed Jul 23 17:14:38 2008 +0200 4.3 @@ -24,12 +24,17 @@ 4.4 4.5 4.6 /* set weather */ 4.7 - sprintf(query, " insert into environment \ 4.8 - (tick, groundwater, slugs, earthworms) \ 4.9 - values ('%d', '%d', '%d', '%d') ", 4.10 - gametime, groundwater, slugs, earthworms); 4.11 + sprintf(query, 4.12 + "insert into environment " 4.13 + "(tick, groundwater, slugs, earthworms) " 4.14 + "values ('%d', '%d', '%d', '%d') " 4.15 + , gametime 4.16 + , groundwater 4.17 + , slugs 4.18 + , earthworms 4.19 + ); 4.20 if (!db_update(query)) { 4.21 - printf("error: environment insertion failed: %s\n", sqlite3_errmsg(db)); 4.22 + db_error("environment insertion"); 4.23 } 4.24 4.25 }
5.1 --- a/game.h Wed Jul 23 16:49:10 2008 +0200 5.2 +++ b/game.h Wed Jul 23 17:14:38 2008 +0200 5.3 @@ -1,9 +1,3 @@ 5.4 -int gametime; 5.5 - 5.6 - 5.7 -int read_time(); 5.8 - 5.9 - 5.10 void worldclock(void); 5.11 void environment(void); 5.12 void weather(void);
6.1 --- a/growth.c Wed Jul 23 16:49:10 2008 +0200 6.2 +++ b/growth.c Wed Jul 23 17:14:38 2008 +0200 6.3 @@ -5,14 +5,13 @@ 6.4 6.5 6.6 void grow_plants() { 6.7 - /* get weather and last environments to calculate the next one */ 6.8 - sprintf(query, "update field \ 6.9 - set age = age+1, size = size+1 "); 6.10 - stmt = db_query(query); 6.11 + sprintf(query, 6.12 + "update field " 6.13 + "set age = age+1, size = size+1 " 6.14 + ); 6.15 if (!db_update(query)) { 6.16 - printf("E: update failed ++ %s\n", sqlite3_errmsg(db)); 6.17 + db_error("grow plants"); 6.18 } 6.19 - sqlite3_finalize(stmt); 6.20 } 6.21 6.22
7.1 --- a/weather.c Wed Jul 23 16:49:10 2008 +0200 7.2 +++ b/weather.c Wed Jul 23 17:14:38 2008 +0200 7.3 @@ -26,8 +26,8 @@ 7.4 float mean_hum[12] = {1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0, 9.0, 10.0, 11.0, 12.0}; 7.5 7.6 7.7 +/* generates random number between -limit and +limit */ 7.8 float rand_limit(float limit) { 7.9 - /* generates random number between -limit and +limit */ 7.10 int r; 7.11 7.12 r = rand() / ( ((float) RAND_MAX + 1) / (2*limit) ); 7.13 @@ -45,8 +45,9 @@ 7.14 " select temp, sun, rain, wind, hum from weather " 7.15 " order by tick desc " 7.16 " limit %d " 7.17 - , nlast); 7.18 - db_query(query); 7.19 + , nlast 7.20 + ); 7.21 + stmt = db_query(query); 7.22 for (i = 0; i < nlast && sqlite3_step(stmt) == SQLITE_ROW; i++) { 7.23 lastw[i].temp = sqlite3_column_double(stmt, 0); 7.24 lastw[i].sun = sqlite3_column_double(stmt, 1); 7.25 @@ -55,19 +56,6 @@ 7.26 lastw[i].hum = sqlite3_column_double(stmt, 4); 7.27 } 7.28 sqlite3_finalize(stmt); 7.29 - 7.30 - /* 7.31 - result = mysql_store_result(conn); 7.32 - for (i = 0; i < nlast && (row = mysql_fetch_row(result)); i++) { 7.33 - lastw[i].temp = atof(row[0]); 7.34 - lastw[i].sun = atof(row[1]); 7.35 - lastw[i].rain = atof(row[2]); 7.36 - lastw[i].wind = atof(row[3]); 7.37 - lastw[i].hum = atof(row[4]); 7.38 - } 7.39 - mysql_free_result(result); 7.40 - */ 7.41 - 7.42 } 7.43 7.44 7.45 @@ -86,10 +74,10 @@ 7.46 " insert into weather " 7.47 " (tick, temp, sun, rain, wind, hum) " 7.48 " values ('%d', '%f', '%f', '%f', '%f', '%f') " 7.49 - , gametime, w->temp, w->sun, w->rain, w->wind, w->hum); 7.50 - /* puts(query); */ 7.51 + , gametime, w->temp, w->sun, w->rain, w->wind, w->hum 7.52 + ); 7.53 if (!db_update(query)) { 7.54 - printf("error: weather insertion failed: %s\n", sqlite3_errmsg(db)); 7.55 + db_error("weather insertion"); 7.56 } 7.57 } 7.58