blob: e85ae5481a3e447da0257380f83d5076c136ca63 (
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; -*-
;; 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
|