;;; ein-log.el --- Logging module for ein.el ;; Copyright (C) 2012- Takafumi Arakaki ;; Author: Takafumi Arakaki ;; This file is NOT part of GNU Emacs. ;; ein-log.el is free software: you can redistribute it and/or modify ;; it under the terms of the GNU General Public License as published by ;; the Free Software Foundation, either version 3 of the License, or ;; (at your option) any later version. ;; ein-log.el is distributed in the hope that it will be useful, ;; but WITHOUT ANY WARRANTY; without even the implied warranty of ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ;; GNU General Public License for more details. ;; You should have received a copy of the GNU General Public License ;; along with ein-log.el. If not, see . ;;; Commentary: ;; ;;; Code: (eval-when-compile (require 'cl)) (defvar ein:log-buffer) (make-variable-buffer-local 'ein:log-buffer) (put 'ein:log-buffer 'permanent-local t) (defvar ein:log-buffer-name-template " *ein:log %s*") (defvar ein:log-orphan-buffer-name " *ein:log-orphan*") (defvar ein:log-level-def '((debug . 40) (verbose . 30) (info . 20) (warn . 10) (error . 0))) (defvar ein:log-level 30) (defvar ein:log-message-level 20) (defvar ein:log-max-string 1000) (defun ein:log-setup (name) (setq ein:log-buffer (get-buffer-create (format ein:log-buffer-name-template name)))) (defun ein:log-set-level (level) (setq ein:log-level (ein:log-level-name-to-int level))) (defun ein:log-set-message-level (level) (setq ein:log-message-level (ein:log-level-name-to-int level))) (defun ein:log-level-int-to-name (int) (loop for (n . i) in ein:log-level-def when (>= int i) return n finally 'error)) (defun ein:log-level-name-to-int (name) (cdr (assq name ein:log-level-def))) (defun ein:log-wrapper (level func) (setq level (ein:log-level-name-to-int level)) (when (<= level ein:log-level) (let* ((levname (ein:log-level-int-to-name level)) (msg (format "[%s] %s" levname (funcall func)))) (let ((orphan-p (null ein:log-buffer)) (orig-buffer (current-buffer))) (with-current-buffer (or ein:log-buffer (get-buffer-create ein:log-orphan-buffer-name)) (save-excursion (goto-char (point-max)) (insert (if (and ein:log-max-string (> (length msg) ein:log-max-string)) (substring msg 0 ein:log-max-string) msg)) (when orphan-p (insert (format " @%S" orig-buffer))) (insert "\n")))) (when (<= level ein:log-message-level) (message "ein: %s" msg))))) (defmacro ein:log (level string &rest args) (declare (indent 1)) `(ein:log-wrapper ,level (lambda () (format ,string ,@args)))) (defun ein:log-pop-to-buffer () (interactive) (if ein:log-buffer (pop-to-buffer ein:log-buffer) (message "ein: log buffer for current buffer is not set."))) (defun ein:log-pop-to-orphan-buffer () (interactive) (pop-to-buffer (get-buffer-create ein:log-orphan-buffer-name))) (provide 'ein-log) ;;; ein-log.el ends here