Merge pull request #339 from glowing-bear/trimlines

Trim long buffers
This commit is contained in:
David Cormier 2014-06-26 22:41:36 -04:00
commit 118b401d76
1 changed files with 9 additions and 4 deletions

View File

@ -698,6 +698,11 @@ weechat.controller('WeechatCtrl', ['$rootScope', '$scope', '$store', '$timeout',
$rootScope.$on('activeBufferChanged', function(event, unreadSum) { $rootScope.$on('activeBufferChanged', function(event, unreadSum) {
var ab = models.getActiveBuffer(); var ab = models.getActiveBuffer();
// trim lines to 2 screenfuls + 10 lines
ab.lines.splice(0, ab.lines.length - (2 * $scope.lines_per_screen + 10));
ab.requestedLines = ab.lines.length;
$scope.bufferlines = ab.lines; $scope.bufferlines = ab.lines;
$scope.nicklist = ab.nicklist; $scope.nicklist = ab.nicklist;
@ -713,10 +718,10 @@ weechat.controller('WeechatCtrl', ['$rootScope', '$scope', '$store', '$timeout',
$scope.showNicklist = $scope.updateShowNicklist(); $scope.showNicklist = $scope.updateShowNicklist();
} }
if (ab.requestedLines < $scope.lines) { if (ab.requestedLines < $scope.lines_per_screen) {
// buffer has not been loaded, but some lines may already be present if they arrived after we connected // buffer has not been loaded, but some lines may already be present if they arrived after we connected
// try to determine how many lines to fetch // try to determine how many lines to fetch
var numLines = $scope.lines; // that's a screenful plus 10 lines var numLines = $scope.lines_per_screen; // that's a screenful plus 10 lines
unreadSum += 10; // let's just add a 10 line safety margin here again unreadSum += 10; // let's just add a 10 line safety margin here again
if (unreadSum > numLines) { if (unreadSum > numLines) {
// request up to 4*(screenful + 10 lines) // request up to 4*(screenful + 10 lines)
@ -918,7 +923,7 @@ weechat.controller('WeechatCtrl', ['$rootScope', '$scope', '$store', '$timeout',
// Fetch 10 lines more than theoretically needed so that scrolling up will correctly trigger the loading of more lines // Fetch 10 lines more than theoretically needed so that scrolling up will correctly trigger the loading of more lines
// Also, some lines might be hidden, so it's probably better to have a bit of buffer there // Also, some lines might be hidden, so it's probably better to have a bit of buffer there
var numLines = Math.ceil(areaHeight/lineHeight + 10); var numLines = Math.ceil(areaHeight/lineHeight + 10);
$scope.lines = numLines; $scope.lines_per_screen = numLines;
}; };
$scope.calculateNumLines(); $scope.calculateNumLines();
@ -952,7 +957,7 @@ weechat.controller('WeechatCtrl', ['$rootScope', '$scope', '$store', '$timeout',
$rootScope.loadingLines = false; $rootScope.loadingLines = false;
$scope.fetchMoreLines = function(numLines) { $scope.fetchMoreLines = function(numLines) {
if (!numLines) { if (!numLines) {
numLines = $scope.lines; numLines = $scope.lines_per_screen;
} }
return connection.fetchMoreLines(numLines); return connection.fetchMoreLines(numLines);
}; };