|
|
@ -1308,8 +1308,10 @@ public class SMTPTransport extends Transport {
|
|
|
|
total.value++;
|
|
|
|
total.value++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
IProgress progress = (IProgress) session.getProperties()
|
|
|
|
TraceOutputStream.IReport reporter =
|
|
|
|
.get("mail." + name + ".progress");
|
|
|
|
(TraceOutputStream.IReport) session.getProperties()
|
|
|
|
|
|
|
|
.get("mail." + name + ".reporter");
|
|
|
|
|
|
|
|
traceOutput.setReporter(total.value, reporter);
|
|
|
|
if (chunkSize > 0 && supportsExtension("CHUNKING")) {
|
|
|
|
if (chunkSize > 0 && supportsExtension("CHUNKING")) {
|
|
|
|
/*
|
|
|
|
/*
|
|
|
|
* Use BDAT to send the data in chunks.
|
|
|
|
* Use BDAT to send the data in chunks.
|
|
|
@ -1320,34 +1322,12 @@ public class SMTPTransport extends Transport {
|
|
|
|
* from the message content, and b) the message content is
|
|
|
|
* from the message content, and b) the message content is
|
|
|
|
* encoded before we even know that we can use BDAT.
|
|
|
|
* encoded before we even know that we can use BDAT.
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
this.message.writeTo(new FilterOutputStream(bdat()) {
|
|
|
|
this.message.writeTo(bdat(), ignoreList);
|
|
|
|
private int size = 0;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
|
|
|
public void write(int b) throws IOException {
|
|
|
|
|
|
|
|
super.write(b);
|
|
|
|
|
|
|
|
size++;
|
|
|
|
|
|
|
|
if (progress != null && (size % 1024) == 0)
|
|
|
|
|
|
|
|
progress.report(size, total.value);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}, ignoreList);
|
|
|
|
|
|
|
|
finishBdat();
|
|
|
|
finishBdat();
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
this.message.writeTo(new FilterOutputStream(data()) {
|
|
|
|
this.message.writeTo(data(), ignoreList);
|
|
|
|
private int size = 0;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
|
|
|
public void write(int b) throws IOException {
|
|
|
|
|
|
|
|
super.write(b);
|
|
|
|
|
|
|
|
size++;
|
|
|
|
|
|
|
|
if (progress != null && (size % 1024) == 0)
|
|
|
|
|
|
|
|
progress.report(size, total.value);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}, ignoreList);
|
|
|
|
|
|
|
|
finishData();
|
|
|
|
finishData();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (progress != null)
|
|
|
|
|
|
|
|
progress.finished();
|
|
|
|
|
|
|
|
if (sendPartiallyFailed) {
|
|
|
|
if (sendPartiallyFailed) {
|
|
|
|
// throw the exception,
|
|
|
|
// throw the exception,
|
|
|
|
// fire TransportEvent.MESSAGE_PARTIALLY_DELIVERED event
|
|
|
|
// fire TransportEvent.MESSAGE_PARTIALLY_DELIVERED event
|
|
|
@ -1409,12 +1389,6 @@ public class SMTPTransport extends Transport {
|
|
|
|
sendMessageEnd();
|
|
|
|
sendMessageEnd();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public interface IProgress {
|
|
|
|
|
|
|
|
void report(int size, int total);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void finished();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* The send failed, fix the address arrays to report the failure correctly.
|
|
|
|
* The send failed, fix the address arrays to report the failure correctly.
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|