Function: shell-process-pushd
shell-process-pushd is a byte-compiled function defined in
shell.el.gz.
Signature
(shell-process-pushd ARG)
Source Code
;; Defined in /usr/src/emacs/lisp/shell.el.gz
;; pushd [+n | dir]
(defun shell-process-pushd (arg)
(let ((num (shell-extract-num arg)))
(cond ((zerop (length arg))
;; no arg -- swap pwd and car of stack unless shell-pushd-tohome
(cond (shell-pushd-tohome
(shell-process-pushd (concat comint-file-name-prefix "~")))
(shell-dirstack
(let ((old default-directory))
(shell-cd (car shell-dirstack))
(setq shell-dirstack (cons old (cdr shell-dirstack)))
(shell-dirstack-message)))
(t
(message "Directory stack empty."))))
((numberp num)
;; pushd +n
(cond ((> num (length shell-dirstack))
(message "Directory stack not that deep."))
((= num 0)
(error "Couldn't cd"))
(shell-pushd-dextract
(let ((dir (nth (1- num) shell-dirstack)))
(shell-process-popd arg)
(shell-process-pushd default-directory)
(shell-cd dir)
(shell-dirstack-message)))
(t
(let* ((ds (cons default-directory shell-dirstack))
(dslen (length ds))
(front (nthcdr num ds))
(back (reverse (nthcdr (- dslen num) (reverse ds))))
(new-ds (append front back)))
(shell-cd (car new-ds))
(setq shell-dirstack (cdr new-ds))
(shell-dirstack-message)))))
(t
;; pushd <dir>
(let ((old-wd default-directory))
(shell-cd (shell-prefixed-directory-name arg))
(if (or (null shell-pushd-dunique)
(not (member old-wd shell-dirstack)))
(setq shell-dirstack (cons old-wd shell-dirstack)))
(shell-dirstack-message))))))