X-Git-Url: https://git.distorted.org.uk/u/mdw/putty/blobdiff_plain/e9d14678a9f84b52aee758c6ab81dd10f25ef825..edd0cb8aef57080ae884e06731a7892ca8cdba44:/unix/uxsftp.c diff --git a/unix/uxsftp.c b/unix/uxsftp.c index 7045c322..0779ff18 100644 --- a/unix/uxsftp.c +++ b/unix/uxsftp.c @@ -13,6 +13,9 @@ #include #include #include +#ifndef HAVE_NO_SYS_SELECT_H +#include +#endif #include "putty.h" #include "psftp.h" @@ -65,6 +68,17 @@ Filename platform_default_filename(const char *name) return ret; } +char *get_ttymode(void *frontend, const char *mode) { return NULL; } + +int get_userpass_input(prompts_t *p, unsigned char *in, int inlen) +{ + int ret; + ret = cmdline_get_passwd_input(p, in, inlen); + if (ret == -1) + ret = console_get_userpass_input(p, in, inlen); + return ret; +} + /* * Stubs for the GUI feedback mechanism in Windows PSCP. */ @@ -433,8 +447,27 @@ static int ssh_sftp_do_select(int include_stdin, int no_fds_ok) ret = select(maxfd, &rset, &wset, &xset, ptv); if (ret == 0) now = next; - else - now = GETTICKCOUNT(); + else { + long newnow = GETTICKCOUNT(); + /* + * Check to see whether the system clock has + * changed massively during the select. + */ + if (newnow - now < 0 || newnow - now > next - now) { + /* + * If so, look at the elapsed time in the + * select and use it to compute a new + * tickcount_offset. + */ + long othernow = now + tv.tv_sec * 1000 + tv.tv_usec / 1000; + /* So we'd like GETTICKCOUNT to have returned othernow, + * but instead it return newnow. Hence ... */ + tickcount_offset += othernow - newnow; + now = othernow; + } else { + now = newnow; + } + } } while (ret < 0 && errno != EINTR); } while (ret == 0);