X-Git-Url: https://git.shemshak.org/~bandali/configs/blobdiff_plain/e65630e02ebd6d255f86951e3b768a2c323712e2..760226f5301e59d93699b8be5b5684b2c70019cb:/spacemacs/.spacemacs diff --git a/spacemacs/.spacemacs b/spacemacs/.spacemacs index 8fed059..2529efe 100644 --- a/spacemacs/.spacemacs +++ b/spacemacs/.spacemacs @@ -1,106 +1,182 @@ -;; -*- mode: emacs-lisp -*- +;; -*- mode: dotspacemacs -*- ;; This file is loaded by Spacemacs at startup. ;; It must be stored in your home directory. -;; Configuration Layers -;; -------------------- - -(setq-default - ;; List of additional paths where to look for configuration layers. - ;; Paths must have a trailing slash (ie. `~/.mycontribs/') - dotspacemacs-configuration-layer-path '() - ;; List of configuration layers to load. - dotspacemacs-configuration-layers '(mu4e evil git c-c++ auctex html) - ;; A list of packages and/or extensions that will not be install and loaded. - dotspacemacs-excluded-packages '() -) - -;; Settings -;; -------- - -(setq-default - ;; Specify the startup banner. If the value is an integer then the - ;; banner with the corresponding index is used, if the value is `random' - ;; then the banner is chosen randomly among the available banners, if - ;; the value is nil then no banner is displayed. - dotspacemacs-startup-banner 001 - ;; List of themes, the first of the list is loaded when spacemacs starts. - ;; Press T n to cycle to the next theme in the list (works great - ;; with 2 themes variants, one dark and one light) - dotspacemacs-themes '(zenburn) - ;; The leader key - dotspacemacs-leader-key "SPC" - ;; Major mode leader key is a shortcut key which is the equivalent of - ;; pressing ` m` - dotspacemacs-major-mode-leader-key "," - ;; The command key used for Evil commands (ex-commands) and - ;; Emacs commands (M-x). - ;; By default the command key is `:' so ex-commands are executed like in Vim - ;; with `:' and Emacs commands are executed with ` :'. - dotspacemacs-command-key ":" - ;; Guide-key delay in seconds. The Guide-key is the popup buffer listing - ;; the commands bound to the current keystrokes. - dotspacemacs-guide-key-delay 0.4 - ;; If non nil the frame is fullscreen when Emacs starts up (Emacs 24.4+ only). - dotspacemacs-fullscreen-at-startup nil - ;; If non nil `spacemacs/toggle-fullscreen' will not use native fullscreen. - ;; Use to disable fullscreen animations in OSX." - dotspacemacs-fullscreen-use-non-native nil - ;; If non nil the frame is maximized when Emacs starts up (Emacs 24.4+ only). - ;; Takes effect only if `dotspacemacs-fullscreen-at-startup' is nil. - dotspacemacs-maximized-at-startup nil - ;; A value from the range (0..100), in increasing opacity, which describes the - ;; transparency level of a frame when it's active or selected. Transparency can - ;; be toggled through `toggle-transparency'. - dotspacemacs-active-transparency 90 - ;; A value from the range (0..100), in increasing opacity, which describes the - ;; transparency level of a frame when it's inactive or deselected. Transparency - ;; can be toggled through `toggle-transparency'. - dotspacemacs-inactive-transparency 90 - ;; If non nil unicode symbols are displayed in the mode line (e.g. for lighters) - dotspacemacs-mode-line-unicode-symbols t - ;; If non nil smooth scrolling (native-scrolling) is enabled. Smooth scrolling - ;; overrides the default behavior of Emacs which recenters the point when - ;; it reaches the top or bottom of the screen - dotspacemacs-smooth-scrolling t - ;; If non-nil smartparens-strict-mode will be enabled in programming modes. - dotspacemacs-smartparens-strict-mode nil - ;; If non nil advises quit functions to keep server open when quitting. - dotspacemacs-persistent-server nil - ;; The default package repository used if no explicit repository has been - ;; specified with an installed package. - ;; Not used for now. - dotspacemacs-default-package-repository nil - ;; Disable setting the cursor color according to states - dotspacemacs-colorize-cursor-according-to-state nil - ;; font - dotspacemacs-default-font '("Source Code Pro for Powerline" - :size 14 - :weight normal - :width normal - :powerline-scale 1.1) - ) - -;; Initialization Hooks -;; -------------------- +(defun dotspacemacs/layers () + "Configuration Layers declaration." + (setq-default + ;; List of additional paths where to look for configuration layers. + ;; Paths must have a trailing slash (ie. `~/.mycontribs/') + dotspacemacs-configuration-layer-path '() + ;; List of configuration layers to load. If it is the symbol `all' instead + ;; of a list then all discovered layers will be installed. + dotspacemacs-configuration-layers + '( + ;; -------------------------------------------------------- + ;; Example of useful layers you may want to use right away + ;; Uncomment a layer name and press C-c C-c to install it + ;; -------------------------------------------------------- + auto-completion + better-defaults + (git :variables + git-gutter-use-fringe t) + markdown + org + syntax-checking + mu4e + evil + c-c++ + auctex + html + clojure + (haskell :variables '(haskell-enable-hindent-style "chris-done" + haskell-enable-shm-support t)) + emacs-lisp + rust + rust-lang + shell + themes-megapack + ) + ;; A list of packages and/or extensions that will not be install and loaded. + dotspacemacs-excluded-packages '() + ;; If non-nil spacemacs will delete any orphan packages, i.e. packages that + ;; are declared in a layer which is not a member of + ;; the list `dotspacemacs-configuration-layers' + dotspacemacs-delete-orphan-packages t)) (defun dotspacemacs/init () - "User initialization for Spacemacs. This function is called at the very - startup." + "Initialization function. +This function is called at the very startup of Spacemacs initialization +before layers configuration." + ;; This setq-default sexp is an exhaustive list of all the supported + ;; spacemacs settings. + (setq-default + ;; Either `vim' or `emacs'. Evil is always enabled but if the variable + ;; is `emacs' then the `holy-mode' is enabled at startup. + dotspacemacs-editing-style 'vim + ;; If non nil output loading progess in `*Messages*' buffer. + dotspacemacs-verbose-loading nil + ;; Specify the startup banner. Default value is `official', it displays + ;; the official spacemacs logo. An integer value is the index of text + ;; banner, `random' chooses a random text banner in `core/banners' + ;; directory. A string value must be a path to a .PNG file. + ;; If the value is nil then no banner is displayed. + ;; dotspacemacs-startup-banner 'official + dotspacemacs-startup-banner 'official + ;; t if you always want to see the changelog at startup + dotspacemacs-always-show-changelog nil + ;; List of items to show in the startup buffer. If nil it is disabled. + ;; Possible values are: `recents' `bookmarks' `projects'." + dotspacemacs-startup-lists '(recents projects) + ;; List of themes, the first of the list is loaded when spacemacs starts. + ;; Press T n to cycle to the next theme in the list (works great + ;; with 2 themes variants, one dark and one light) + ;; dotspacemacs-themes '(leuven sanityinc-tomorrow-night solarized-dark solarized-light) + dotspacemacs-themes '(gotham) + ;; If non nil the cursor color matches the state color. + dotspacemacs-colorize-cursor-according-to-state t + ;; Default font. `powerline-scale' allows to quickly tweak the mode-line + ;; size to make separators look not too crappy. + dotspacemacs-default-font '("Source Code Pro" + :size 14 + :weight normal + :width normal + :powerline-scale 1.1) + ;; The leader key + dotspacemacs-leader-key "SPC" + ;; The leader key accessible in `emacs state' and `insert state' + dotspacemacs-emacs-leader-key "M-m" + ;; Major mode leader key is a shortcut key which is the equivalent of + ;; pressing ` m`. Set it to `nil` to disable it. + dotspacemacs-major-mode-leader-key "," + ;; Major mode leader key accessible in `emacs state' and `insert state' + dotspacemacs-major-mode-emacs-leader-key "C-M-m" + ;; The command key used for Evil commands (ex-commands) and + ;; Emacs commands (M-x). + ;; By default the command key is `:' so ex-commands are executed like in Vim + ;; with `:' and Emacs commands are executed with ` :'. + dotspacemacs-command-key ":" + ;; If non nil the paste micro-state is enabled. While enabled pressing `p` + ;; several times cycle between the kill ring content. + dotspacemacs-enable-paste-micro-state t + ;; Guide-key delay in seconds. The Guide-key is the popup buffer listing + ;; the commands bound to the current keystrokes. + dotspacemacs-guide-key-delay 0.4 + ;; If non nil a progress bar is displayed when spacemacs is loading. This + ;; may increase the boot time on some systems and emacs builds, set it to + ;; nil ;; to boost the loading time. + dotspacemacs-loading-progress-bar t + ;; If non nil the frame is fullscreen when Emacs starts up. + ;; (Emacs 24.4+ only) + dotspacemacs-fullscreen-at-startup nil + ;; If non nil `spacemacs/toggle-fullscreen' will not use native fullscreen. + ;; Use to disable fullscreen animations in OSX." + dotspacemacs-fullscreen-use-non-native nil + ;; If non nil the frame is maximized when Emacs starts up. + ;; Takes effect only if `dotspacemacs-fullscreen-at-startup' is nil. + ;; (Emacs 24.4+ only) + dotspacemacs-maximized-at-startup nil + ;; A value from the range (0..100), in increasing opacity, which describes + ;; the transparency level of a frame when it's active or selected. + ;; Transparency can be toggled through `toggle-transparency'. + dotspacemacs-active-transparency 90 + ;; A value from the range (0..100), in increasing opacity, which describes + ;; the transparency level of a frame when it's inactive or deselected. + ;; Transparency can be toggled through `toggle-transparency'. + dotspacemacs-inactive-transparency 90 + ;; If non nil unicode symbols are displayed in the mode line. + dotspacemacs-mode-line-unicode-symbols t + ;; If non nil smooth scrolling (native-scrolling) is enabled. Smooth + ;; scrolling overrides the default behavior of Emacs which recenters the + ;; point when it reaches the top or bottom of the screen. + dotspacemacs-smooth-scrolling t + ;; If non-nil smartparens-strict-mode will be enabled in programming modes. + dotspacemacs-smartparens-strict-mode nil + ;; If non nil advises quit functions to keep server open when quitting. + dotspacemacs-persistent-server nil + ;; The default package repository used if no explicit repository has been + ;; specified with an installed package. + ;; Not used for now. + dotspacemacs-default-package-repository nil + ;; Disable setting the cursor color according to states + dotspacemacs-colorize-cursor-according-to-state nil + ) + ;; User initialization goes here ) (defun dotspacemacs/config () - "This is were you can ultimately override default Spacemacs configuration. -This function is called at the very end of Spacemacs initialization." + "Configuration function. + This function is called at the very end of Spacemacs initialization after +layers configuration." (setq powerline-default-separator nil) (setq TeX-PDF-mode t Tex-command-default 'TeX) -) + (setq undo-tree-auto-save-history t + undo-tree-history-directory-alist + `(("." . ,(concat spacemacs-cache-directory "undo")))) + (unless (file-exists-p (concat spacemacs-cache-directory "undo")) + (make-directory (concat spacemacs-cache-directory "undo"))) + + (setq TeX-view-program-selection + '(((output-dvi style-pstricks) + "dvips and gv") + (output-dvi "xdvi") + (output-pdf "zathura") + (output-html "xdg-open"))) -;; Custom variables -;; ---------------- + (setq TeX-view-program-list + '(("zathura" + ("zathura" (mode-io-correlate "-sync.sh") + " " + (mode-io-correlate "%n:1:%t ") + "%o")))) + + (advice-add #'magit-key-mode-popup-committing :after + (lambda () + (magit-key-mode-toggle-option (quote committing) "--verbose"))) +) -;; Do not write anything in this section. This is where Emacs will +;; Do not write anything past this comment. This is where Emacs will ;; auto-generate custom variable definitions.