blob: d7be5022cb95a008d6f35abace04e8e57a20dcb4 (
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
|
;;; hide-mode-line.el --- Hide the modeline super easy -*- lexical-binding: t; -*-
;; Copyright (C) 2023 Aryadev Chavali
;; Author: Aryadev Chavali <aryadev@aryadevchavali.com>
;; Keywords:
;; This program is free software; you can redistribute it and/or
;; modify it under the terms of the GNU General Public License version
;; 2 as published by the Free Software Foundation.
;; This program is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;; GNU General Public License for more details.
;; You should have received a copy of the GNU General Public License
;; along with this program. If not, see <https://www.gnu.org/licenses/>.
;;; Commentary:
;; Defines a minor mode which toggles off the mode line.
;;; Code:
(defvar hide-mode-line--prev-mode-line nil)
(define-minor-mode hide-mode-line-mode
"Minor mode for hiding model lines"
:lighter nil
(cond
((and mode-line-format hide-mode-line-mode)
(setq-local hide-mode-line-mode t
hide-mode-line--prev-mode-line mode-line-format
mode-line-format nil))
(t (setq-local hide-mode-line nil
mode-line-format hide-mode-line--prev-mode-line
hide-mode-line--prev-mode-line nil))))
(define-globalized-minor-mode global-hide-mode-line-mode hide-mode-line-mode
(lambda nil (hide-mode-line-mode t)))
(provide 'hide-mode-line)
;;; hide-mode-line.el ends here
|