summaryrefslogtreecommitdiff
path: root/js
diff options
context:
space:
mode:
authorAndrew Dolgov <[email protected]>2017-01-22 19:38:07 +0300
committerAndrew Dolgov <[email protected]>2017-01-22 19:38:07 +0300
commitd5f74019ac49e4812b11dfc8e5be18668b634e95 (patch)
treededee795793d691f5bd7474ba1a423dcb272d40b /js
parenta4e04c498f3178dd9b869c3080b13f35beac5b6e (diff)
parse_counters: cache previous reply and skip processing of unchanged rows (better implementation)
Diffstat (limited to 'js')
-rw-r--r--js/feedlist.js40
1 files changed, 33 insertions, 7 deletions
diff --git a/js/feedlist.js b/js/feedlist.js
index 232cf0be1..3a0b7cb12 100644
--- a/js/feedlist.js
+++ b/js/feedlist.js
@@ -254,15 +254,41 @@ function request_counters(force) {
}
}
+// NOTE: this implementation is incomplete
+// for general objects but good enough for counters
+// http://adripofjavascript.com/blog/drips/object-equality-in-javascript.html
+function counter_is_equal(a, b) {
+ // Create arrays of property names
+ var aProps = Object.getOwnPropertyNames(a);
+ var bProps = Object.getOwnPropertyNames(b);
+
+ // If number of properties is different,
+ // objects are not equivalent
+ if (aProps.length != bProps.length) {
+ return false;
+ }
+
+ for (var i = 0; i < aProps.length; i++) {
+ var propName = aProps[i];
+
+ // If values of same property are not equal,
+ // objects are not equivalent
+ if (a[propName] !== b[propName]) {
+ return false;
+ }
+ }
+
+ // If we made it this far, objects
+ // are considered equivalent
+ return true;
+}
+
+
function parse_counters(elems) {
try {
for (var l = 0; l < elems.length; l++) {
- if (_counters_prev[l] &&
- _counters_prev[l].id == elems[l].id &&
- _counters_prev[l].updated == elems[l].updated &&
- _counters_prev[l].counter == elems[l].counter) {
-
+ if (_counters_prev[l] && counter_is_equal(elems[l], _counters_prev[l])) {
continue;
}
@@ -285,9 +311,9 @@ function parse_counters(elems) {
continue;
}
- if (getFeedUnread(id, (kind == "cat")) != ctr ||
+ /*if (getFeedUnread(id, (kind == "cat")) != ctr ||
(kind == "cat")) {
- }
+ }*/
setFeedUnread(id, (kind == "cat"), ctr);
setFeedValue(id, (kind == "cat"), 'auxcounter', auxctr);