blob: 2dc1fb3b13d352608ffbf02ae9edf8465e04d697 (
plain)
| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
 | ;;; prog-python --- Python Specific Setup and Functionality -*- lexical-binding: t; coding: utf-8; -*-
;; author Craig Jennings <c@cjennings.net>
;;; Commentary:
;;; Code:
;; -------------------------------- Python Setup -------------------------------
;; preferences for Python programming
(defun cj/python-setup ()
  "My default code preferences for Python coding."
  (tree-sitter-hl-mode)               ;; use tree-sitter's highlighting
  (hs-minor-mode)                     ;; folding
  (company-mode)                      ;; completion framework
  (flyspell-prog-mode)                ;; spell check comments
  (superword-mode)                    ;; see-this-as-one-word
  (setq-default fill-column 80)       ;; wrap at 80 columns
  (setq-default tab-width 4)          ;; set the tab width to 4 spaces
  (setq-default standard-indent 4)    ;; indent 4 spaces
  (setq-default indent-tabs-mode nil) ;; disable tab characters
  (electric-pair-mode t))             ;; match delimiters automatically
;; ----------------------------------- Python ----------------------------------
;; configuration for Emacs' built-in Python editing support
(use-package python
  :ensure nil ;; built-in
  :hook
  (python-mode . cj/python-setup)
  :custom
  (python-shell-interpreter "python3")
  :config
  ;; remove the "guess indent" python message
  (setq python-indent-guess-indent-offset-verbose nil))
;; ----------------------------------- Poetry ----------------------------------
;; virtual environments and dependencies
(use-package poetry
  :defer t
  :after (python)
  :hook (python-mode . poetry-tracking-mode)
  :config
  ;; Checks for the correct virtualenv. Better strategy IMO because the default
  ;; one is quite slow.
  (setq poetry-tracking-strategy 'switch-buffer))
;; ---------------------------------- Blacken ----------------------------------
;; formatting on save
(use-package blacken
  :defer 1
  :custom
  (blacken-allow-py36 t)
  (blacken-skip-string-normalization t)
  :hook (python-mode . blacken-mode))
;; ---------------------------------- Numpydoc ---------------------------------
;; automatically insert NumPy style docstrings in Python function definitions
(use-package numpydoc
  :defer 1
  :custom
  (numpydoc-insert-examples-block nil)
  (numpydoc-template-long nil)
  :bind (:map python-mode-map
			  ("C-c C-n" . numpydoc-generate)))
;; ------------------------------------ TOML -----------------------------------
;; editing support and documentation for TOML files
(use-package toml-mode
  :defer 1)
(use-package eldoc-toml
  :defer 1)
(provide 'prog-python)
;;; prog-python.el ends here
 |