vine-default の仕組み
vine-default は、以下のようにして Vine Linux のデフォルト設定が読み込まれます。
- それぞれの elisp アプリケーションの初期設定ファイル /etc/emacs-23.3/site-start.d/*-init.el を然るべき順序で読み込む
- vine-default-setup-hook に、 各 elisp アプリケーションの vine-default-package を然るべき順序でひっかけておく
- ~/.emacs.d/emacs23-vine-default.el(図 2-2) を参照して、それぞれの vine-default-package の挙動がきまる
- vine-default-setup を実行することで、 vine-default-setup-hook にひっかけていた vine-default-package が ~/.emacs.d/emacs23-vine-default.el(図 2-2) に応じて、読み込まれる。
- /usr/share/emacs-23.3/site-lisp/site-start.el
- /etc/emacs-23.3/site-start.d/XXpackage-init.el (X ∈ {0, 1, 2,..., 9})
- /etc/emacs/emacs23-local.el
- vine-default 用設定ファイル ${HOME}/.emacs.d/emacs23-vine-default.el
-
vine-default-setup を実行:
/usr/share/emacs-23.3/site-lisp/ 以下の
- vine-default-base.el, vine-default-faces.el
- package/vine-default-package.el
- デフォルトのユーザ初期設定ファイル ${HOME}/.emacs.d/init.el
Vine Linux 5 から Vine Linux 6 への変更
Vine Linux 6 の vine-default の仕組みは、 Vine Linux 5 の vine-default からいくつか改良しました。 主な変更点は、以下のようになります。
- vine-default を呼ぶタイミングを改善するときに、 vine-default 設定ファイル ~/.emacs.d/emacs23-vine-default.el(図 2-2) を設けました。 これにより、ユーザ自身の Emacs に関する設定から vine-default に関する設定のみを分離できます。
- vine-default を呼ぶタイミングを改善したことにより、 after-vine-default-setup-hook を廃止しました。 これにより、vine-default に関する設定が、 ユーザ初期設定ファイル ~/.emacs.d/init.el(図 2-3) に混在しません。
- システム全体での設定(セクション 2.2 - system-wide な設定)を担う設定ファイル名が /etc/emacs/emacs-23-local.el から /etc/emacs/emacs23-local.el へ変更
3.4.1. vine-default に関する関数とフック
具体的には、 /usr/share/emacs-23.3/site-lisp/site-start.el に、以下のような関数とフックを定義しています。
(defcustom vine-default t
"A boolean for all Vine Linux default settings"
:type 'boolean)
(if (equal (getenv "LOGNAME") "root")
(setq vine-default nil))
(defcustom vine-default-base t
"A boolean for vine-default-base"
:type 'boolean)
(defcustom vine-default-faces t
"A boolean for vine-default-faces"
:type 'boolean)
(defvar vine-default-setup-hook nil
"List of functions to be called at vine-default-setup")
(defun vine-default-setup ()
"A function for setup to default configurations of Vine Linux"
(when vine-default
(message "Starting vine-default-setup ...")
(when vine-default-base
(message "Loading vine-default-base ...")
(require 'vine-default-base))
(when vine-default-faces
(message "Loading vine-default-faces ...")
(require 'vine-default-faces))
(run-hooks 'vine-default-setup-hook)
;; (run-hooks 'after-vine-default-setup-hook); obsolete
)
)
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;; run functions from the /etc/emacs-23.3/site-start.d directory
;;; Files in this directory ending with ".el" are run on startup
(mapc 'load (directory-files "/etc/emacs-23.3/site-start.d" t "\\.el\\'"))
;;; load local configuration
(if (file-exists-p (expand-file-name "/etc/emacs/emacs23-local.el"))
(load (expand-file-name "/etc/emacs/emacs23-local.el")))
;;; load vine-default configuration per user before vine-default-setup
(if (file-exists-p (expand-file-name "~/.emacs.d/emacs23-vine-default.el"))
(load (expand-file-name "~/.emacs.d/emacs23-vine-default.el")))
;;; run vine-default-setup
(vine-default-setup)
3.4.2. 各 elisp アプリケーションの vine-default-package
例えば、ibus-el の場合は /etc/emacs-23.3/site-start.d/95ibus-el-init.el に以下のような設定をしています。
(defcustom vine-default-ibus-el t
"A boolean for vine-default-ibus-el"
:type 'boolean)
(add-hook 'vine-default-setup-hook
(lambda()
(when vine-default-ibus-el
(message "Loading vine-default-ibus-el ...")
(require 'vine-default-ibus-el))))



