diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/HTAlert.c | 4 | ||||
-rw-r--r-- | src/LYCurses.h | 7 | ||||
-rw-r--r-- | src/LYDownload.c | 11 | ||||
-rw-r--r-- | src/LYHistory.c | 14 | ||||
-rw-r--r-- | src/LYMain.c | 4 | ||||
-rw-r--r-- | src/LYMainLoop.c | 13 | ||||
-rw-r--r-- | src/LYUtils.c | 33 |
7 files changed, 59 insertions, 27 deletions
diff --git a/src/HTAlert.c b/src/HTAlert.c index 017354a4..42aa340f 100644 --- a/src/HTAlert.c +++ b/src/HTAlert.c @@ -122,7 +122,7 @@ PUBLIC void HTReadProgress ARGS2( if (LYshow_kb_rate && (total >= kb_units || bytes >= kb_units)) { units = "KB"; - divisor = 1024; + divisor = kb_units; bytes /= divisor; if (total > 0) total /= divisor; } @@ -132,7 +132,7 @@ PUBLIC void HTReadProgress ARGS2( else sprintf (line, "Read %ld %s of data", bytes, units); if ((transfer_rate > 0) - && (!LYshow_kb_rate || (bytes * divisor > kb_units))) + && (!LYshow_kb_rate || (bytes * divisor >= kb_units))) sprintf (line + strlen(line), ", %ld %s/sec.", transfer_rate / divisor, units); else sprintf (line + strlen(line), "."); diff --git a/src/LYCurses.h b/src/LYCurses.h index ace10813..48bea1e5 100644 --- a/src/LYCurses.h +++ b/src/LYCurses.h @@ -392,9 +392,12 @@ extern void lynx_stop_radio_color NOPARAMS; extern void lynx_stop_all_colors NOPARAMS; /* - * To prevent corrupting binary data with _WINDOWS and DJGPP we open files and - * stdout in BINARY mode by default. Where necessary we should open and + * To prevent corrupting binary data on DOS, MS-WINDOWS or OS/2 we open files + * and stdout in BINARY mode by default. Where necessary we should open and * (close!) TEXT mode. + * + * Note: EMX has no corresponding variable like _fmode on DOS, but it does + * have setmode. */ #if defined(_WINDOWS) || defined(DJGPP) || defined(__EMX__) #define SetOutputMode(mode) setmode(fileno(stdout), mode) diff --git a/src/LYDownload.c b/src/LYDownload.c index e55d0dbc..acf6d882 100644 --- a/src/LYDownload.c +++ b/src/LYDownload.c @@ -614,15 +614,20 @@ PUBLIC int LYdownload_options ARGS2( BeginInternalPage(fp0, DOWNLOAD_OPTIONS_TITLE, DOWNLOAD_OPTIONS_HELP); fprintf(fp0, "<pre>\n"); + + fprintf(fp0, "\ + <em>Downloaded link:</em> %s\n", + downloaded_url); + + if (!no_disk_save && !child_lynx) fprintf(fp0, "\ - <em>Downloaded link:</em> %s\n\ <em>Suggested file name:</em> %s%s\n", - downloaded_url, (lynx_save_space ? lynx_save_space : ""), sug_filename); + (lynx_save_space ? lynx_save_space : ""), sug_filename); fprintf(fp0, "\n%s options:\n", (user_mode == NOVICE_MODE) ? "Standard download" : "Download"); - if(!no_disk_save && !child_lynx) { + if (!no_disk_save && !child_lynx) { #ifdef DIRED_SUPPORT /* * Disable save to disk option for local files. diff --git a/src/LYHistory.c b/src/LYHistory.c index fe077e48..20126cc9 100644 --- a/src/LYHistory.c +++ b/src/LYHistory.c @@ -121,8 +121,8 @@ PUBLIC BOOLEAN LYwouldPush ARGS1( char *, title) { return (!strcmp(title, HISTORY_PAGE_TITLE) - || !strcmp(title, PRINT_OPTIONS_TITLE) - || !strcmp(title, DOWNLOAD_OPTIONS_TITLE) + || !strcmp(title, PRINT_OPTIONS_TITLE) + || !strcmp(title, DOWNLOAD_OPTIONS_TITLE) #ifdef DIRED_SUPPORT || !strcmp(title, DIRED_MENU_TITLE) || !strcmp(title, UPLOAD_OPTIONS_TITLE) @@ -322,6 +322,11 @@ PUBLIC void LYpop ARGS1( doc->isHEAD = history[nhist].isHEAD; doc->safe = history[nhist].safe; doc->internal_link = history[nhist].internal_link; +#ifdef DISP_PARTIAL + /* assume we pop the 'doc' to show it soon... */ + Newline_partial = doc->line; /* reinitialize */ + NumOfLines_partial = -1; /* initialize to -1 */ +#endif /* DISP_PARTIAL */ CTRACE(tfp, "LYpop[%d]: address:%s\n title:%s\n", nhist, doc->address, doc->title); } @@ -347,6 +352,11 @@ PUBLIC void LYpop_num ARGS2( doc->isHEAD = history[number].isHEAD; doc->safe = history[number].safe; doc->internal_link = history[number].internal_link; /* ?? */ +#ifdef DISP_PARTIAL + /* assume we pop the 'doc' to show it soon... */ + Newline_partial = doc->line; /* reinitialize */ + NumOfLines_partial = -1; /* initialize to -1 */ +#endif /* DISP_PARTIAL */ } } diff --git a/src/LYMain.c b/src/LYMain.c index 49d6d3e5..e749f638 100644 --- a/src/LYMain.c +++ b/src/LYMain.c @@ -564,13 +564,13 @@ PUBLIC int main ARGS2( #endif /* - * To prevent corrupting binary data with _WINDOWS and DJGPP + * To prevent corrupting binary data on DOS, MS-WINDOWS or OS/2 * we open files and stdout in BINARY mode by default. * Where necessary we should open and (close!) TEXT mode. * (use LYNewTxtFile/LYAppendToTxtFile to open text files for writing) */ SetDefaultMode(O_BINARY); - SetOutputMode( O_BINARY ); + SetOutputMode(O_BINARY); #ifdef DOSPATH if (getenv("TERM")==NULL) putenv("TERM=vt100"); diff --git a/src/LYMainLoop.c b/src/LYMainLoop.c index 51c0fd88..5d062f73 100644 --- a/src/LYMainLoop.c +++ b/src/LYMainLoop.c @@ -505,14 +505,16 @@ try_again: /* and set the flag to 0 */ if (display_partial) { /* - * Disable display_partial if requested URL has #fragment. + * Disable display_partial if requested URL has #fragment + * and we are not popped from the history stack + * so can't calculate correct newline position for fragment. * Otherwise user got the new document from the first page * and be moved to #fragment later after download - * completed, but only if user did not mess screen up by + * completed, but only if s/he did not mess screen up by * scrolling before... So fall down to old behavior here. */ if (!LYCursesON || - (strchr(newdoc.address, '#'))) + (Newline_partial == 1 && strchr(newdoc.address, '#'))) display_partial = FALSE; } #endif /* DISP_PARTIAL */ @@ -985,7 +987,8 @@ try_again: * Override newdoc.line with a new value if user * scrolled the document while downloading. */ - if (Newline_partial != newdoc.line) + if (Newline_partial != newdoc.line + && NumOfLines_partial > 0) Newline = Newline_partial; /* @@ -4928,7 +4931,6 @@ check_add_bookmark_to_self: newdoc.isHEAD = history[number].isHEAD; newdoc.safe = history[number].safe; newdoc.internal_link = FALSE; - newdoc.line = curdoc.line; /* need for display_partial ! */ newdoc.link = 0; HTOutputFormat = HTAtom_for("www/download"); LYUserSpecifiedURL = TRUE; @@ -5007,7 +5009,6 @@ check_add_bookmark_to_self: newdoc.safe = FALSE; } newdoc.internal_link = FALSE; - newdoc.line = curdoc.line; /* need for display_partial ! */ newdoc.link = 0; HTOutputFormat = HTAtom_for("www/download"); /* diff --git a/src/LYUtils.c b/src/LYUtils.c index ac66b7f7..7808d659 100644 --- a/src/LYUtils.c +++ b/src/LYUtils.c @@ -2822,18 +2822,23 @@ PUBLIC BOOLEAN inlocaldomain NOARGS #include <sys/ioctl.h> #endif -/* For systems that have both, but both can't be included, duh */ -#ifdef TERMIO_AND_TERMIOS +/* For systems that have both, but both can't be included, duh (or neither) */ +/* FIXME: this whole chunk may be redundant */ +#ifdef TERMIO_AND_CURSES # include <termio.h> -#else -# ifdef HAVE_TERMIOS_H -# include <termios.h> # else -# ifdef HAVE_TERMIO_H -# include <termio.h> -# endif /* HAVE_TERMIO_H */ -# endif /* HAVE_TERMIOS_H */ -#endif /* TERMIO_AND_TERMIOS */ +# ifdef TERMIO_AND_TERMIOS +# include <termio.h> +# else +# ifdef HAVE_TERMIOS_H +# include <termios.h> +# else +# ifdef HAVE_TERMIO_H +# include <termio.h> +# endif /* HAVE_TERMIO_H */ +# endif /* HAVE_TERMIOS_H */ +# endif /* TERMIO_AND_TERMIOS */ +#endif /* USE_TERMIO_H */ PUBLIC void size_change ARGS1( int, sig GCC_UNUSED) @@ -3010,6 +3015,14 @@ PUBLIC void change_sug_filename ARGS1( } FREE(temp); + if (fname[strlen(fname) - 1] == '/') + /* + * Hmm... we have a directory name. + * It is annoying to see a scheme+host+path name as a suggested one, + * let's remove the last_slash and go ahead like we have a file name. - LP + */ + fname[strlen(fname) - 1] = '\0'; + /* * Remove everything up the the last_slash if there is one. */ |