forked from Archives/Athou_commafeed
small refactoring
This commit is contained in:
@@ -57,41 +57,46 @@ public class FeedRefreshTaskGiver {
|
|||||||
|
|
||||||
public synchronized Feed take() {
|
public synchronized Feed take() {
|
||||||
Feed feed = takeQueue.poll();
|
Feed feed = takeQueue.poll();
|
||||||
|
|
||||||
if (feed == null) {
|
if (feed == null) {
|
||||||
Date now = Calendar.getInstance().getTime();
|
refill();
|
||||||
|
|
||||||
int count = 3 * backgroundThreads;
|
|
||||||
List<Feed> feeds = feedDAO.findNextUpdatable(count);
|
|
||||||
|
|
||||||
int size = addQueue.size();
|
|
||||||
for (int i = 0; i < size; i++) {
|
|
||||||
feeds.add(addQueue.poll());
|
|
||||||
}
|
|
||||||
|
|
||||||
Map<Long, Feed> map = Maps.newHashMap();
|
|
||||||
for (Feed f : feeds) {
|
|
||||||
f.setLastUpdated(now);
|
|
||||||
map.put(f.getId(), f);
|
|
||||||
}
|
|
||||||
takeQueue.addAll(map.values());
|
|
||||||
|
|
||||||
size = giveBackQueue.size();
|
|
||||||
for (int i = 0; i < size; i++) {
|
|
||||||
Feed f = giveBackQueue.poll();
|
|
||||||
f.setLastUpdated(now);
|
|
||||||
map.put(f.getId(), f);
|
|
||||||
}
|
|
||||||
|
|
||||||
feedDAO.update(map.values());
|
|
||||||
|
|
||||||
feed = takeQueue.poll();
|
feed = takeQueue.poll();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (feed != null) {
|
if (feed != null) {
|
||||||
metricsBean.feedRefreshed();
|
metricsBean.feedRefreshed();
|
||||||
}
|
}
|
||||||
return feed;
|
return feed;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void refill() {
|
||||||
|
Date now = Calendar.getInstance().getTime();
|
||||||
|
|
||||||
|
int count = 2 * backgroundThreads;
|
||||||
|
List<Feed> feeds = feedDAO.findNextUpdatable(count);
|
||||||
|
|
||||||
|
int size = addQueue.size();
|
||||||
|
for (int i = 0; i < size; i++) {
|
||||||
|
feeds.add(addQueue.poll());
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<Long, Feed> map = Maps.newHashMap();
|
||||||
|
for (Feed f : feeds) {
|
||||||
|
f.setLastUpdated(now);
|
||||||
|
map.put(f.getId(), f);
|
||||||
|
}
|
||||||
|
takeQueue.addAll(map.values());
|
||||||
|
|
||||||
|
size = giveBackQueue.size();
|
||||||
|
for (int i = 0; i < size; i++) {
|
||||||
|
Feed f = giveBackQueue.poll();
|
||||||
|
f.setLastUpdated(now);
|
||||||
|
map.put(f.getId(), f);
|
||||||
|
}
|
||||||
|
|
||||||
|
feedDAO.update(map.values());
|
||||||
|
}
|
||||||
|
|
||||||
public void giveBack(Feed feed) {
|
public void giveBack(Feed feed) {
|
||||||
giveBackQueue.add(feed);
|
giveBackQueue.add(feed);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user