summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorCracker64 <cracker642@gmail.com>2011-01-30 23:15:53 (GMT)
committer Cracker64 <cracker642@gmail.com>2011-01-30 23:15:53 (GMT)
commit6aaa9e78cd8ce2e11b6696f979a17d92e1c7fc40 (patch)
tree047a0b91f8b99ec4f15a7bfdd28d0874fb9c0416 /src
parent8ed2947b4cbfbe21b9ba30961c469823f2e285ee (diff)
downloadpowder-6aaa9e78cd8ce2e11b6696f979a17d92e1c7fc40.zip
powder-6aaa9e78cd8ce2e11b6696f979a17d92e1c7fc40.tar.gz
possible fix from jacksonmj, cursor gets set to end while changing commands with up/down
Diffstat (limited to 'src')
-rw-r--r--src/interface.c3
-rw-r--r--src/main.c5
2 files changed, 6 insertions, 2 deletions
diff --git a/src/interface.c b/src/interface.c
index 0d963e0..8ec97fb 100644
--- a/src/interface.c
+++ b/src/interface.c
@@ -3883,7 +3883,7 @@ char *console_ui(pixel *vid_buf,char error[255]) { //TODO: error messages, show
currentcommand->prev_command = last_command;
currentcommand->command = mystrdup(ed.str);
last_command = currentcommand;
- return ed.str;
+ return currentcommand->command;
}
if (sdl_key==SDLK_ESCAPE || sdl_key==SDLK_BACKQUOTE)
{
@@ -3910,6 +3910,7 @@ char *console_ui(pixel *vid_buf,char error[255]) { //TODO: error messages, show
currentcommand = currentcommand->prev_command;
}
strcpy(ed.str, currentcommand->command);
+ ed.cursor = strlen(ed.str);
}
else
{
diff --git a/src/main.c b/src/main.c
index e6f29b4..ac439ba 100644
--- a/src/main.c
+++ b/src/main.c
@@ -1121,7 +1121,7 @@ int main(int argc, char *argv[])
pixel *pers_bg=calloc((XRES+BARSIZE)*YRES, PIXELSIZE);
void *http_ver_check;
char *ver_data=NULL, *tmp;
- char error[255];
+ char error[255] = "";
int i, j, bq, fire_fc=0, do_check=0, old_version=0, http_ret=0, major, minor, old_ver_len;
#ifdef INTERNAL
int vs = 0;
@@ -1707,6 +1707,7 @@ int main(int argc, char *argv[])
//char error[255] = "error!";
sys_pause = 1;
console = console_ui(vid_buf,error);
+ console = mystrdup(console);
strcpy(error,"");
if(console && strcmp(console, "")!=0 && strncmp(console, " ", 1)!=0)
{
@@ -1716,6 +1717,7 @@ int main(int argc, char *argv[])
console5 = strtok(NULL, " ");
if(strcmp(console2, "quit")==0)
{
+ free(console);
break;
}
else if(strcmp(console2, "load")==0 && console3)
@@ -1955,6 +1957,7 @@ int main(int argc, char *argv[])
else
sprintf(error, "Invalid Command", console2);
}
+ free(console);
if(!console_mode)
hud_enable = 1;
}