Browse Source

Revamp the lsp/python stuff and use tree sitter for syntax highlighting.

master
Taylor Bockman 2 years ago
parent
commit
2310cbe20d
  1. 2
      elisp/custom.el
  2. 4
      elisp/keybinds.el
  3. 52
      elisp/modes/default-modes.el
  4. 20
      elisp/modes/python-mode-settings.el

2
elisp/custom.el

@ -4,7 +4,7 @@
;; Your init file should contain only one such instance. ;; Your init file should contain only one such instance.
;; If there is more than one, they won't work right. ;; If there is more than one, they won't work right.
'(package-selected-packages '(package-selected-packages
'(color-identifiers-mode centaur-tabs lsp-pyright magit doom-modeline flycheck-indicator nord-theme powerline rainbow-delimiters python-pytest json-mode company-jedi jedi hl-defined counsel rainbow-identifiers exwm-config all-the-icons-ibuffer slime ivy zerodark-theme zerodark neotree all-the-icons paredit flycheck aggressive-indent aggressive-indent-mode lsp-python-ms py-autopep8 pyenv-mode elpy lsp-ui use-package))) '(company-lsp color-identifiers-mode centaur-tabs lsp-pyright magit doom-modeline flycheck-indicator nord-theme powerline rainbow-delimiters python-pytest json-mode company-jedi jedi hl-defined counsel rainbow-identifiers exwm-config all-the-icons-ibuffer slime ivy zerodark-theme zerodark neotree all-the-icons paredit flycheck aggressive-indent aggressive-indent-mode lsp-python-ms py-autopep8 pyenv-mode elpy lsp-ui use-package)))
(custom-set-faces (custom-set-faces
;; custom-set-faces was added by Custom. ;; custom-set-faces was added by Custom.
;; If you edit it by hand, you could mess it up, so be careful. ;; If you edit it by hand, you could mess it up, so be careful.

4
elisp/keybinds.el

@ -12,3 +12,7 @@
;; Force C-x C-b to ibuffer ;; Force C-x C-b to ibuffer
(global-set-key (kbd "C-x C-b") 'ibuffer) (global-set-key (kbd "C-x C-b") 'ibuffer)
;; Use projectile find file to help
;; with larger projects.
(global-set-key (kbd "C-x f") 'projectile--find-file)

52
elisp/modes/default-modes.el

@ -1,27 +1,10 @@
;; Default mode definitions. ;; Default mode definitions.
;;; Code:
;; Easier to identify identifiers
(use-package color-identifiers-mode
:ensure t
:init (add-hook 'after-init-hook 'global-color-identifiers-mode)
:config
(setq color-identifiers:recoloring-delay 1))
;; Flycheck is enabled globally. ;; Flycheck is enabled globally.
(use-package flycheck (use-package flycheck
:ensure t :ensure t
:hook ((after-init . global-flycheck-mode))) :hook ((after-init . global-flycheck-mode)))
;; Company is enabled globally.
(use-package company
:ensure t
:hook ((after-init . global-company-mode))
:config ;; backend setting must be done only after load.
(push 'company-files company-backends)
(push 'company-keywords company-backends)
(push 'company-capf company-backends))
(use-package projectile (use-package projectile
:ensure t :ensure t
:bind-keymap :bind-keymap
@ -29,12 +12,41 @@
(use-package lsp-mode (use-package lsp-mode
:ensure t :ensure t
:hook ((python-mode . lsp-deferred)) :hook ((python-mode . lsp-deferred)
:commands (lsp lsp-deferred)) (ruby-mode . lsp-deferred)
(c-mode . lsp-deferred)
(c++-mode . lsp-deferred)))
(use-package lsp-ui (use-package lsp-ui
:ensure t :ensure t
:hook (lsp-mode . lsp-ui-mode)) :after lsp
:hook ((lsp-mode . lsp-ui-mode))
:config
(setq lsp-ui-doc-enable t)
(setq lsp-ui-doc-show-with-cursor t)
(setq lsp-ui-doc-show-with-mouse t))
;; Way better syntax highlighting for many languages
;; Emacs 29 supports this natively.
(if (version<= emacs-version "29")
(progn
(use-package tree-sitter
:ensure t
:init
(global-tree-sitter-mode)
:hook ((tree-sitter-after-on . tree-sitter-hl-mode)))
(use-package tree-sitter-langs
:ensure t))
)
;; Company is enabled globally.
(use-package company
:ensure t
:hook ((after-init . global-company-mode))
:config ;; backend setting must be done only after load.
(push 'company-files company-backends)
(push 'company-keywords company-backends)
(push 'company-capf company-backends))
(with-eval-after-load 'magit-mode (with-eval-after-load 'magit-mode
(add-hook 'after-save-hook 'magit-after-save-refresh-status t)) (add-hook 'after-save-hook 'magit-after-save-refresh-status t))

20
elisp/modes/python-mode-settings.el

@ -4,8 +4,8 @@
;;; ;;;
;;; ;;;
;;; - For each project you will need to install flake8/autopep8 into the virtualenv ;;; - For each project you will need to install flake8/autopep8 into the virtualenv
;;; - For each project you will need to install jedi into the virtualenv
;;; - To set your pyenv use M-x pyenv-mode and select your local virtualenv ;;; - To set your pyenv use M-x pyenv-mode and select your local virtualenv
;; thx rakan.me ;; thx rakan.me
(defun pyenv-activate-current-project () (defun pyenv-activate-current-project ()
"Automatically activates pyenv version if .python-version file exists." "Automatically activates pyenv version if .python-version file exists."
@ -19,20 +19,13 @@
(pyenv-mode-set pyenv-current-version) (pyenv-mode-set pyenv-current-version)
(message (concat "Setting virtualenv to " pyenv-current-version)))))))) (message (concat "Setting virtualenv to " pyenv-current-version))))))))
;; For Python enable Elpy.
(use-package elpy
:ensure t
:defer t
:init
(advice-add 'python-mode :before 'elpy-enable))
;; Enable pyenv integration. ;; Enable pyenv integration.
(if (executable-find "pyenv") (if (executable-find "pyenv")
(use-package pyenv-mode (use-package pyenv-mode
:ensure t :ensure t
:config :config
(pyenv-mode))) (pyenv-mode)))
;; Disable elpy default virtualenv (use the pyenv one) ;; Disable elpy default virtualenv (use the pyenv one)
(setq elpy-rpc-virtualenv-path 'current) (setq elpy-rpc-virtualenv-path 'current)
@ -40,12 +33,13 @@
(use-package py-autopep8 (use-package py-autopep8
:ensure t) :ensure t)
(add-hook 'elpy-mode-hook 'py-autopep8-enable-on-save) (add-hook 'elpy-mode-hook 'py-autopep8-mode)
;; Enable flake8 - requires flake8 in your path so use pyenv/global pip install ;; Enable flake8 - requires flake8 in your path so use pyenv/global pip install
(add-hook 'python-mode-hook '(lambda () (add-hook 'python-mode-hook '(lambda ()
(setq flycheck-python-flake8-executable "flake8") (setq flycheck-python-flake8-executable "flake8")
(flycheck-select-checker 'python-flake8) (flycheck-select-checker 'python-flake8)
(flycheck-mode t))) (flycheck-mode t)))
;; Activate pyenv automatically if a .python-version is supplied ;; Activate pyenv automatically if a .python-version is supplied
(if (executable-find "pyenv") (if (executable-find "pyenv")
(add-hook 'python-mode-hook 'pyenv-activate-current-project)) (add-hook 'python-mode-hook 'pyenv-activate-current-project))

Loading…
Cancel
Save