| 
									
										
										
										
											2018-04-07 10:45:42 +08:00
										 |  |  | ;; -*- mode: emacs-lisp -*- | 
					
						
							|  |  |  | ;; This file is loaded by Spacemacs at startup. | 
					
						
							|  |  |  | ;; It must be stored in your home directory. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ;; find java command for different platforms | 
					
						
							|  |  |  | (defun find-java () | 
					
						
							|  |  |  |   (cond ((eq system-type 'darwin) | 
					
						
							|  |  |  |          ;; we need to escape SPC charater to avoid execution fail | 
					
						
							|  |  |  |          "/Library/Internet\\ Plug-Ins/JavaAppletPlugin.plugin/Contents/Home/bin/java") | 
					
						
							|  |  |  |         ((eq system-type 'berkeley-unix) | 
					
						
							|  |  |  |          "/usr/local/bin/java") | 
					
						
							|  |  |  |         (t "/usr/bin/java"))) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ;; load configuration for local host | 
					
						
							|  |  |  | (defun load-local-config (config) | 
					
						
							|  |  |  |   (let ((file (concat "~/" config "." system-name ".el"))) | 
					
						
							|  |  |  |     ;; load config | 
					
						
							|  |  |  |     (message "loading %s..." file) | 
					
						
							|  |  |  |     (when (file-exists-p file) | 
					
						
							|  |  |  |       (load-file file)))) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (defun do-foreach (tag action) | 
					
						
							|  |  |  |   (save-excursion | 
					
						
							|  |  |  |     (progn (goto-char (point-min)) | 
					
						
							|  |  |  |            (while (re-search-forward tag nil t) | 
					
						
							|  |  |  |              (progn (funcall action) | 
					
						
							|  |  |  |                     (forward-line 1)))))) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (defun semantic-select-windows () | 
					
						
							|  |  |  |   (add-to-list 'semantic-lex-c-preprocessor-symbol-map | 
					
						
							|  |  |  |                '("WIN32" . "1")) | 
					
						
							|  |  |  |   (add-to-list 'semantic-lex-c-preprocessor-symbol-map | 
					
						
							|  |  |  |                '("__linux__" . "")) | 
					
						
							|  |  |  |   (add-to-list 'semantic-lex-c-preprocessor-symbol-map | 
					
						
							|  |  |  |                '("_MACOS_X_" . ""))) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (defun semantic-select-linux () | 
					
						
							|  |  |  |   (add-to-list 'semantic-lex-c-preprocessor-symbol-map | 
					
						
							|  |  |  |                '("WIN32" . "")) | 
					
						
							|  |  |  |   (add-to-list 'semantic-lex-c-preprocessor-symbol-map | 
					
						
							|  |  |  |                '("__linux__" . "1")) | 
					
						
							|  |  |  |   (add-to-list 'semantic-lex-c-preprocessor-symbol-map | 
					
						
							|  |  |  |                '("_MACOS_X_" . ""))) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (defun semantic-select-macos ()   | 
					
						
							|  |  |  |   (add-to-list 'semantic-lex-c-preprocessor-symbol-map | 
					
						
							|  |  |  |                '("WIN32" . "")) | 
					
						
							|  |  |  |   (add-to-list 'semantic-lex-c-preprocessor-symbol-map | 
					
						
							|  |  |  |                '("__linux__" . "")) | 
					
						
							|  |  |  |   (add-to-list 'semantic-lex-c-preprocessor-symbol-map | 
					
						
							|  |  |  |                '("_MACOS_X_" . "1"))) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (defun semantic-select-target-os (os) | 
					
						
							|  |  |  |   (interactive | 
					
						
							|  |  |  |    (let ((os-selected (completing-read "Choose OS:" | 
					
						
							|  |  |  |                                        (list "windows" | 
					
						
							|  |  |  |                                              "linux" | 
					
						
							|  |  |  |                                              "macos")))) | 
					
						
							|  |  |  |      (list os-selected))) | 
					
						
							|  |  |  |   (when os | 
					
						
							|  |  |  |     (semantic-c-reset-preprocessor-symbol-map) | 
					
						
							|  |  |  |     (cond ((equal os "windows") | 
					
						
							|  |  |  |            (semantic-select-windows)) | 
					
						
							|  |  |  |           ((equal os "linux") | 
					
						
							|  |  |  |            (semantic-select-linux)) | 
					
						
							|  |  |  |           ((equal os "macos") | 
					
						
							|  |  |  |            (semantic-select-macos)) | 
					
						
							|  |  |  |           (t (message "unsupported os\n"))))) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (defun dotspacemacs/layers () | 
					
						
							|  |  |  |   "Configuration Layers declaration. | 
					
						
							|  |  |  | You should not put any user code in this function besides modifying the variable | 
					
						
							|  |  |  | values." | 
					
						
							|  |  |  |   (setq-default | 
					
						
							|  |  |  |    ;; Base distribution to use. This is a layer contained in the directory | 
					
						
							|  |  |  |    ;; `+distribution'. For now available distributions are `spacemacs-base' | 
					
						
							|  |  |  |    ;; or `spacemacs'. (default 'spacemacs) | 
					
						
							|  |  |  |    dotspacemacs-distribution 'spacemacs | 
					
						
							|  |  |  |    ;; Lazy installation of layers (i.e. layers are installed only when a file | 
					
						
							|  |  |  |    ;; with a supported type is opened). Possible values are `all', `unused' | 
					
						
							|  |  |  |    ;; and `nil'. `unused' will lazy install only unused layers (i.e. layers | 
					
						
							|  |  |  |    ;; not listed in variable `dotspacemacs-configuration-layers'), `all' will | 
					
						
							|  |  |  |    ;; lazy install any layer that support lazy installation even the layers | 
					
						
							|  |  |  |    ;; listed in `dotspacemacs-configuration-layers'. `nil' disable the lazy | 
					
						
							|  |  |  |    ;; installation feature and you have to explicitly list a layer in the | 
					
						
							|  |  |  |    ;; variable `dotspacemacs-configuration-layers' to install it. | 
					
						
							|  |  |  |    ;; (default 'unused) | 
					
						
							|  |  |  |    dotspacemacs-enable-lazy-installation 'unused | 
					
						
							|  |  |  |    ;; If non-nil then Spacemacs will ask for confirmation before installing | 
					
						
							|  |  |  |    ;; a layer lazily. (default t) | 
					
						
							|  |  |  |    dotspacemacs-ask-for-lazy-installation t | 
					
						
							|  |  |  |    ;; If non-nil layers with lazy install support are lazy installed. | 
					
						
							|  |  |  |    ;; List of additional paths where to look for configuration layers. | 
					
						
							|  |  |  |    ;; Paths must have a trailing slash (i.e. `~/.mycontribs/') | 
					
						
							| 
									
										
										
										
											2018-04-07 10:57:46 +08:00
										 |  |  |    dotspacemacs-configuration-layer-path '("~/workenv/emacs/layers.personal") | 
					
						
							| 
									
										
										
										
											2018-04-07 10:45:42 +08:00
										 |  |  |    ;; 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 | 
					
						
							|  |  |  |    '( | 
					
						
							|  |  |  |      haskell | 
					
						
							|  |  |  |      go | 
					
						
							|  |  |  |      yaml | 
					
						
							|  |  |  |      ;; ---------------------------------------------------------------- | 
					
						
							|  |  |  |      ;; Example of useful layers you may want to use right away. | 
					
						
							|  |  |  |      ;; Uncomment some layer names and press <SPC f e R> (Vim style) or | 
					
						
							|  |  |  |      ;; <M-m f e R> (Emacs style) to install them. | 
					
						
							|  |  |  |      ;; ---------------------------------------------------------------- | 
					
						
							|  |  |  |      helm | 
					
						
							|  |  |  |      ;; auto-completion | 
					
						
							|  |  |  |      better-defaults | 
					
						
							|  |  |  |      emacs-lisp | 
					
						
							|  |  |  |      git | 
					
						
							|  |  |  |      (markdown :variables markdown-live-preview-engine 'vmd) | 
					
						
							|  |  |  |      (org :variables | 
					
						
							|  |  |  |           org-enable-github-support t) | 
					
						
							|  |  |  |      (shell :variables | 
					
						
							|  |  |  |             shell-default-height 30 | 
					
						
							|  |  |  |             shell-default-position 'bottom) | 
					
						
							|  |  |  |      (spell-checking :variables | 
					
						
							|  |  |  |                      spell-checking-enable-auto-dictionary t | 
					
						
							|  |  |  |                      spell-checking-enable-by-default nil) | 
					
						
							|  |  |  |      (syntax-checking :variables | 
					
						
							|  |  |  |                       syntax-checking-enable-by-default nil) | 
					
						
							|  |  |  |      version-control | 
					
						
							|  |  |  |      ;; enable c-c++ layer seems downgrade | 
					
						
							|  |  |  |      ;; the performance of Emacs | 
					
						
							|  |  |  |      (c-c++ :variables | 
					
						
							|  |  |  |             c-c++-default-mode-for-headers 'c++-mode  | 
					
						
							|  |  |  |             c-c++-enable-clang-support nil) | 
					
						
							|  |  |  |      ;;semantic | 
					
						
							|  |  |  |      common-lisp | 
					
						
							|  |  |  |      (latex :variables | 
					
						
							|  |  |  |             latex-build-command "LatexMk") | 
					
						
							|  |  |  |      ;;ocaml | 
					
						
							|  |  |  |      racket | 
					
						
							|  |  |  |      python | 
					
						
							|  |  |  |      shell-scripts | 
					
						
							|  |  |  |      (chinese :variables | 
					
						
							|  |  |  |               chinese-enable-youdao-dict t | 
					
						
							|  |  |  |               pangu-spacing-exclude-modes '(c-mode c++-mode)) | 
					
						
							|  |  |  |      themes-megapack | 
					
						
							|  |  |  |      emoji | 
					
						
							|  |  |  |      ess | 
					
						
							|  |  |  |      asciidoc | 
					
						
							|  |  |  |      github | 
					
						
							|  |  |  |      ;;gtags | 
					
						
							|  |  |  |      (colors :variables | 
					
						
							|  |  |  |              colors-enable-rainbow-identifiers t | 
					
						
							|  |  |  |              colors-enable-nyan-cat-progress-bar t) | 
					
						
							|  |  |  |      ;; javascript | 
					
						
							|  |  |  |      scala | 
					
						
							|  |  |  |      myeiffel | 
					
						
							|  |  |  |      mycquery | 
					
						
							|  |  |  |      ;;my-polymode | 
					
						
							|  |  |  |      orgtools | 
					
						
							|  |  |  |      ;;smex | 
					
						
							|  |  |  |      (customized :variables | 
					
						
							|  |  |  |                  my-default-c-style "Personal") | 
					
						
							|  |  |  |      scheme  | 
					
						
							|  |  |  |      csv | 
					
						
							|  |  |  |      myscribble | 
					
						
							|  |  |  |      html | 
					
						
							|  |  |  |      (mypollen :variables | 
					
						
							|  |  |  |                pollen-templates-directory "~/workenv/templates.pollen") | 
					
						
							|  |  |  |      search-engine | 
					
						
							|  |  |  |      javascript | 
					
						
							|  |  |  |      graphviz | 
					
						
							|  |  |  |      mytools | 
					
						
							|  |  |  | ;;   mymermaid | 
					
						
							|  |  |  |      ) | 
					
						
							|  |  |  |    ;; List of additional packages that will be installed without being | 
					
						
							|  |  |  |    ;; wrapped in a layer. If you need some configuration for these | 
					
						
							|  |  |  |    ;; packages, then consider creating a layer. You can also put the | 
					
						
							|  |  |  |    ;; configuration in `dotspacemacs/user-config'. | 
					
						
							|  |  |  |    dotspacemacs-additional-packages '() | 
					
						
							|  |  |  |    ;; A list of packages that cannot be updated. | 
					
						
							|  |  |  |    dotspacemacs-frozen-packages '() | 
					
						
							|  |  |  |    ;; A list of packages that will not be installed and loaded. | 
					
						
							|  |  |  |    dotspacemacs-excluded-packages '(savehist) | 
					
						
							|  |  |  |    ;; Defines the behaviour of Spacemacs when installing packages. | 
					
						
							|  |  |  |    ;; Possible values are `used-only', `used-but-keep-unused' and `all'. | 
					
						
							|  |  |  |    ;; `used-only' installs only explicitly used packages and uninstall any | 
					
						
							|  |  |  |    ;; unused packages as well as their unused dependencies. | 
					
						
							|  |  |  |    ;; `used-but-keep-unused' installs only the used packages but won't uninstall | 
					
						
							|  |  |  |    ;; them if they become unused. `all' installs *all* packages supported by | 
					
						
							|  |  |  |    ;; Spacemacs and never uninstall them. (default is `used-only') | 
					
						
							|  |  |  |    dotspacemacs-install-packages 'used-only)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (defun dotspacemacs/init () | 
					
						
							|  |  |  |   "Initialization function. | 
					
						
							|  |  |  | This function is called at the very startup of Spacemacs initialization | 
					
						
							|  |  |  | before layers configuration. | 
					
						
							|  |  |  | You should not put any user code in there besides modifying the variable | 
					
						
							|  |  |  | values." | 
					
						
							|  |  |  |   ;; This setq-default sexp is an exhaustive list of all the supported | 
					
						
							|  |  |  |   ;; spacemacs settings. | 
					
						
							|  |  |  |   (setq-default | 
					
						
							|  |  |  |    ;; If non nil ELPA repositories are contacted via HTTPS whenever it's | 
					
						
							|  |  |  |    ;; possible. Set it to nil if you have no way to use HTTPS in your | 
					
						
							|  |  |  |    ;; environment, otherwise it is strongly recommended to let it set to t. | 
					
						
							|  |  |  |    ;; This variable has no effect if Emacs is launched with the parameter | 
					
						
							|  |  |  |    ;; `--insecure' which forces the value of this variable to nil. | 
					
						
							|  |  |  |    ;; (default t) | 
					
						
							|  |  |  |    dotspacemacs-elpa-https t | 
					
						
							|  |  |  |    ;; Maximum allowed time in seconds to contact an ELPA repository. | 
					
						
							|  |  |  |    dotspacemacs-elpa-timeout 5 | 
					
						
							|  |  |  |    ;; If non nil then spacemacs will check for updates at startup | 
					
						
							|  |  |  |    ;; when the current branch is not `develop'. Note that checking for | 
					
						
							|  |  |  |    ;; new versions works via git commands, thus it calls GitHub services | 
					
						
							|  |  |  |    ;; whenever you start Emacs. (default nil) | 
					
						
							|  |  |  |    dotspacemacs-check-for-update t | 
					
						
							|  |  |  |    ;; If non-nil, a form that evaluates to a package directory. For example, to | 
					
						
							|  |  |  |    ;; use different package directories for different Emacs versions, set this | 
					
						
							|  |  |  |    ;; to `emacs-version'. | 
					
						
							|  |  |  |    dotspacemacs-elpa-subdirectory nil | 
					
						
							|  |  |  |    ;; One of `vim', `emacs' or `hybrid'. | 
					
						
							|  |  |  |    ;; `hybrid' is like `vim' except that `insert state' is replaced by the | 
					
						
							|  |  |  |    ;; `hybrid state' with `emacs' key bindings. The value can also be a list | 
					
						
							|  |  |  |    ;; with `:variables' keyword (similar to layers). Check the editing styles | 
					
						
							|  |  |  |    ;; section of the documentation for details on available variables. | 
					
						
							|  |  |  |    ;; (default 'vim) | 
					
						
							|  |  |  |    dotspacemacs-editing-style 'vim | 
					
						
							|  |  |  |    ;; If non nil output loading progress in `*Messages*' buffer. (default nil) | 
					
						
							|  |  |  |    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 an image format supported | 
					
						
							|  |  |  |    ;; by your Emacs build. | 
					
						
							|  |  |  |    ;; If the value is nil then no banner is displayed. (default 'official) | 
					
						
							|  |  |  |    dotspacemacs-startup-banner 'official | 
					
						
							|  |  |  |    ;; List of items to show in startup buffer or an association list of | 
					
						
							|  |  |  |    ;; the form `(list-type . list-size)`. If nil then it is disabled. | 
					
						
							|  |  |  |    ;; Possible values for list-type are: | 
					
						
							|  |  |  |    ;; `recents' `bookmarks' `projects' `agenda' `todos'." | 
					
						
							|  |  |  |    ;; List sizes may be nil, in which case | 
					
						
							|  |  |  |    ;; `spacemacs-buffer-startup-lists-length' takes effect. | 
					
						
							|  |  |  |    dotspacemacs-startup-lists '((recents . 5) | 
					
						
							|  |  |  |                                 (projects . 7)) | 
					
						
							|  |  |  |    ;; True if the home buffer should respond to resize events. | 
					
						
							|  |  |  |    dotspacemacs-startup-buffer-responsive t | 
					
						
							|  |  |  |    ;; Default major mode of the scratch buffer (default `text-mode') | 
					
						
							|  |  |  |    dotspacemacs-scratch-mode 'emacs-lisp-mode | 
					
						
							|  |  |  |    ;; List of themes, the first of the list is loaded when spacemacs starts. | 
					
						
							|  |  |  |    ;; Press <SPC> T n to cycle to the next theme in the list (works great | 
					
						
							|  |  |  |    ;; with 2 themes variants, one dark and one light) | 
					
						
							|  |  |  |    dotspacemacs-themes '(spacemacs-dark | 
					
						
							|  |  |  |                          spacemacs-light | 
					
						
							|  |  |  |                          solarized-light | 
					
						
							|  |  |  |                          solarized-dark | 
					
						
							|  |  |  |                          leuven | 
					
						
							|  |  |  |                          monokai | 
					
						
							|  |  |  |                          cherry-blossom | 
					
						
							|  |  |  |                          zenburn) | 
					
						
							|  |  |  |    ;; If non nil the cursor color matches the state color in GUI Emacs. | 
					
						
							|  |  |  |    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 '("Inconsolata LGC" | 
					
						
							|  |  |  |                                :size 14 | 
					
						
							|  |  |  |                                :weight normal | 
					
						
							|  |  |  |                                :width normal | 
					
						
							|  |  |  |                                :powerline-scale 1.1) | 
					
						
							|  |  |  |    ;; The leader key | 
					
						
							|  |  |  |    dotspacemacs-leader-key "SPC" | 
					
						
							|  |  |  |    ;; The key used for Emacs commands (M-x) (after pressing on the leader key). | 
					
						
							|  |  |  |    ;; (default "SPC") | 
					
						
							|  |  |  |    dotspacemacs-emacs-command-key "SPC" | 
					
						
							|  |  |  |    ;; The key used for Vim Ex commands (default ":") | 
					
						
							|  |  |  |    dotspacemacs-ex-command-key ":" | 
					
						
							|  |  |  |    ;; The leader key accessible in `emacs state' and `insert state' | 
					
						
							|  |  |  |    ;; (default "M-m") | 
					
						
							|  |  |  |    dotspacemacs-emacs-leader-key "M-m" | 
					
						
							|  |  |  |    ;; Major mode leader key is a shortcut key which is the equivalent of | 
					
						
							|  |  |  |    ;; pressing `<leader> m`. Set it to `nil` to disable it. (default ",") | 
					
						
							|  |  |  |    dotspacemacs-major-mode-leader-key "," | 
					
						
							|  |  |  |    ;; Major mode leader key accessible in `emacs state' and `insert state'. | 
					
						
							|  |  |  |    ;; (default "C-M-m") | 
					
						
							|  |  |  |    dotspacemacs-major-mode-emacs-leader-key "C-M-m" | 
					
						
							|  |  |  |    ;; These variables control whether separate commands are bound in the GUI to | 
					
						
							|  |  |  |    ;; the key pairs C-i, TAB and C-m, RET. | 
					
						
							|  |  |  |    ;; Setting it to a non-nil value, allows for separate commands under <C-i> | 
					
						
							|  |  |  |    ;; and TAB or <C-m> and RET. | 
					
						
							|  |  |  |    ;; In the terminal, these pairs are generally indistinguishable, so this only | 
					
						
							|  |  |  |    ;; works in the GUI. (default nil) | 
					
						
							|  |  |  |    dotspacemacs-distinguish-gui-tab nil | 
					
						
							|  |  |  |    ;; If non nil `Y' is remapped to `y$' in Evil states. (default nil) | 
					
						
							|  |  |  |    dotspacemacs-remap-Y-to-y$ nil | 
					
						
							|  |  |  |    ;; If non-nil, the shift mappings `<' and `>' retain visual state if used | 
					
						
							|  |  |  |    ;; there. (default t) | 
					
						
							|  |  |  |    dotspacemacs-retain-visual-state-on-shift t | 
					
						
							|  |  |  |    ;; If non-nil, J and K move lines up and down when in visual mode. | 
					
						
							|  |  |  |    ;; (default nil) | 
					
						
							|  |  |  |    dotspacemacs-visual-line-move-text nil | 
					
						
							|  |  |  |    ;; If non nil, inverse the meaning of `g' in `:substitute' Evil ex-command. | 
					
						
							|  |  |  |    ;; (default nil) | 
					
						
							|  |  |  |    dotspacemacs-ex-substitute-global nil | 
					
						
							|  |  |  |    ;; Name of the default layout (default "Default") | 
					
						
							|  |  |  |    dotspacemacs-default-layout-name "Default" | 
					
						
							|  |  |  |    ;; If non nil the default layout name is displayed in the mode-line. | 
					
						
							|  |  |  |    ;; (default nil) | 
					
						
							|  |  |  |    dotspacemacs-display-default-layout nil | 
					
						
							|  |  |  |    ;; If non nil then the last auto saved layouts are resume automatically upon | 
					
						
							|  |  |  |    ;; start. (default nil) | 
					
						
							|  |  |  |    dotspacemacs-auto-resume-layouts nil | 
					
						
							|  |  |  |    ;; Size (in MB) above which spacemacs will prompt to open the large file | 
					
						
							|  |  |  |    ;; literally to avoid performance issues. Opening a file literally means that | 
					
						
							|  |  |  |    ;; no major mode or minor modes are active. (default is 1) | 
					
						
							|  |  |  |    dotspacemacs-large-file-size 1 | 
					
						
							|  |  |  |    ;; Location where to auto-save files. Possible values are `original' to | 
					
						
							|  |  |  |    ;; auto-save the file in-place, `cache' to auto-save the file to another | 
					
						
							|  |  |  |    ;; file stored in the cache directory and `nil' to disable auto-saving. | 
					
						
							|  |  |  |    ;; (default 'cache) | 
					
						
							|  |  |  |    dotspacemacs-auto-save-file-location 'cache | 
					
						
							|  |  |  |    ;; Maximum number of rollback slots to keep in the cache. (default 5) | 
					
						
							|  |  |  |    dotspacemacs-max-rollback-slots 5 | 
					
						
							|  |  |  |    ;; If non nil, `helm' will try to minimize the space it uses. (default nil) | 
					
						
							|  |  |  |    dotspacemacs-helm-resize nil | 
					
						
							|  |  |  |    ;; if non nil, the helm header is hidden when there is only one source. | 
					
						
							|  |  |  |    ;; (default nil) | 
					
						
							|  |  |  |    dotspacemacs-helm-no-header nil | 
					
						
							|  |  |  |    ;; define the position to display `helm', options are `bottom', `top', | 
					
						
							|  |  |  |    ;; `left', or `right'. (default 'bottom) | 
					
						
							|  |  |  |    dotspacemacs-helm-position 'bottom | 
					
						
							|  |  |  |    ;; Controls fuzzy matching in helm. If set to `always', force fuzzy matching | 
					
						
							|  |  |  |    ;; in all non-asynchronous sources. If set to `source', preserve individual | 
					
						
							|  |  |  |    ;; source settings. Else, disable fuzzy matching in all sources. | 
					
						
							|  |  |  |    ;; (default 'always) | 
					
						
							|  |  |  |    dotspacemacs-helm-use-fuzzy 'always | 
					
						
							|  |  |  |    ;; If non nil the paste micro-state is enabled. When enabled pressing `p` | 
					
						
							|  |  |  |    ;; several times cycle between the kill ring content. (default nil) | 
					
						
							|  |  |  |    dotspacemacs-enable-paste-transient-state nil | 
					
						
							|  |  |  |    ;; Which-key delay in seconds. The which-key buffer is the popup listing | 
					
						
							|  |  |  |    ;; the commands bound to the current keystroke sequence. (default 0.4) | 
					
						
							|  |  |  |    dotspacemacs-which-key-delay 0.4 | 
					
						
							|  |  |  |    ;; Which-key frame position. Possible values are `right', `bottom' and | 
					
						
							|  |  |  |    ;; `right-then-bottom'. right-then-bottom tries to display the frame to the | 
					
						
							|  |  |  |    ;; right; if there is insufficient space it displays it at the bottom. | 
					
						
							|  |  |  |    ;; (default 'bottom) | 
					
						
							|  |  |  |    dotspacemacs-which-key-position 'bottom | 
					
						
							|  |  |  |    ;; 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. (default t) | 
					
						
							|  |  |  |    dotspacemacs-loading-progress-bar t | 
					
						
							|  |  |  |    ;; If non nil the frame is fullscreen when Emacs starts up. (default nil) | 
					
						
							|  |  |  |    ;; (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. (default nil) | 
					
						
							|  |  |  |    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. | 
					
						
							|  |  |  |    ;; (default 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'. (default 90) | 
					
						
							|  |  |  |    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'. (default 90) | 
					
						
							|  |  |  |    dotspacemacs-inactive-transparency 90 | 
					
						
							|  |  |  |    ;; If non nil show the titles of transient states. (default t) | 
					
						
							|  |  |  |    dotspacemacs-show-transient-state-title t | 
					
						
							|  |  |  |    ;; If non nil show the color guide hint for transient state keys. (default t) | 
					
						
							|  |  |  |    dotspacemacs-show-transient-state-color-guide t | 
					
						
							|  |  |  |    ;; If non nil unicode symbols are displayed in the mode line. (default t) | 
					
						
							|  |  |  |    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 point | 
					
						
							|  |  |  |    ;; when it reaches the top or bottom of the screen. (default t) | 
					
						
							|  |  |  |    dotspacemacs-smooth-scrolling t | 
					
						
							|  |  |  |    ;; Control line numbers activation. | 
					
						
							|  |  |  |    ;; If set to `t' or `relative' line numbers are turned on in all `prog-mode' and | 
					
						
							|  |  |  |    ;; `text-mode' derivatives. If set to `relative', line numbers are relative. | 
					
						
							|  |  |  |    ;; This variable can also be set to a property list for finer control: | 
					
						
							|  |  |  |    ;; '(:relative nil | 
					
						
							|  |  |  |    ;;   :disabled-for-modes dired-mode | 
					
						
							|  |  |  |    ;;                       doc-view-mode | 
					
						
							|  |  |  |    ;;                       markdown-mode | 
					
						
							|  |  |  |    ;;                       org-mode | 
					
						
							|  |  |  |    ;;                       pdf-view-mode | 
					
						
							|  |  |  |    ;;                       text-mode | 
					
						
							|  |  |  |    ;;   :size-limit-kb 1000) | 
					
						
							|  |  |  |    ;; (default nil) | 
					
						
							|  |  |  |    dotspacemacs-line-numbers t | 
					
						
							|  |  |  |    ;; Code folding method. Possible values are `evil' and `origami'. | 
					
						
							|  |  |  |    ;; (default 'evil) | 
					
						
							|  |  |  |    dotspacemacs-folding-method 'evil | 
					
						
							|  |  |  |    ;; If non-nil smartparens-strict-mode will be enabled in programming modes. | 
					
						
							|  |  |  |    ;; (default nil) | 
					
						
							|  |  |  |    dotspacemacs-smartparens-strict-mode nil | 
					
						
							|  |  |  |    ;; If non-nil pressing the closing parenthesis `)' key in insert mode passes | 
					
						
							|  |  |  |    ;; over any automatically added closing parenthesis, bracket, quote, etc… | 
					
						
							|  |  |  |    ;; This can be temporary disabled by pressing `C-q' before `)'. (default nil) | 
					
						
							|  |  |  |    dotspacemacs-smart-closing-parenthesis nil | 
					
						
							|  |  |  |    ;; Select a scope to highlight delimiters. Possible values are `any', | 
					
						
							|  |  |  |    ;; `current', `all' or `nil'. Default is `all' (highlight any scope and | 
					
						
							|  |  |  |    ;; emphasis the current one). (default 'all) | 
					
						
							|  |  |  |    dotspacemacs-highlight-delimiters 'all | 
					
						
							|  |  |  |    ;; If non nil, advise quit functions to keep server open when quitting. | 
					
						
							|  |  |  |    ;; (default nil) | 
					
						
							|  |  |  |    dotspacemacs-persistent-server nil | 
					
						
							|  |  |  |    ;; List of search tool executable names. Spacemacs uses the first installed | 
					
						
							|  |  |  |    ;; tool of the list. Supported tools are `ag', `pt', `ack' and `grep'. | 
					
						
							|  |  |  |    ;; (default '("ag" "pt" "ack" "grep")) | 
					
						
							|  |  |  |    dotspacemacs-search-tools '("ag" "pt" "ack" "grep") | 
					
						
							|  |  |  |    ;; The default package repository used if no explicit repository has been | 
					
						
							|  |  |  |    ;; specified with an installed package. | 
					
						
							|  |  |  |    ;; Not used for now. (default nil) | 
					
						
							|  |  |  |    dotspacemacs-default-package-repository nil | 
					
						
							|  |  |  |    ;; Delete whitespace while saving buffer. Possible values are `all' | 
					
						
							|  |  |  |    ;; to aggressively delete empty line and long sequences of whitespace, | 
					
						
							|  |  |  |    ;; `trailing' to delete only the whitespace at end of lines, `changed'to | 
					
						
							|  |  |  |    ;; delete only whitespace for changed lines or `nil' to disable cleanup. | 
					
						
							|  |  |  |    ;; (default nil) | 
					
						
							|  |  |  |    dotspacemacs-whitespace-cleanup nil)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (defun dotspacemacs/user-init () | 
					
						
							|  |  |  |   "Initialization function for user code. | 
					
						
							|  |  |  | It is called immediately after `dotspacemacs/init', before layer configuration | 
					
						
							|  |  |  | executes. | 
					
						
							|  |  |  |  This function is mostly useful for variables that need to be set | 
					
						
							|  |  |  | before packages are loaded. If you are unsure, you should try in setting them in | 
					
						
							|  |  |  | `dotspacemacs/user-config' first." | 
					
						
							|  |  |  |   (setq configuration-layer--elpa-archives | 
					
						
							|  |  |  |         '(("gnu-cn" . "http://mirrors.tuna.tsinghua.edu.cn/elpa/gnu/") | 
					
						
							|  |  |  |           ("org-cn"   . "http://mirrors.tuna.tsinghua.edu.cn/elpa/org/") | 
					
						
							|  |  |  |           ("melpa-cn"   . "http://mirrors.tuna.tsinghua.edu.cn/elpa/melpa/")))  | 
					
						
							|  |  |  |   ;; load slime helper ffor quicklisp  | 
					
						
							|  |  |  |   (let ((quicklisp-slime-helper (expand-file-name "~/quicklisp/slime-helper.el"))) | 
					
						
							|  |  |  |     (when (file-exists-p quicklisp-slime-helper) | 
					
						
							|  |  |  |       (load quicklisp-slime-helper))) | 
					
						
							|  |  |  |   (setq slime-lisp-implementations | 
					
						
							|  |  |  |         '((cmucl ("cmucl" "-quiet")) | 
					
						
							|  |  |  |           (sbcl ("sbcl" "--dynamic-space-size" "2560") :coding-system utf-8-unix))) | 
					
						
							|  |  |  |   (setq slime-default-lisp 'sbcl) | 
					
						
							|  |  |  |   (load-local-config ".user-init") | 
					
						
							|  |  |  |   (add-hook 'org-mode-hook | 
					
						
							|  |  |  |             #'(lambda () | 
					
						
							|  |  |  |                 (auto-fill-mode)))) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | (defun dotspacemacs/user-config () | 
					
						
							|  |  |  |   "Configuration function for user code. | 
					
						
							|  |  |  | This function is called at the very end of Spacemacs initialization after | 
					
						
							|  |  |  | layers configuration. | 
					
						
							|  |  |  | This is the place where most of your configurations should be done. Unless it is | 
					
						
							|  |  |  | explicitly specified that a variable should be set before a package is loaded, | 
					
						
							|  |  |  | you should place your code here." | 
					
						
							|  |  |  |   (add-hook 'doc-view-mode-hook 'auto-revert-mode) | 
					
						
							|  |  |  |   (global-visual-line-mode 1) | 
					
						
							|  |  |  |   (setq dired-guess-shell-alist-user | 
					
						
							|  |  |  |         (list (list "\\.pdf$" '(cond | 
					
						
							|  |  |  |                                 ((eq system-type 'darwin) "open") | 
					
						
							|  |  |  |                                 ((eq system-type 'windows-nt) "acroreader") | 
					
						
							|  |  |  |                                 (t "FoxitReader"))))) | 
					
						
							|  |  |  |   (add-to-list 'auto-mode-alist '("\\.Rmd$" . markdown-mode)) | 
					
						
							|  |  |  |   (global-visual-line-mode 1)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ;; Do not write anything past this comment. This is where Emacs will | 
					
						
							|  |  |  | ;; auto-generate custom variable definitions. | 
					
						
							|  |  |  | (custom-set-variables | 
					
						
							|  |  |  |  ;; custom-set-variables was added by Custom. | 
					
						
							|  |  |  |  ;; If you edit it by hand, you could mess it up, so be careful. | 
					
						
							|  |  |  |  ;; Your init file should contain only one such instance. | 
					
						
							|  |  |  |  ;; If there is more than one, they won't work right. | 
					
						
							|  |  |  |  '(blink-cursor-mode nil) | 
					
						
							|  |  |  |  '(c-basic-offset 4) | 
					
						
							|  |  |  |  '(c-block-comment-prefix "* ") | 
					
						
							|  |  |  |  '(c-comment-prefix-regexp | 
					
						
							|  |  |  |    (quote | 
					
						
							|  |  |  |     ((pike-mode . "//+!?\\|\\**") | 
					
						
							|  |  |  |      (awk-mode . "#+") | 
					
						
							|  |  |  |      (other . "//+\\|\\**")))) | 
					
						
							|  |  |  |  '(c-default-style | 
					
						
							|  |  |  |    (quote | 
					
						
							|  |  |  |     ((java-mode . "java") | 
					
						
							|  |  |  |      (awk-mode . "awk") | 
					
						
							|  |  |  |      (other . "gnu")))) | 
					
						
							|  |  |  |  '(column-number-mode t) | 
					
						
							|  |  |  |  '(debug-on-error t) | 
					
						
							|  |  |  |  '(exec-path-from-shell-arguments (quote ("-l"))) | 
					
						
							|  |  |  |  '(helm-popup-tip-mode t) | 
					
						
							|  |  |  |  '(org-babel-ditaa-java-cmd (find-java)) | 
					
						
							|  |  |  |  '(org-babel-load-languages | 
					
						
							|  |  |  |    (quote | 
					
						
							|  |  |  |     ((emacs-lisp . t) | 
					
						
							|  |  |  |      (awk . t) | 
					
						
							|  |  |  |      (plantuml . t) | 
					
						
							|  |  |  |      (ditaa . t) | 
					
						
							|  |  |  |      (dot . t) | 
					
						
							|  |  |  |      (gnuplot . t) | 
					
						
							|  |  |  |      (mscgen . t) | 
					
						
							|  |  |  |      (maxima . t) | 
					
						
							|  |  |  |      (octave . t) | 
					
						
							|  |  |  |      (shell . t) | 
					
						
							|  |  |  |      (org . t) | 
					
						
							|  |  |  |      (latex . t) | 
					
						
							|  |  |  |      (C . t) | 
					
						
							|  |  |  |      (mermaid . t) | 
					
						
							|  |  |  |      (R . t)))) | 
					
						
							|  |  |  |  '(org-babel-tangle-lang-exts | 
					
						
							|  |  |  |    (quote | 
					
						
							|  |  |  |     (("awk" . "awk") | 
					
						
							|  |  |  |      ("ruby" . "rb") | 
					
						
							|  |  |  |      ("python" . "py") | 
					
						
							|  |  |  |      ("picolisp" . "l") | 
					
						
							|  |  |  |      ("ocaml" . "ml") | 
					
						
							|  |  |  |      ("maxima" . "max") | 
					
						
							|  |  |  |      ("lisp" . "lisp") | 
					
						
							|  |  |  |      ("latex" . "tex") | 
					
						
							|  |  |  |      ("emacs-lisp" . "el") | 
					
						
							|  |  |  |      ("elisp" . "el") | 
					
						
							|  |  |  |      ("mermaid" . "mmd")))) | 
					
						
							|  |  |  |  '(org-confirm-babel-evaluate nil) | 
					
						
							| 
									
										
										
										
											2018-04-07 10:57:46 +08:00
										 |  |  |  '(org-ditaa-eps-jar-path "~/workenv/emacs/jars/DitaaEps.jar") | 
					
						
							|  |  |  |  '(org-ditaa-jar-path "~/workenv/emacs/jars/ditaa.jar") | 
					
						
							| 
									
										
										
										
											2018-04-07 10:45:42 +08:00
										 |  |  |  '(org-modules | 
					
						
							|  |  |  |    (quote | 
					
						
							|  |  |  |     (org-bbdb org-bibtex org-docview org-gnus org-info org-irc org-mhe org-rmail org-w3m org-choose org-depend org-learn org-toc))) | 
					
						
							| 
									
										
										
										
											2018-04-07 10:57:46 +08:00
										 |  |  |  '(org-plantuml-jar-path "~/workenv/emacs/jars/plantuml.jar") | 
					
						
							| 
									
										
										
										
											2018-04-07 10:45:42 +08:00
										 |  |  |  '(package-selected-packages | 
					
						
							|  |  |  |    (quote | 
					
						
							|  |  |  |     (company-lsp lsp-ui cquery lsp-mode white-sand-theme rebecca-theme org-plus-contrib org-mime intero hlint-refactor hindent helm-hoogle haskell-snippets flycheck-haskell exotica-theme ghub let-alist company-ghci company-ghc ghc haskell-mode cmm-mode go-guru go-eldoc go-mode vmd-mode ox-epub vlfi pyim pyim-basedict org-category-capture graphviz-dot-mode yaml-mode polymode orgit org-dotemacs ox-tufte winum unfill solarized-theme madhat2r-theme fuzzy csv-mode engine-mode vlf telephone-line autothemer slime-company insert-shebang hide-comnt web-mode tagedit slim-mode scss-mode sass-mode pug-mode less-css-mode helm-css-scss haml-mode emmet-mode company-web web-completion-data pollen-mode geiser cdlatex origami xterm-color shell-pop multi-term helm-company helm-c-yasnippet eshell-z eshell-prompt-extras esh-help company-tern dash-functional company-statistics company-shell company-emoji company-c-headers company-auctex company-anaconda common-lisp-snippets auto-yasnippet ac-ispell auto-complete names chinese-word-at-point caml faceup powerline spinner alert log4e gntp markdown-mode macrostep skewer-mode simple-httpd json-snatcher json-reformat multiple-cursors js2-mode hydra parent-mode projectile request gitignore-mode fringe-helper git-gutter+ git-gutter gh marshal logito pcache ht flyspell-correct flycheck pkg-info epl flx magit magit-popup git-commit with-editor smartparens iedit anzu evil goto-chg undo-tree highlight ctable ess julia-mode company yasnippet sbt-mode scala-mode diminish chinese-pyim-basedict pos-tip bind-map bind-key packed auctex pythonic f dash s markup-faces pinyinlib ace-jump-mode helm avy helm-core popup async package-build tern zonokai-theme zenburn-theme zen-and-art-theme youdao-dictionary yapfify ws-butler window-numbering which-key web-beautify volatile-highlights vi-tilde-fringe uuidgen utop use-package underwater-theme ujelly-theme twilight-theme twilight-bright-theme twilight-anti-bright-theme tuareg tronesque-theme toxi-theme toc-org tao-theme tangotango-theme tango-plus-theme tango-2-theme sunny-day-theme sublime-themes subatomic256-theme subatomic-theme stickyfunc-enhance stekene-theme srefactor spacemacs-theme spaceline spacegray-theme soothe-theme soft-stone-theme soft-morning-theme soft-charcoal-theme smyx-theme smeargle slime seti-theme reverse-theme restart-emacs rainbow-mode rainbow-identifiers rainbow-delimiters railscasts-theme racket-mode quelpa pyvenv pytest pyenv-mode py-isort purple-haze-theme professional-theme popwin planet-theme pip-requirements phoenix-dark-pink-theme phoenix-dark-mono-theme persp-mode pcre2el pastels-on-dark-theme paradox pangu-spacing ox-gfm organic-green-theme org-projectile org-present org-pomodoro org-download org-bullets open-junk-file omtose-phellack-theme oldlace-theme ocp-indent occidental-theme obsidian-theme noflet noctilux-theme niflheim-theme neotree naquadah-theme mwim mustang-theme move-text monokai-theme monochrome-theme molokai-theme moe-theme mmm-mode minimal-theme merlin material-theme markdown-toc majapahit-theme magit-gitflow magit-gh-pulls lush-theme lorem-ipsum livid-mode live-py-mode linum-relative link-hint light-soap-theme json-mode js2-refactor js-doc jbeans-theme jazz-theme ir-black-theme inkpot-theme info+ indent-guide ido-vertical-mode hy-mode hungry-delete htmlize hl-todo highlight-parentheses highlight-numbers highlight-indentation heroku-theme hemisu-theme help-fns+ helm-themes helm-swoop helm-pydoc helm-projectile helm-mode-manager helm-make helm-gtags helm-gitignore helm-flx helm-descbinds helm-ag hc-zenburn-theme gruvbox-theme gruber-darker-theme grandshell-theme gotham-theme google-translate google-c-style golden-ratio gnuplot github-search github-clone github-browse-file gitconfig-mode gitattributes-mode git-timemachine git-messenger git-link git-gutter-fringe git-gutter-fringe+ gist gh-md ggtags gandalf-theme flyspell-correct-helm flycheck-pos-tip flx-ido flatui-theme flatland-theme fish-mode firebelly-theme find-by-pinyin-dired fill-column-indicator farmhouse-theme fancy-battery eyebrowse expand-region exec-path-from- | 
					
						
							|  |  |  |  '(paradox-github-token t) | 
					
						
							|  |  |  |  '(tool-bar-mode nil) | 
					
						
							|  |  |  |  '(url-configuration-directory "/usr/home/rshen/.emacs.d/.cache/url/" t) | 
					
						
							|  |  |  |  '(url-cookie-file "/usr/home/rshen/.emacs.d/.cache/url/cookies") | 
					
						
							|  |  |  |  '(url-history-file "/usr/home/rshen/.emacs.d/.cache/url/history")) | 
					
						
							|  |  |  | (custom-set-faces | 
					
						
							|  |  |  |  ;; custom-set-faces was added by Custom. | 
					
						
							|  |  |  |  ;; If you edit it by hand, you could mess it up, so be careful. | 
					
						
							|  |  |  |  ;; Your init file should contain only one such instance. | 
					
						
							|  |  |  |  ;; If there is more than one, they won't work right. | 
					
						
							|  |  |  |  '(default ((t (:family "Inconsolata LGC" :foundry "nil" :slant normal :weight normal :height 140 :width normal))))) |