- FetchResult fetchResult = freenetInterface.fetchUri(requestUri);
- logger.log(Level.FINEST, "Got %d bytes back.", fetchResult.size());
- Sone parsedSone = parseSone(sone, fetchResult, requestUri);
- if (parsedSone != null) {
- core.addSone(parsedSone);
+ core.setSoneStatus(sone, SoneStatus.downloading);
+ try {
+ FetchResult fetchResult = freenetInterface.fetchUri(requestUri);
+ if (fetchResult == null) {
+ /* TODO - mark Sone as bad. */
+ return;
+ }
+ logger.log(Level.FINEST, "Got %d bytes back.", fetchResult.size());
+ Sone parsedSone = parseSone(sone, fetchResult, requestUri);
+ if (parsedSone != null) {
+ core.addSone(parsedSone);
+ }
+ } finally {
+ core.setSoneStatus(sone, (sone.getTime() == 0) ? SoneStatus.unknown : SoneStatus.idle);