зеркало из https://github.com/mozilla/pjs.git
of newsgroups over a fast connection. compute the download rate for the UI. sr=bienvenu,syd. thanks to bratell@lysator.liu.se for the patch (for #61007).
This commit is contained in:
Родитель
68a9329b84
Коммит
f5ffdbec1e
|
@ -38,7 +38,7 @@ enterPassword=Please enter a password for news server access
|
||||||
enterPasswordTitle=News Server Password Required
|
enterPasswordTitle=News Server Password Required
|
||||||
okButtonText=Download
|
okButtonText=Download
|
||||||
|
|
||||||
bytesReceived=%S K read (at %SK/sec)
|
bytesReceived=%SK read (at %SK/sec)
|
||||||
checkingForNewNews=Checking newsgroup %S of %S for new messages
|
checkingForNewNews=Checking newsgroup %S of %S for new messages
|
||||||
|
|
||||||
# LOCALIZATION NOTE (Error -304): In the following item, don't translate "NNTP"
|
# LOCALIZATION NOTE (Error -304): In the following item, don't translate "NNTP"
|
||||||
|
|
|
@ -93,8 +93,11 @@
|
||||||
#define PREF_NEWS_CANCEL_CONFIRM "news.cancel.confirm"
|
#define PREF_NEWS_CANCEL_CONFIRM "news.cancel.confirm"
|
||||||
#define PREF_NEWS_CANCEL_ALERT_ON_SUCCESS "news.cancel.alert_on_success"
|
#define PREF_NEWS_CANCEL_ALERT_ON_SUCCESS "news.cancel.alert_on_success"
|
||||||
#define DEFAULT_NEWS_CHUNK_SIZE -1
|
#define DEFAULT_NEWS_CHUNK_SIZE -1
|
||||||
#define READ_NEWS_LIST_COUNT_MAX 20 /* number of groups to process at a time when reading the list from the server */
|
#define READ_NEWS_LIST_COUNT_MAX 500 /* number of groups to process at a time when reading the list from the server */
|
||||||
#define READ_NEWS_LIST_TIMEOUT 50 /* uSec to wait until doing more */
|
#define READ_NEWS_LIST_TIMEOUT 50 /* uSec to wait until doing more */
|
||||||
|
#define RATE_STR_BUF_LEN 32
|
||||||
|
#define UPDATE_THRESHHOLD 25600 /* only update every 25 KB */
|
||||||
|
|
||||||
|
|
||||||
#define NEWS_MSGS_URL "chrome://messenger/locale/news.properties"
|
#define NEWS_MSGS_URL "chrome://messenger/locale/news.properties"
|
||||||
// ***jt -- the following were pirated from xpcom/io/nsByteBufferInputStream
|
// ***jt -- the following were pirated from xpcom/io/nsByteBufferInputStream
|
||||||
|
@ -326,7 +329,7 @@ char *XP_AppCodeName = "Mozilla";
|
||||||
#else
|
#else
|
||||||
const char *XP_AppCodeName = "Mozilla";
|
const char *XP_AppCodeName = "Mozilla";
|
||||||
#endif
|
#endif
|
||||||
#define NET_IS_SPACE(x) ((((unsigned int) (x)) > 0x7f) ? 0 : isspace(x))
|
#define NET_IS_SPACE(x) ((x)==' ' || (x)=='\t')
|
||||||
|
|
||||||
char * NET_SACopy (char **destination, const char *source)
|
char * NET_SACopy (char **destination, const char *source)
|
||||||
{
|
{
|
||||||
|
@ -459,6 +462,7 @@ nsNNTPProtocol::nsNNTPProtocol(nsIURI * aURL, nsIMsgWindow *aMsgWindow)
|
||||||
|
|
||||||
mBytesReceived = 0;
|
mBytesReceived = 0;
|
||||||
mBytesReceivedSinceLastStatusUpdate = 0;
|
mBytesReceivedSinceLastStatusUpdate = 0;
|
||||||
|
m_startTime = PR_Now();
|
||||||
|
|
||||||
if (aMsgWindow) {
|
if (aMsgWindow) {
|
||||||
m_msgWindow = aMsgWindow;
|
m_msgWindow = aMsgWindow;
|
||||||
|
@ -2742,6 +2746,7 @@ PRInt32 nsNNTPProtocol::BeginNewsgroups()
|
||||||
#else
|
#else
|
||||||
mBytesReceived = 0;
|
mBytesReceived = 0;
|
||||||
mBytesReceivedSinceLastStatusUpdate = 0;
|
mBytesReceivedSinceLastStatusUpdate = 0;
|
||||||
|
m_startTime = PR_Now();
|
||||||
#endif
|
#endif
|
||||||
return(status);
|
return(status);
|
||||||
}
|
}
|
||||||
|
@ -2879,6 +2884,7 @@ PRInt32 nsNNTPProtocol::BeginReadNewsList()
|
||||||
|
|
||||||
mBytesReceived = 0;
|
mBytesReceived = 0;
|
||||||
mBytesReceivedSinceLastStatusUpdate = 0;
|
mBytesReceivedSinceLastStatusUpdate = 0;
|
||||||
|
m_startTime = PR_Now();
|
||||||
|
|
||||||
PRInt32 status = 0;
|
PRInt32 status = 0;
|
||||||
#ifdef UNREADY_CODE
|
#ifdef UNREADY_CODE
|
||||||
|
@ -2888,10 +2894,33 @@ PRInt32 nsNNTPProtocol::BeginReadNewsList()
|
||||||
return(status);
|
return(status);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define RATE_CONSTANT 976.5625 /* PR_USEC_PER_SEC / 1024 bytes */
|
||||||
|
|
||||||
|
static void ComputeRate(PRInt32 bytes, PRTime startTime, float *rate)
|
||||||
|
{
|
||||||
|
// rate = (bytes / USECS since start) * RATE_CONSTANT
|
||||||
|
|
||||||
|
// compute usecs since we started.
|
||||||
|
PRTime timeSinceStart;
|
||||||
|
PRTime now = PR_Now();
|
||||||
|
LL_SUB(timeSinceStart, now, startTime);
|
||||||
|
|
||||||
|
// convert PRTime to PRInt32
|
||||||
|
PRInt32 delta;
|
||||||
|
LL_L2I(delta, timeSinceStart);
|
||||||
|
|
||||||
|
// compute rate
|
||||||
|
if (delta > 0) {
|
||||||
|
*rate = (bytes * RATE_CONSTANT) / delta;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
*rate = 0.0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* display a list of all or part of the newsgroups list
|
/* display a list of all or part of the newsgroups list
|
||||||
* from the news server
|
* from the news server
|
||||||
*/
|
*/
|
||||||
|
|
||||||
PRInt32 nsNNTPProtocol::ReadNewsList(nsIInputStream * inputStream, PRUint32 length)
|
PRInt32 nsNNTPProtocol::ReadNewsList(nsIInputStream * inputStream, PRUint32 length)
|
||||||
{
|
{
|
||||||
nsresult rv;
|
nsresult rv;
|
||||||
|
@ -2939,10 +2968,10 @@ PRInt32 nsNNTPProtocol::ReadNewsList(nsIInputStream * inputStream, PRUint32 leng
|
||||||
#else
|
#else
|
||||||
mBytesReceived += status;
|
mBytesReceived += status;
|
||||||
mBytesReceivedSinceLastStatusUpdate += status;
|
mBytesReceivedSinceLastStatusUpdate += status;
|
||||||
|
|
||||||
// only update every 10 KB
|
if ((mBytesReceivedSinceLastStatusUpdate > UPDATE_THRESHHOLD) && m_msgWindow) {
|
||||||
if ((mBytesReceivedSinceLastStatusUpdate > (1024 * 25)) && m_msgWindow) {
|
|
||||||
mBytesReceivedSinceLastStatusUpdate = 0;
|
mBytesReceivedSinceLastStatusUpdate = 0;
|
||||||
|
|
||||||
nsCOMPtr <nsIMsgStatusFeedback> msgStatusFeedback;
|
nsCOMPtr <nsIMsgStatusFeedback> msgStatusFeedback;
|
||||||
|
|
||||||
rv = m_msgWindow->GetStatusFeedback(getter_AddRefs(msgStatusFeedback));
|
rv = m_msgWindow->GetStatusFeedback(getter_AddRefs(msgStatusFeedback));
|
||||||
|
@ -2959,14 +2988,20 @@ PRInt32 nsNNTPProtocol::ReadNewsList(nsIInputStream * inputStream, PRUint32 leng
|
||||||
getter_AddRefs(bundle));
|
getter_AddRefs(bundle));
|
||||||
NS_ENSURE_SUCCESS(rv, rv);
|
NS_ENSURE_SUCCESS(rv, rv);
|
||||||
|
|
||||||
nsString kBytesStr;
|
nsString bytesStr;
|
||||||
kBytesStr.AppendInt(mBytesReceived / 1024);
|
bytesStr.AppendInt(mBytesReceived / 1024);
|
||||||
|
|
||||||
nsString kRateStr;
|
// compute the rate, and then convert it have one
|
||||||
// todo, fix this
|
// decimal precision.
|
||||||
//kRateStr.AppendFloat(0.0);
|
float rate = 0.0;
|
||||||
kRateStr.AppendWithConversion("?.?");
|
ComputeRate(mBytesReceived, m_startTime, &rate);
|
||||||
const PRUnichar *formatStrings[2] = { kBytesStr.GetUnicode(), kRateStr.GetUnicode() };
|
char rate_buf[RATE_STR_BUF_LEN];
|
||||||
|
PR_snprintf(rate_buf,RATE_STR_BUF_LEN,"%.1f", rate);
|
||||||
|
|
||||||
|
nsString rateStr;
|
||||||
|
rateStr.AppendWithConversion(rate_buf);
|
||||||
|
|
||||||
|
const PRUnichar *formatStrings[2] = { bytesStr.GetUnicode(), rateStr.GetUnicode() };
|
||||||
NS_NAMED_LITERAL_STRING(literalPropertyTag, "bytesReceived");
|
NS_NAMED_LITERAL_STRING(literalPropertyTag, "bytesReceived");
|
||||||
const PRUnichar *propertyTag = literalPropertyTag.get();
|
const PRUnichar *propertyTag = literalPropertyTag.get();
|
||||||
rv = bundle->FormatStringFromName(propertyTag,
|
rv = bundle->FormatStringFromName(propertyTag,
|
||||||
|
|
|
@ -405,6 +405,7 @@ private:
|
||||||
nsresult AlertError(PRInt32 errorCode, const char *text);
|
nsresult AlertError(PRInt32 errorCode, const char *text);
|
||||||
PRInt32 mBytesReceived;
|
PRInt32 mBytesReceived;
|
||||||
PRInt32 mBytesReceivedSinceLastStatusUpdate;
|
PRInt32 mBytesReceivedSinceLastStatusUpdate;
|
||||||
|
PRTime m_startTime;
|
||||||
};
|
};
|
||||||
|
|
||||||
NS_BEGIN_EXTERN_C
|
NS_BEGIN_EXTERN_C
|
||||||
|
|
Загрузка…
Ссылка в новой задаче