fixed #138 - fixed auto-install's behaviour
This commit is contained in:
parent
9fcc478b97
commit
5b38ad5d8c
3 changed files with 46 additions and 81 deletions
1
init.el
1
init.el
|
@ -61,7 +61,6 @@ ELPA (or MELPA).")
|
||||||
(require 'prelude-mode)
|
(require 'prelude-mode)
|
||||||
(require 'prelude-editor)
|
(require 'prelude-editor)
|
||||||
(require 'prelude-global-keybindings)
|
(require 'prelude-global-keybindings)
|
||||||
(require 'prelude-auto-install)
|
|
||||||
|
|
||||||
;; OSX specific settings
|
;; OSX specific settings
|
||||||
(when (eq system-type 'darwin)
|
(when (eq system-type 'darwin)
|
||||||
|
|
|
@ -1,71 +0,0 @@
|
||||||
;;; prelude-auto-install.el --- Emacs Prelude: auto-install required packages
|
|
||||||
;;
|
|
||||||
;; Copyright (c) 2011-2012 Bozhidar Batsov
|
|
||||||
;;
|
|
||||||
;; Author: Bozhidar Batsov <bozhidar@batsov.com>
|
|
||||||
;; URL: http://batsov.com/emacs-prelude
|
|
||||||
;; Version: 1.0.0
|
|
||||||
;; Keywords: convenience
|
|
||||||
|
|
||||||
;; This file is not part of GNU Emacs.
|
|
||||||
|
|
||||||
;;; Commentary:
|
|
||||||
|
|
||||||
;; A simple mechanism to automatically install missing packages.
|
|
||||||
|
|
||||||
;;; License:
|
|
||||||
|
|
||||||
;; This program 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.
|
|
||||||
;;
|
|
||||||
;; This program 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 GNU Emacs; see the file COPYING. If not, write to the
|
|
||||||
;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
||||||
;; Boston, MA 02110-1301, USA.
|
|
||||||
|
|
||||||
;;; Code:
|
|
||||||
|
|
||||||
|
|
||||||
(defmacro prelude-auto-install (ext mode)
|
|
||||||
`(unless (fboundp ',mode)
|
|
||||||
(add-to-list 'auto-mode-alist
|
|
||||||
`(,ext . (lambda ()
|
|
||||||
(package-install ',mode)
|
|
||||||
(,mode))))))
|
|
||||||
|
|
||||||
(defvar prelude-auto-install-alist
|
|
||||||
'(("\\.markdown\\'" . markdown-mode)
|
|
||||||
("\\.md\\'" . markdown-mode)
|
|
||||||
("\\.haml\\'" . haml-mode)
|
|
||||||
("\\.scss\\'" . scss-mode)
|
|
||||||
("\\.sass\\'" . sass-mode)
|
|
||||||
("\\.groovy\\'" . groovy-mode)
|
|
||||||
("\\.yml\\'" . yaml-mode)
|
|
||||||
("\\.php\\'" . php-mode)
|
|
||||||
("\\.hs\\'" . haskell-mode)
|
|
||||||
("\\.less\\'" . less-css-mode)
|
|
||||||
("\\.lua\\'" . lua-mode)
|
|
||||||
("\\.coffee\\'" . coffee-mode)
|
|
||||||
("\\.erl\\'" . erlang-mode)
|
|
||||||
("\\.feature\\'" . feature-mode)))
|
|
||||||
|
|
||||||
;; markdown-mode doesn't have autoloads for the auto-mode-alist
|
|
||||||
;; so we add them manually if it's already installed
|
|
||||||
(when (package-installed-p 'markdown-mode)
|
|
||||||
(add-to-list 'auto-mode-alist '("\\.markdown\\'" . markdown-mode))
|
|
||||||
(add-to-list 'auto-mode-alist '("\\.md\\'" . markdown-mode)))
|
|
||||||
|
|
||||||
(dolist (entry prelude-auto-install-alist)
|
|
||||||
(let ((ext (car entry))
|
|
||||||
(mode (cdr entry)))
|
|
||||||
(prelude-auto-install ext mode)))
|
|
||||||
|
|
||||||
(provide 'prelude-auto-install)
|
|
||||||
;;; prelude-auto-install.el ends here
|
|
|
@ -50,15 +50,52 @@
|
||||||
when (not (package-installed-p p)) do (return nil)
|
when (not (package-installed-p p)) do (return nil)
|
||||||
finally (return t)))
|
finally (return t)))
|
||||||
|
|
||||||
(unless (prelude-packages-installed-p)
|
(defun prelude-install-packages ()
|
||||||
;; check for new packages (package versions)
|
(unless (prelude-packages-installed-p)
|
||||||
(message "%s" "Emacs Prelude is now refreshing its package database...")
|
;; check for new packages (package versions)
|
||||||
(package-refresh-contents)
|
(message "%s" "Emacs Prelude is now refreshing its package database...")
|
||||||
(message "%s" " done.")
|
(package-refresh-contents)
|
||||||
;; install the missing packages
|
(message "%s" " done.")
|
||||||
(dolist (p prelude-packages)
|
;; install the missing packages
|
||||||
(when (not (package-installed-p p))
|
(dolist (p prelude-packages)
|
||||||
(package-install p))))
|
(unless (package-installed-p p)
|
||||||
|
(package-install p)))))
|
||||||
|
|
||||||
|
(prelude-install-packages)
|
||||||
|
|
||||||
|
(defmacro prelude-auto-install (ext mode)
|
||||||
|
`(add-to-list 'auto-mode-alist
|
||||||
|
`(,ext . (lambda ()
|
||||||
|
(package-install ',mode)
|
||||||
|
(,mode)))))
|
||||||
|
|
||||||
|
(defvar prelude-auto-install-alist
|
||||||
|
'(("\\.markdown\\'" . markdown-mode)
|
||||||
|
("\\.md\\'" . markdown-mode)
|
||||||
|
("\\.haml\\'" . haml-mode)
|
||||||
|
("\\.scss\\'" . scss-mode)
|
||||||
|
("\\.sass\\'" . sass-mode)
|
||||||
|
("\\.groovy\\'" . groovy-mode)
|
||||||
|
("\\.yml\\'" . yaml-mode)
|
||||||
|
("\\.php\\'" . php-mode)
|
||||||
|
("\\.hs\\'" . haskell-mode)
|
||||||
|
("\\.less\\'" . less-css-mode)
|
||||||
|
("\\.lua\\'" . lua-mode)
|
||||||
|
("\\.coffee\\'" . coffee-mode)
|
||||||
|
("\\.erl\\'" . erlang-mode)
|
||||||
|
("\\.feature\\'" . feature-mode)))
|
||||||
|
|
||||||
|
;; markdown-mode doesn't have autoloads for the auto-mode-alist
|
||||||
|
;; so we add them manually if it's already installed
|
||||||
|
(when (package-installed-p 'markdown-mode)
|
||||||
|
(add-to-list 'auto-mode-alist '("\\.markdown\\'" . markdown-mode))
|
||||||
|
(add-to-list 'auto-mode-alist '("\\.md\\'" . markdown-mode)))
|
||||||
|
|
||||||
|
(dolist (entry prelude-auto-install-alist)
|
||||||
|
(let ((ext (car entry))
|
||||||
|
(mode (cdr entry)))
|
||||||
|
(unless (package-installed-p mode)
|
||||||
|
(prelude-auto-install ext mode))))
|
||||||
|
|
||||||
(provide 'prelude-packages)
|
(provide 'prelude-packages)
|
||||||
;;; prelude-packages.el ends here
|
;;; prelude-packages.el ends here
|
||||||
|
|
Loading…
Reference in a new issue