1 ;;; riece-shrink-buffer.el --- free old IRC messages to save memory usage
2 ;; Copyright (C) 1998-2005 Daiki Ueno
4 ;; Author: Daiki Ueno <ueno@unixuser.org>
6 ;; Keywords: IRC, riece
8 ;; This file is part of Riece.
10 ;; This program is free software; you can redistribute it and/or modify
11 ;; it under the terms of the GNU General Public License as published by
12 ;; the Free Software Foundation; either version 2, or (at your option)
15 ;; This program is distributed in the hope that it will be useful,
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 ;; GNU General Public License for more details.
20 ;; You should have received a copy of the GNU General Public License
21 ;; along with GNU Emacs; see the file COPYING. If not, write to the
22 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
23 ;; Boston, MA 02110-1301, USA.
27 ;; NOTE: This is an add-on module for Riece.
31 (require 'riece-globals)
34 (defgroup riece-shrink-buffer nil
35 "Free old IRC messages to save memory usage."
39 (defcustom riece-shrink-buffer-idle-time-delay 5
40 "Number of idle seconds to wait before shrinking channel buffers."
42 :group 'riece-shrink-buffer)
44 (defcustom riece-max-buffer-size 65536
45 "Maximum size of channel buffers."
46 :type '(integer :tag "Number of characters")
47 :group 'riece-shrink-buffer)
49 (defcustom riece-shrink-buffer-remove-chars (/ riece-max-buffer-size 2)
50 "Number of chars removed when shrinking channel buffers."
52 :group 'riece-shrink-buffer)
54 (defvar riece-shrink-buffer-idle-timer nil
55 "Timer object to periodically shrink channel buffers.")
57 (defconst riece-shrink-buffer-description
58 "Free old IRC messages to save memory usage.")
60 (defun riece-shrink-buffer-idle-timer ()
61 (let ((buffers riece-buffer-list))
63 (if (and (get 'riece-shrink-buffer 'riece-addon-enabled)
64 (buffer-live-p (car buffers))
65 (with-current-buffer (car buffers)
66 (riece-derived-mode-p 'riece-dialogue-mode)))
67 (riece-shrink-buffer (car buffers)))
68 (setq buffers (cdr buffers)))))
70 (defun riece-shrink-buffer (buffer)
71 (with-current-buffer buffer
72 (goto-char (point-min))
73 (while (> (buffer-size) riece-max-buffer-size)
74 (let* ((inhibit-read-only t)
77 (goto-char riece-shrink-buffer-remove-chars)
80 (overlays (riece-overlays-in (point-min) end)))
82 (riece-delete-overlay (car overlays))
83 (setq overlays (cdr overlays)))
84 (delete-region (point-min) end)))))
86 (defun riece-shrink-buffer-startup-hook ()
87 (setq riece-shrink-buffer-idle-timer
88 (riece-run-with-idle-timer
89 riece-shrink-buffer-idle-time-delay t
90 'riece-shrink-buffer-idle-timer)))
92 (defun riece-shrink-buffer-exit-hook ()
93 (if riece-shrink-buffer-idle-timer
94 (riece-cancel-timer riece-shrink-buffer-idle-timer)))
96 (defun riece-shrink-buffer-insinuate ()
97 (add-hook 'riece-startup-hook
98 'riece-shrink-buffer-startup-hook)
99 ;; Reset the timer since riece-shrink-buffer-insinuate will be
100 ;; called before running riece-startup-hook.
101 (unless riece-shrink-buffer-idle-timer
102 (riece-shrink-buffer-startup-hook))
103 (add-hook 'riece-exit-hook
104 'riece-shrink-buffer-exit-hook))
106 (defun riece-shrink-buffer-uninstall ()
107 (riece-shrink-buffer-exit-hook)
108 (remove-hook 'riece-startup-hook
109 'riece-shrink-buffer-startup-hook)
110 (remove-hook 'riece-exit-hook
111 'riece-shrink-buffer-exit-hook))
113 (provide 'riece-shrink-buffer)
115 ;;; riece-shrink-buffer.el ends here