summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorCracker64 <cracker642@gmail.com>2011-01-30 21:46:50 (GMT)
committer Cracker64 <cracker642@gmail.com>2011-01-30 21:46:50 (GMT)
commit8ed2947b4cbfbe21b9ba30961c469823f2e285ee (patch)
tree24ee9b111014b1df89d3b999f88037d452c9f3ec /src
parentfcf958da21621887a80249f2af863991544815fd (diff)
downloadpowder-8ed2947b4cbfbe21b9ba30961c469823f2e285ee.zip
powder-8ed2947b4cbfbe21b9ba30961c469823f2e285ee.tar.gz
update with latest
Diffstat (limited to 'src')
-rw-r--r--src/http.c27
-rw-r--r--src/interface.c114
-rw-r--r--src/main.c14
-rw-r--r--src/misc.c13
-rw-r--r--src/powder.c6
5 files changed, 143 insertions, 31 deletions
diff --git a/src/http.c b/src/http.c
index a68ea45..a881c73 100644
--- a/src/http.c
+++ b/src/http.c
@@ -680,7 +680,7 @@ char *http_simple_get(char *uri, int *ret, int *len)
return http_async_req_stop(ctx, ret, len);
}
static char hex[] = "0123456789abcdef";
-void http_auth_headers(void *ctx, char *user, char *pass)
+void http_auth_headers(void *ctx, char *user, char *pass, char *session_id)
{
char *tmp;
int i;
@@ -690,7 +690,6 @@ void http_auth_headers(void *ctx, char *user, char *pass)
if (user)
{
- http_async_add_header(ctx, "X-Auth-User", user);
if (pass)
{
md5_init(&md5);
@@ -710,9 +709,18 @@ void http_auth_headers(void *ctx, char *user, char *pass)
http_async_add_header(ctx, "X-Auth-Hash", tmp);
free(tmp);
}
+ if(session_id)
+ {
+ http_async_add_header(ctx, "X-Auth-User-Id", user);
+ http_async_add_header(ctx, "X-Auth-Session-Key", session_id);
+ }
+ else
+ {
+ http_async_add_header(ctx, "X-Auth-User", user);
+ }
}
}
-char *http_auth_get(char *uri, char *user, char *pass, int *ret, int *len)
+char *http_auth_get(char *uri, char *user, char *pass, char *session_id, int *ret, int *len)
{
void *ctx = http_async_req_start(NULL, uri, NULL, 0, 0);
@@ -870,7 +878,7 @@ char *http_ret_text(int ret)
return "Unknown Status Code";
}
}
-char *http_multipart_post(char *uri, char **names, char **parts, int *plens, char *user, char *pass, int *ret, int *len)
+char *http_multipart_post(char *uri, char **names, char **parts, int *plens, char *user, char *pass, char *session_id, int *ret, int *len)
{
void *ctx;
char *data = NULL, *tmp, *p;
@@ -965,7 +973,7 @@ retry:
if (user)
{
- http_async_add_header(ctx, "X-Auth-User", user);
+ //http_async_add_header(ctx, "X-Auth-User", user);
if (pass)
{
md5_init(&md5);
@@ -1023,6 +1031,15 @@ retry:
http_async_add_header(ctx, "X-Auth-Hash", tmp);
free(tmp);
}
+ if(session_id)
+ {
+ http_async_add_header(ctx, "X-Auth-User-Id", user);
+ http_async_add_header(ctx, "X-Auth-Session-Key", session_id);
+ }
+ else
+ {
+ http_async_add_header(ctx, "X-Auth-User", user);
+ }
}
if (data)
diff --git a/src/interface.c b/src/interface.c
index 6f3f0bc..0d963e0 100644
--- a/src/interface.c
+++ b/src/interface.c
@@ -25,7 +25,9 @@ int svf_login = 0;
int svf_admin = 0;
int svf_mod = 0;
char svf_user[64] = "";
+char svf_user_id[64] = "";
char svf_pass[64] = "";
+char svf_session_id[64] = "";
int svf_open = 0;
int svf_own = 0;
@@ -836,7 +838,7 @@ void login_ui(pixel *vid_buf)
res = http_multipart_post(
"http://" SERVER "/Login.api",
NULL, NULL, NULL,
- svf_user, svf_pass,
+ svf_user, svf_pass, NULL,
&err, NULL);
if (err != 200)
{
@@ -845,14 +847,27 @@ void login_ui(pixel *vid_buf)
free(res);
goto fail;
}
- if (res && !strncmp(res, "OK", 2))
+ if (res && !strncmp(res, "OK ", 3))
{
- if (!strcmp(res, "OK ADMIN"))
+ char *s_id,*u_e,*nres;
+ s_id = strchr(res+3, ' ');
+ *(s_id++) = 0;
+
+ u_e = strchr(s_id, ' ');
+ *(u_e++) = 0;
+
+ strcpy(svf_user_id, res+3);
+ strcpy(svf_session_id, s_id);
+ nres = mystrdup(u_e);
+
+ printf("\n{%s} {%s} {%s}\n", svf_user_id, svf_session_id, nres);
+
+ if (!strncmp(nres, "ADMIN", 5))
{
svf_admin = 1;
svf_mod = 0;
}
- else if (!strcmp(res, "OK MOD"))
+ else if (!strncmp(nres, "MOD", 3))
{
svf_admin = 0;
svf_mod = 1;
@@ -874,6 +889,8 @@ void login_ui(pixel *vid_buf)
fail:
strcpy(svf_user, "");
strcpy(svf_pass, "");
+ strcpy(svf_user_id, "");
+ strcpy(svf_session_id, "");
svf_login = 0;
svf_own = 0;
svf_admin = 0;
@@ -2489,7 +2506,8 @@ int search_ui(pixel *vid_buf)
http = http_async_req_start(http, uri, NULL, 0, 1);
if (svf_login)
{
- http_auth_headers(http, svf_user, svf_pass);
+ //http_auth_headers(http, svf_user, svf_pass);
+ http_auth_headers(http, svf_user_id, NULL, svf_session_id);
}
http_last_use = time(NULL);
free(uri);
@@ -2757,8 +2775,10 @@ int open_ui(pixel *vid_buf, char *save_id, char *save_date)
http_2 = http_async_req_start(http_2, uri_2, NULL, 0, 1);
if (svf_login)
{
- http_auth_headers(http, svf_user, svf_pass);
- http_auth_headers(http_2, svf_user, svf_pass);
+ //http_auth_headers(http, svf_user, svf_pass);
+ //http_auth_headers(http_2, svf_user, svf_pass);
+ http_auth_headers(http, svf_user_id, NULL, svf_session_id);
+ http_auth_headers(http_2, svf_user_id, NULL, svf_session_id);
}
http_last_use = time(NULL);
http_last_use_2 = time(NULL);
@@ -3483,7 +3503,7 @@ int execute_tagop(pixel *vid_buf, char *op, char *tag)
result = http_multipart_post(
uri,
names, parts, NULL,
- svf_user, svf_pass,
+ svf_user_id, /*svf_pass*/NULL, svf_session_id,
&status, NULL);
free(uri);
@@ -3543,7 +3563,7 @@ void execute_save(pixel *vid_buf)
result = http_multipart_post(
"http://" SERVER "/Save.api",
names, parts, plens,
- svf_user, svf_pass,
+ svf_user_id, /*svf_pass*/NULL, svf_session_id,
&status, NULL);
if (svf_last)
@@ -3600,7 +3620,7 @@ int execute_delete(pixel *vid_buf, char *id)
result = http_multipart_post(
"http://" SERVER "/Delete.api",
names, parts, NULL,
- svf_user, svf_pass,
+ svf_user_id, /*svf_pass*/NULL, svf_session_id,
&status, NULL);
if (status!=200)
@@ -3636,7 +3656,7 @@ void execute_submit(pixel *vid_buf, char *id, char *message)
result = http_multipart_post(
"http://" SERVER "/Comment.api",
names, parts, NULL,
- svf_user, svf_pass,
+ svf_user_id, /*svf_pass*/NULL, svf_session_id,
&status, NULL);
if (status!=200)
@@ -3671,7 +3691,7 @@ int execute_report(pixel *vid_buf, char *id, char *reason)
result = http_multipart_post(
"http://" SERVER "/Report.api",
names, parts, NULL,
- svf_user, svf_pass,
+ svf_user_id, /*svf_pass*/NULL, svf_session_id,
&status, NULL);
if (status!=200)
@@ -3706,7 +3726,7 @@ void execute_fav(pixel *vid_buf, char *id)
result = http_multipart_post(
"http://" SERVER "/Favourite.api",
names, parts, NULL,
- svf_user, svf_pass,
+ svf_user_id, /*svf_pass*/NULL, svf_session_id,
&status, NULL);
if (status!=200)
@@ -3741,7 +3761,7 @@ int execute_vote(pixel *vid_buf, char *id, char *action)
result = http_multipart_post(
"http://" SERVER "/Vote.api",
names, parts, NULL,
- svf_user, svf_pass,
+ svf_user_id, /*svf_pass*/NULL, svf_session_id,
&status, NULL);
if (status!=200)
@@ -3789,8 +3809,15 @@ void open_link(char *uri) {
printf("Cannot open browser\n");
#endif
}
+struct command_history {
+ void *prev_command;
+ char *command;
+};
+typedef struct command_history command_history;
+command_history *last_command = NULL;
char *console_ui(pixel *vid_buf,char error[255]) { //TODO: error messages, show previous commands
- int mx,my,b,bq;
+ int mx,my,b,bq,cc,ci = -1;
+ command_history *currentcommand;
ui_edit ed;
ed.x = 15;
ed.y = 210;
@@ -3820,6 +3847,30 @@ char *console_ui(pixel *vid_buf,char error[255]) { //TODO: error messages, show
"Reset works with pressure, velocity, sparks, temp (ex. 'reset pressure')\n"
"To load a save use load saveID (ex. load 1337)"
,255, 187, 187, 255);
+
+ cc = 0;
+ currentcommand = last_command;
+ while(cc < 10)
+ {
+ if(currentcommand==NULL)
+ break;
+ drawtext(vid_buf, 15, 175-(cc*12), currentcommand->command, 255, 255, 255, 255);
+ if(currentcommand->prev_command!=NULL)
+ {
+ if(cc<9) {
+ currentcommand = currentcommand->prev_command;
+ } else if(currentcommand->prev_command!=NULL){
+ free(currentcommand->prev_command);
+ currentcommand->prev_command = NULL;
+ }
+ cc++;
+ }
+ else
+ {
+ break;
+ }
+ }
+
if(error)
drawtext(vid_buf, 15, 190, error,255, 187, 187, 255);
ui_edit_draw(vid_buf, &ed);
@@ -3827,6 +3878,11 @@ char *console_ui(pixel *vid_buf,char error[255]) { //TODO: error messages, show
sdl_blit(0, 0, (XRES+BARSIZE), YRES+MENUSIZE, vid_buf, (XRES+BARSIZE));
if (sdl_key==SDLK_RETURN)
{
+ currentcommand = malloc(sizeof(command_history));
+ memset(currentcommand, 0, sizeof(command_history));
+ currentcommand->prev_command = last_command;
+ currentcommand->command = mystrdup(ed.str);
+ last_command = currentcommand;
return ed.str;
}
if (sdl_key==SDLK_ESCAPE || sdl_key==SDLK_BACKQUOTE)
@@ -3834,6 +3890,34 @@ char *console_ui(pixel *vid_buf,char error[255]) { //TODO: error messages, show
console_mode = 0;
return NULL;
}
+ if(sdl_key==SDLK_UP || sdl_key==SDLK_DOWN)
+ {
+ ci += sdl_key==SDLK_UP?1:-1;
+ if(ci<-1)
+ ci = -1;
+ if(ci==-1)
+ {
+ strcpy(ed.str, "");
+ }
+ else
+ {
+ if(last_command!=NULL){
+ currentcommand = last_command;
+ for (cc = 0; cc<ci; cc++) {
+ if(currentcommand->prev_command==NULL)
+ ci = cc;
+ else
+ currentcommand = currentcommand->prev_command;
+ }
+ strcpy(ed.str, currentcommand->command);
+ }
+ else
+ {
+ ci = -1;
+ strcpy(ed.str, "");
+ }
+ }
+ }
}
diff --git a/src/main.c b/src/main.c
index 6f7ee7b..e6f29b4 100644
--- a/src/main.c
+++ b/src/main.c
@@ -492,6 +492,10 @@ int parse_save(void *save, int size, int replace, int x0, int y0)
memset(vx, 0, sizeof(vx));
memset(vy, 0, sizeof(vy));
memset(pv, 0, sizeof(pv));
+ memset(photons, 0, sizeof(photons));
+ memset(wireless, 0, sizeof(wireless));
+ memset(gol2, 0, sizeof(gol2));
+ memset(portal, 0, sizeof(portal));
death = death2 = ISSPAWN1 = ISSPAWN2 = 0;
}
@@ -714,10 +718,10 @@ int parse_save(void *save, int size, int replace, int x0, int y0)
ttv |= (d[p++]);
parts[i-1].tmp = ttv;
if(ptypes[parts[i-1].type].properties&PROP_LIFE && !parts[i-1].tmp)
- for(q = 1; q<NGOL ; q++){
- if(parts[i-1].type==goltype[q-1] && grule[q][9]==2)
- parts[i-1].tmp = grule[q][9]-1;
- }
+ for(q = 1; q<NGOL ; q++) {
+ if(parts[i-1].type==goltype[q-1] && grule[q][9]==2)
+ parts[i-1].tmp = grule[q][9]-1;
+ }
} else {
p+=2;
}
@@ -1509,7 +1513,7 @@ int main(int argc, char *argv[])
parts[i].type = parts[i].ctype;
parts[i].life = 0;
}
- }
+ }
else
{
for (nx = 0; nx<XRES/CELL; nx++)
diff --git a/src/misc.c b/src/misc.c
index 64c2af5..d5b57c5 100644
--- a/src/misc.c
+++ b/src/misc.c
@@ -5,6 +5,7 @@
#include "defines.h"
#include "interface.h"
#include "graphics.h"
+#include "powder.h"
//Signum function
#if defined(WIN32) && !defined(__GNUC__)
@@ -95,7 +96,9 @@ void save_presets(int do_update)
return;
fwrite(sig, 1, 4, f);
save_string(f, svf_user);
- save_string(f, svf_pass);
+ //save_string(f, svf_pass);
+ save_string(f, svf_user_id);
+ save_string(f, svf_session_id);
fwrite(&tmp, 1, 1, f);
tmp = cmode;
fwrite(&tmp, 1, 1, f);
@@ -144,7 +147,11 @@ void load_presets(void)
}
if (load_string(f, svf_user, 63))
goto fail;
- if (load_string(f, svf_pass, 63))
+ //if (load_string(f, svf_pass, 63))
+ //goto fail;
+ if (load_string(f, svf_user_id, 63))
+ goto fail;
+ if (load_string(f, svf_session_id, 63))
goto fail;
svf_login = !!svf_user[0];
if (fread(&tmp, 1, 1, f) != 1)
@@ -152,7 +159,7 @@ void load_presets(void)
sdl_scale = (tmp == 2) ? 2 : 1;
if (fread(&tmp, 1, 1, f) != 1)
goto fail;
- cmode = tmp%7;
+ cmode = tmp%CM_COUNT;
if (fread(&tmp, 1, 1, f) != 1)
goto fail;
svf_admin = tmp;
diff --git a/src/powder.c b/src/powder.c
index 873913c..b2932d1 100644
--- a/src/powder.c
+++ b/src/powder.c
@@ -664,9 +664,9 @@ inline int create_part(int p, int x, int y, int t)
parts[i].life = 50;
parts[i].tmp = 50;
}
- if(ptypes[t].properties&PROP_LIFE) {
+ if (ptypes[t].properties&PROP_LIFE) {
int r;
- for(r = 0;r<NGOL;r++)
+ for(r = 0; r<NGOL; r++)
if(t==goltype[r])
parts[i].tmp = grule[r+1][9] - 1;
}
@@ -1317,7 +1317,7 @@ void update_particles_i(pixel *vid, int start, int inc)
} else {
parts[r>>8].tmp --;
if(parts[r>>8].tmp<=0)
- parts[r>>8].type = PT_NONE;//using kill_part makes it not work
+ parts[r>>8].type = PT_NONE;//using kill_part makes it not work
}
}
}