Smarter (and prettier) wg integration (now like tabs in vim)
This commit is contained in:
parent
0570abc2dd
commit
cb20d9f285
3 changed files with 69 additions and 30 deletions
|
@ -7,7 +7,7 @@
|
||||||
(setq-default
|
(setq-default
|
||||||
wg-session-file (expand-file-name "wg-default" narf-temp-dir)
|
wg-session-file (expand-file-name "wg-default" narf-temp-dir)
|
||||||
wg-workgroup-directory (expand-file-name "workgroups" narf-temp-dir)
|
wg-workgroup-directory (expand-file-name "workgroups" narf-temp-dir)
|
||||||
wg-first-wg-name "main"
|
wg-first-wg-name "*untitled*"
|
||||||
wg-session-load-on-start t
|
wg-session-load-on-start t
|
||||||
wg-mode-line-display-on nil
|
wg-mode-line-display-on nil
|
||||||
wg-mess-with-buffer-list t
|
wg-mess-with-buffer-list t
|
||||||
|
@ -15,9 +15,11 @@
|
||||||
wg-workgroups-mode-exit-save-behavior 'save
|
wg-workgroups-mode-exit-save-behavior 'save
|
||||||
wg-log-level 0
|
wg-log-level 0
|
||||||
|
|
||||||
wg-list-display-decor-divider " : "
|
wg-list-display-decor-divider " "
|
||||||
wg-list-display-decor-current-left "["
|
wg-list-display-decor-left-brace ""
|
||||||
wg-list-display-decor-current-right "]"
|
wg-list-display-decor-right-brace ""
|
||||||
|
wg-list-display-decor-current-left ""
|
||||||
|
wg-list-display-decor-current-right ""
|
||||||
wg-list-display-decor-previous-left ""
|
wg-list-display-decor-previous-left ""
|
||||||
wg-list-display-decor-previous-right "")
|
wg-list-display-decor-previous-right "")
|
||||||
:config
|
:config
|
||||||
|
@ -30,6 +32,8 @@
|
||||||
(action . narf/wg-helm-switch-to-workgroup)))
|
(action . narf/wg-helm-switch-to-workgroup)))
|
||||||
|
|
||||||
(defvar narf-wg-frames '())
|
(defvar narf-wg-frames '())
|
||||||
|
(defvar narf-wg-names '())
|
||||||
|
(add-to-list 'savehist-additional-variables 'narf-wg-names)
|
||||||
|
|
||||||
(after! projectile
|
(after! projectile
|
||||||
;; Create a new workgroup on switch-project
|
;; Create a new workgroup on switch-project
|
||||||
|
|
|
@ -28,34 +28,40 @@
|
||||||
(interactive "<!><a>")
|
(interactive "<!><a>")
|
||||||
(wg-open-session (if session-name
|
(wg-open-session (if session-name
|
||||||
(concat wg-workgroup-directory session-name)
|
(concat wg-workgroup-directory session-name)
|
||||||
wg-session-file)))
|
wg-session-file))
|
||||||
|
(narf/workgroup-display t))
|
||||||
|
|
||||||
;;;###autoload (autoload 'narf:workgroup-new "defuns-workgroup" nil t)
|
;;;###autoload (autoload 'narf:workgroup-new "defuns-workgroup" nil t)
|
||||||
(evil-define-command narf:workgroup-new (bang name)
|
(evil-define-command narf:workgroup-new (bang name &optional silent)
|
||||||
"Create a new workgroup. If BANG, clone the current one to it."
|
"Create a new workgroup. If BANG, clone the current one to it."
|
||||||
(interactive "<!><a>")
|
(interactive "<!><a>")
|
||||||
(unless name
|
(unless name
|
||||||
(user-error "No name specified for new workgroup"))
|
(setq name (format "#%s" (length (wg-workgroup-list)))))
|
||||||
(if bang
|
(if bang
|
||||||
(wg-clone-workgroup (wg-current-workgroup) name)
|
(wg-clone-workgroup (wg-current-workgroup) name)
|
||||||
(wg-create-workgroup name t)))
|
(wg-create-workgroup name t))
|
||||||
|
(unless silent
|
||||||
|
(narf/workgroup-display (wg-previous-workgroup))))
|
||||||
|
|
||||||
;;;###autoload (autoload 'narf:workgroup-rename "defuns-workgroup" nil t)
|
;;;###autoload (autoload 'narf:workgroup-rename "defuns-workgroup" nil t)
|
||||||
(evil-define-command narf:workgroup-rename (new-name)
|
(evil-define-command narf:workgroup-rename (new-name)
|
||||||
(interactive "<a>")
|
(interactive "<a>")
|
||||||
(wg-rename-workgroup new-name))
|
(let ((wg (wg-current-workgroup)))
|
||||||
|
(wg-rename-workgroup new-name wg)
|
||||||
|
(add-to-list 'narf-wg-names wg)))
|
||||||
|
|
||||||
;;;###autoload (autoload 'narf:workgroup-delete "defuns-workgroup" nil t)
|
;;;###autoload (autoload 'narf:workgroup-delete "defuns-workgroup" nil t)
|
||||||
(evil-define-command narf:workgroup-delete (bang &optional name)
|
(evil-define-command narf:workgroup-delete (&optional bang name)
|
||||||
(interactive "<!><a>")
|
(interactive "<!><a>")
|
||||||
(let ((wg-name name))
|
(let* ((current-wg (wg-current-workgroup))
|
||||||
(when (or bang (eq name ""))
|
(wg-name (or name (wg-workgroup-name current-wg))))
|
||||||
|
(when bang
|
||||||
(setq wg-name (wg-read-workgroup-name)))
|
(setq wg-name (wg-read-workgroup-name)))
|
||||||
(let ((wg (wg-get-workgroup name)))
|
(let ((wg (wg-get-workgroup name)))
|
||||||
(if (eq wg (wg-current-workgroup))
|
(if (eq wg current-wg)
|
||||||
(wg-kill-workgroup)
|
(wg-kill-workgroup)
|
||||||
(wg-delete-workgroup wg))
|
(wg-delete-workgroup wg))
|
||||||
(message "Deleted workgroup: %s" name))))
|
(message "%s [Deleted %s]" (narf/workgroup-display nil t) wg-name))))
|
||||||
|
|
||||||
;;;###autoload
|
;;;###autoload
|
||||||
(defun narf:kill-other-workgroups ()
|
(defun narf:kill-other-workgroups ()
|
||||||
|
@ -67,19 +73,33 @@
|
||||||
(wg-kill-workgroup w)))))
|
(wg-kill-workgroup w)))))
|
||||||
|
|
||||||
;;;###autoload
|
;;;###autoload
|
||||||
(defun narf:workgroup-display ()
|
(defun narf/workgroup-display (&optional suppress-update return-p)
|
||||||
(interactive)
|
(interactive)
|
||||||
(when (wg-current-session t)
|
(when (wg-current-session t)
|
||||||
(message "%s"
|
(unless (eq suppress-update t)
|
||||||
(wg-display-internal
|
(narf/workgroup-update-names (if (wg-workgroup-p suppress-update) suppress-update)))
|
||||||
(lambda (workgroup index)
|
(let ((output (wg-display-internal
|
||||||
(if (not workgroup) wg-nowg-string
|
(lambda (workgroup index)
|
||||||
(wg-element-display
|
(if (not workgroup) wg-nowg-string
|
||||||
workgroup
|
(wg-element-display
|
||||||
(format "%d %s" (1+ index) (wg-workgroup-name workgroup))
|
workgroup
|
||||||
'wg-current-workgroup-p
|
(format " (%d) %s " (1+ index) (wg-workgroup-name workgroup))
|
||||||
'wg-previous-workgroup-p)))
|
'wg-current-workgroup-p)))
|
||||||
(wg-workgroup-list)))))
|
(wg-workgroup-list))))
|
||||||
|
(if return-p
|
||||||
|
output
|
||||||
|
(message "%s" output)))))
|
||||||
|
|
||||||
|
;;;###autoload
|
||||||
|
(defun narf/workgroup-update-names (&optional wg)
|
||||||
|
(let ((wg (or wg (wg-current-workgroup))))
|
||||||
|
(unless (memq wg narf-wg-names)
|
||||||
|
(ignore-errors
|
||||||
|
(let ((old-name (wg-workgroup-name wg))
|
||||||
|
(base (f-filename (buffer-file-name))))
|
||||||
|
(unless (string= base old-name)
|
||||||
|
(wg-rename-workgroup base wg)))))))
|
||||||
|
;; (advice-add 'select-window :after 'narf|workgroup-update-name)
|
||||||
|
|
||||||
;;;###autoload (autoload 'narf:switch-to-workgroup-left "defuns-workgroup" nil t)
|
;;;###autoload (autoload 'narf:switch-to-workgroup-left "defuns-workgroup" nil t)
|
||||||
(evil-define-command narf:switch-to-workgroup-left (count)
|
(evil-define-command narf:switch-to-workgroup-left (count)
|
||||||
|
@ -87,7 +107,7 @@
|
||||||
(if count
|
(if count
|
||||||
(wg-switch-to-workgroup-at-index (1- count))
|
(wg-switch-to-workgroup-at-index (1- count))
|
||||||
(wg-switch-to-workgroup-left))
|
(wg-switch-to-workgroup-left))
|
||||||
(narf:workgroup-display))
|
(narf/workgroup-display (wg-previous-workgroup)))
|
||||||
|
|
||||||
;;;###autoload (autoload 'narf:switch-to-workgroup-right "defuns-workgroup" nil t)
|
;;;###autoload (autoload 'narf:switch-to-workgroup-right "defuns-workgroup" nil t)
|
||||||
(evil-define-command narf:switch-to-workgroup-right (count)
|
(evil-define-command narf:switch-to-workgroup-right (count)
|
||||||
|
@ -95,16 +115,16 @@
|
||||||
(if count
|
(if count
|
||||||
(wg-switch-to-workgroup-at-index (1- count))
|
(wg-switch-to-workgroup-at-index (1- count))
|
||||||
(wg-switch-to-workgroup-right))
|
(wg-switch-to-workgroup-right))
|
||||||
(narf:workgroup-display))
|
(narf/workgroup-display (wg-previous-workgroup)))
|
||||||
|
|
||||||
;;;###autoload
|
;;;###autoload
|
||||||
(defun narf:switch-to-workgroup-at-index (index)
|
(defun narf:switch-to-workgroup-at-index (index)
|
||||||
(interactive)
|
(interactive)
|
||||||
(narf:workgroup-display)
|
(narf/workgroup-update-names)
|
||||||
(let ((wgs (wg-workgroup-list-or-error)))
|
(let ((wgs (wg-workgroup-list-or-error)))
|
||||||
(unless (eq (nth index wgs) (wg-current-workgroup t))
|
(unless (eq (nth index wgs) (wg-current-workgroup t))
|
||||||
(wg-switch-to-workgroup-at-index index)
|
(wg-switch-to-workgroup-at-index index)))
|
||||||
(narf:workgroup-display))))
|
(narf/workgroup-display t))
|
||||||
|
|
||||||
;;;###autoload
|
;;;###autoload
|
||||||
(defun narf/undo-window-change ()
|
(defun narf/undo-window-change ()
|
||||||
|
@ -116,5 +136,16 @@
|
||||||
(interactive)
|
(interactive)
|
||||||
(call-interactively (if (wg-current-workgroup t) 'wg-redo-wconfig-change 'winner-redo)))
|
(call-interactively (if (wg-current-workgroup t) 'wg-redo-wconfig-change 'winner-redo)))
|
||||||
|
|
||||||
|
;;;###autoload
|
||||||
|
(defun narf/close-window-or-workgroup ()
|
||||||
|
(interactive)
|
||||||
|
(if (and (= (length (window-list)) 1)
|
||||||
|
(> (length (wg-workgroup-list)) 1))
|
||||||
|
(if (string= (wg-workgroup-name (wg-current-workgroup)) wg-first-wg-name)
|
||||||
|
(evil-window-delete)
|
||||||
|
(narf:workgroup-delete))
|
||||||
|
(evil-window-delete)))
|
||||||
|
|
||||||
|
|
||||||
(provide 'defuns-workgroup)
|
(provide 'defuns-workgroup)
|
||||||
;;; defuns-workgroup.el ends here
|
;;; defuns-workgroup.el ends here
|
||||||
|
|
|
@ -168,6 +168,10 @@
|
||||||
`(reb-match-2 ((,c (:foreground ,green :inverse-video t))))
|
`(reb-match-2 ((,c (:foreground ,green :inverse-video t))))
|
||||||
`(reb-match-3 ((,c (:foreground ,yellow :inverse-video t))))
|
`(reb-match-3 ((,c (:foreground ,yellow :inverse-video t))))
|
||||||
|
|
||||||
|
;; workgroups2
|
||||||
|
`(wg-current-workgroup-face ((,c (:foreground ,black :background ,orange))))
|
||||||
|
`(wg-other-workgroup-face ((,c (:foreground ,grey-.5 :background ,current-line))))
|
||||||
|
|
||||||
;; neotree
|
;; neotree
|
||||||
`(neo-root-dir-face ((,c (:foreground ,cyan))))
|
`(neo-root-dir-face ((,c (:foreground ,cyan))))
|
||||||
`(neo-file-link-face ((,c (:foreground ,white))))
|
`(neo-file-link-face ((,c (:foreground ,white))))
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue