;;; Find and load the correct package.el ;; When switching between Emacs 23 and 24, we always use the bundled package.el in Emacs 24 (let ((package-el-site-lisp-dir (expand-file-name "site-lisp/package" user-emacs-directory))) (when (and (file-directory-p package-el-site-lisp-dir) (> emacs-major-version 23)) (message "Removing local package.el from load-path to avoid shadowing bundled version") (setq load-path (remove package-el-site-lisp-dir load-path)))) (require 'package) ;;; Standard package repositories ;(add-to-list 'package-archives '("marmalade" . "http://marmalade-repo.org/packages/")) ;; We include the org repository for completeness, but don't normally ;; use it. (add-to-list 'package-archives '("org" . "http://orgmode.org/elpa/")) (when (< emacs-major-version 24) (add-to-list 'package-archives '("gnu" . "http://elpa.gnu.org/packages/"))) ;;; Also use Melpa for most packages (add-to-list 'package-archives '("melpa" . "http://melpa.milkbox.net/packages/")) (add-to-list 'package-archives '("melpa-stable" . "http://melpa-stable.milkbox.net/packages/")) ;; If gpg cannot be found, signature checking will fail, so we ;; conditionally enable it according to whether gpg is available. We ;; re-run this check once $PATH has been configured (defun sanityinc/package-maybe-enable-signatures () (setq package-check-signature (when (executable-find "gpg") 'allow-unsigned))) (sanityinc/package-maybe-enable-signatures) ;;(after-load 'init-exec-path ;; (sanityinc/package-maybe-enable-signatures)) ;;; On-demand installation of packages (defun require-package (package &optional min-version no-refresh) "Install given PACKAGE, optionally requiring MIN-VERSION. If NO-REFRESH is non-nil, the available package lists will not be re-downloaded in order to locate PACKAGE." (if (package-installed-p package min-version) t (if (or (assoc package package-archive-contents) no-refresh) (package-install package) (progn (package-refresh-contents) (require-package package min-version t))))) ;;; Fire up package.el (setq package-enable-at-startup nil) (package-initialize) (require-package 'fullframe) (fullframe list-packages quit-window) (require-package 'cl-lib) (require 'cl-lib) (defun sanityinc/set-tabulated-list-column-width (col-name width) "Set any column with name COL-NAME to the given WIDTH." (cl-loop for column across tabulated-list-format when (string= col-name (car column)) do (setf (elt column 1) width))) (defun sanityinc/maybe-widen-package-menu-columns () "Widen some columns of the package menu table to avoid truncation." (when (boundp 'tabulated-list-format) (sanityinc/set-tabulated-list-column-width "Version" 13) (let ((longest-archive-name (apply 'max (mapcar 'length (mapcar 'car package-archives))))) (sanityinc/set-tabulated-list-column-width "Archive" longest-archive-name)))) (add-hook 'package-menu-mode-hook 'sanityinc/maybe-widen-package-menu-columns) (provide 'init-elpa)