|
23 | 23 |
|
24 | 24 | (eask-load "core/package") ; load dist path |
25 | 25 |
|
26 | | -(defun eask-install-packages (names) |
| 26 | +(defun eask-install--not-installed (names) |
| 27 | + "Return a list of not installed packages' NAMES." |
| 28 | + (cl-remove-if-not |
| 29 | + (lambda (name) |
| 30 | + (or (eask-force-p) |
| 31 | + (not (package-installed-p (eask-intern name))))) |
| 32 | + names)) |
| 33 | + |
| 34 | +(defun eask-install--packages (names) |
27 | 35 | "Install packages with their NAMES." |
28 | 36 | (let* ((names (mapcar #'eask-intern names)) |
29 | | - (len (length names)) (s (eask--sinr len "" "s")) |
30 | | - (pkg-not-installed (cl-remove-if #'package-installed-p names)) |
31 | | - (installed (length pkg-not-installed)) (skipped (- len installed))) |
| 37 | + (len (length names)) |
| 38 | + (s (eask--sinr len "" "s")) |
| 39 | + (not-installed (eask-install--not-installed names)) |
| 40 | + (installed (length not-installed)) |
| 41 | + (skipped (- len installed))) |
32 | 42 | (eask-log "Installing %s specified package%s..." len s) |
33 | 43 | (eask-msg "") |
34 | 44 | (eask--package-mapc #'eask-package-install names) |
@@ -80,7 +90,7 @@ For argument FILE, please see function `package-install-file' for the details." |
80 | 90 | (eask-pkg-init) |
81 | 91 | (if-let* ((names (eask-args))) |
82 | 92 | ;; If package [name..] are specified, we try to install it |
83 | | - (eask-install-packages names) |
| 93 | + (eask-install--packages names) |
84 | 94 | ;; Else we try to install package from the working directory |
85 | 95 | (eask-install-dependencies) |
86 | 96 | (let* ((name (eask-guess-package-name)) |
|
0 commit comments