X-Git-Url: http://47.100.26.94:8080/?a=blobdiff_plain;f=emacs.d_2%2Fconfig.org;h=ea05da6e0592c7ea542fb2ab1d3e9304893b5954;hb=254309ce28de5bea8a405f03f507b761a2bc2d72;hp=2d3aab5bbfadef83cdaa54160b523ec7965ea165;hpb=7e46d5b458f5af000cdac12212e699805cf60b9c;p=dotfiles.git diff --git a/emacs.d_2/config.org b/emacs.d_2/config.org index 2d3aab5..ea05da6 100644 --- a/emacs.d_2/config.org +++ b/emacs.d_2/config.org @@ -4,7 +4,7 @@ * Introduction -Most config are just copied from [[https://github.com/howardabrams/dot-files][howardabrams]]'s dotfiles +Most config are just copied from [[https://github.com/howardabrams/dot-files][howardabrams]]'s and [[https://github.com/abo-abo/oremacs][abo-abo's]] dotfiles * Basic Settings @@ -39,7 +39,7 @@ Disable scroll bar, tool-bar and menu-bar (scroll-bar-mode 0) (tool-bar-mode 0) - (menu-bar-mode 0) + (menu-bar-mode 1) (setq debug-on-error t) (setq inhibit-startup-message t) @@ -47,9 +47,13 @@ Disable scroll bar, tool-bar and menu-bar (defalias 'yes-or-no-p 'y-or-n-p) (show-paren-mode 1) + (global-set-key (kbd "") 'toggle-frame-fullscreen) + #+END_SRC -* Use-package +* Package Management Tools + +** Use-package Using [[https://github.com/jwiegley/use-package][use-package]] to manage emacs packages @@ -63,6 +67,20 @@ Using [[https://github.com/jwiegley/use-package][use-package]] to manage emacs p #+END_SRC +** El-get + +[[https://github.com/dimitri/el-get][El-get]] is package management tool, whicl allows to install external elisp package from any git repository not in mepla. +Check out [[http://tapoueh.org/emacs/el-get.html][el-get]]. + +#+BEGIN_SRC emacs-lisp :tangle yes :results silent + + (use-package el-get + :ensure t + :init + (add-to-list 'load-path "~/.emacs.d/el-get")) + +#+END_SRC + * Color and Fonts Settings ** highlight current line @@ -116,7 +134,7 @@ Setting the fonts (if window-system (when sd/fixed-font-family (set-frame-font sd/fixed-font-family) - (set-face-attribute 'default nil :font sd/fixed-font-family :height 140) + (set-face-attribute 'default nil :font sd/fixed-font-family :height 120) (set-face-font 'default sd/fixed-font-family))) #+END_SRC @@ -237,17 +255,22 @@ Always indents header, and hide header leading starts so that no need type =#+ST #+BEGIN_SRC emacs-lisp :tangle yes :results silent - + (use-package org + :ensure t + :init (setq org-startup-indented t) (setq org-hide-leading-starts t) (setq org-src-fontify-natively t) (setq org-src-tab-acts-natively t) (setq org-confirm-babel-evaluate nil) + (setq org-use-speed-commands t) + (setq org-completion-use-ido t)) (org-babel-do-load-languages 'org-babel-load-languages '((python . t) (C . t) + (perl . t) (calc . t) (latex . t) (java . t) @@ -258,10 +281,6 @@ Always indents header, and hide header leading starts so that no need type =#+ST (sqlite . t) (js . t))) - (setq org-use-speed-commands t - org-completion-use-ido t) - - #+END_SRC ** Org-bullets @@ -281,17 +300,25 @@ use [[https://github.com/sabof/org-bullets][org-bullets]] package to show utf-8 ** Worf Mode -[[https://github.com/abo-abo/worf][worf]] mode is an extension of vi-like binding for org-mode +[[https://github.com/abo-abo/worf][worf]] mode is an extension of vi-like binding for org-mode. +In =worf-mode=, it is mapping =[=, =]= as =worf-backward= and =worf-forward= in global, wich +cause we cannot input =[= and =]=, so here I unset this mappings. And redifined this two to +=M-[= and =M-]=. see this [[https://github.com/abo-abo/worf/issues/19#issuecomment-223756599][issue]] #+BEGIN_SRC emacs-lisp :tangle yes :results silent (use-package worf :ensure t :commands worf-mode - :init (add-hook 'org-mode-hook 'worf-mode)) - + :init (add-hook 'org-mode-hook 'worf-mode) + :config + (define-key worf-mode-map "[" nil) + (define-key worf-mode-map "]" nil) + (define-key worf-mode-map (kbd "M-[") 'worf-backward) + (define-key worf-mode-map (kbd "M-]") 'worf-forward)) #+END_SRC + ** Task Management ** Capture @@ -368,6 +395,107 @@ use [[https://github.com/sabof/org-bullets][org-bullets]] package to show utf-8 * Misc Settings +** [[https://github.com/abo-abo/hydra][Hydra]] + +#+BEGIN_SRC emacs-lisp :tangle yes :results silent + + (use-package hydra + :ensure t) + +#+END_SRC + +*** Font Zoom + +#+BEGIN_SRC emacs-lisp :tangle yes :results silent + + (defhydra sd/font-zoom (global-map "") + "zoom" + ("g" text-scale-increase "in") + ("l" text-scale-decrease "out")) + +#+END_SRC + +*** Windmove Splitter + +Refer [[https://github.com/abo-abo/hydra/blob/master/hydra-examples.el][hydra-example]], to enlarge or shrink the windows splitter + +#+BEGIN_SRC emacs-lisp :tangle yes :results silent + + (defun hydra-move-splitter-left (arg) + "Move window splitter left." + (interactive "p") + (if (let ((windmove-wrap-around)) + (windmove-find-other-window 'right)) + (shrink-window-horizontally arg) + (enlarge-window-horizontally arg))) + + (defun hydra-move-splitter-right (arg) + "Move window splitter right." + (interactive "p") + (if (let ((windmove-wrap-around)) + (windmove-find-other-window 'right)) + (enlarge-window-horizontally arg) + (shrink-window-horizontally arg))) + + (defun hydra-move-splitter-up (arg) + "Move window splitter up." + (interactive "p") + (if (let ((windmove-wrap-around)) + (windmove-find-other-window 'up)) + (enlarge-window arg) + (shrink-window arg))) + + (defun hydra-move-splitter-down (arg) + "Move window splitter down." + (interactive "p") + (if (let ((windmove-wrap-around)) + (windmove-find-other-window 'up)) + (shrink-window arg) + (enlarge-window arg))) + +#+END_SRC + +*** hydra-window + +#+BEGIN_SRC emacs-lisp :tangle yes :results silent + + (winner-mode 1) + + (defhydra sd/hydra-window (:color red :columns nil) + "window" + ("h" windmove-left nil) + ("j" windmove-down nil) + ("k" windmove-up nil) + ("l" windmove-right nil) + ("H" hydra-move-splitter-left nil) + ("J" hydra-move-splitter-down nil) + ("K" hydra-move-splitter-up nil) + ("L" hydra-move-splitter-right nil) + ("v" (lambda () + (interactive) + (split-window-right) + (windmove-right)) + "vert") + ("x" (lambda () + (interactive) + (split-window-below) + (windmove-down)) + "horz") + ("o" delete-other-windows "one" :exit t) + ("a" ace-window "ace") + ("s" ace-swap-window "swap") + ("d" ace-delete-window "ace-one" :exit t) + ("i" ace-maximize-window "ace-one" :exit t) + ("b" ido-switch-buffer "buf") + ("m" headlong-bookmark-jump "bmk") + ("q" nil "cancel") + ("u" (progn (winner-undo) (setq this-command 'winner-undo)) "undo") + ("f" nil)) + + (global-set-key (kbd "M-o") 'sd/hydra-window/body) + +#+END_SRC + ** Line Number Enable linum mode on programming modes @@ -424,19 +552,69 @@ I like [[https://github.com/coldnew/linum-relative][linum-relative]], just like #+END_SRC -* Eshell Setting +** Multi-term + +#+BEGIN_SRC emacs-lisp :tangle yes :results silent + + (use-package multi-term + :ensure t) + +#+END_SRC + +** ace-link + +[[https://github.com/abo-abo/ace-link][ace-link]] is a package written by [[https://github.com/abo-abo][Oleh Krehel]]. It is convenient to jump to link in help mode, info-mode, etc +Type =o= to go to the link + +#+BEGIN_SRC emacs-lisp :tangle yes :results silent + + (use-package ace-link + :ensure t + :init + (ace-link-setup-default)) + +#+END_SRC + +** Emux + +[[https://github.com/re5et/emux][emux]] is + +#+BEGIN_SRC emacs-lisp :tangle yes :results silent + + (el-get-bundle re5et/emux) + +#+END_SRC + +** Smart Parens + +#+BEGIN_SRC emacs-lisp :tangle yes :results silent + + (use-package smartparens + :ensure t) + +#+END_SRC + +** Ace-Windows -Setting PATH environment variable +[[https://github.com/abo-abo/ace-window][ace-window]] #+BEGIN_SRC emacs-lisp :tangle yes :results silent - (setenv "PATH" (concat (getenv "PATH") ":/usr/local/bin")) + (use-package ace-window + :ensure t + :defer t + ; :init + ; (global-set-key (kbd "M-o") 'ace-window) + :config + (setq aw-keys '(?a ?s ?d ?f ?j ?k ?l))) #+END_SRC -* Programming Languages +* Programming + +** Languages -** Emacs Lisp +*** Emacs Lisp #+BEGIN_SRC emacs-lisp :tangle yes :results silent @@ -444,14 +622,159 @@ Setting PATH environment variable :ensure t :init (add-hook 'emacs-lisp-mode-hook 'color-identifiers-mode) + :diminish color-identifiers-mode) #+END_SRC -* Others +*** Perl + +[[https://www.emacswiki.org/emacs/CPerlMode][CPerl mode]] has more features than =PerlMode= for perl programming. Alias this to =CPerlMode= + +#+BEGIN_SRC emacs-lisp :tangle yes :results silent + + (defalias 'perl-mode 'cperl-mode) + + ;(setq cperl-hairy t) ;; Turns on most of the CPerlMode options + (setq cperl-auto-newline t) + (setq cperl-highlight-variables-indiscriminately t) + ;(setq cperl-indent-level 4) + ;(setq cperl-continued-statement-offset 4) + (setq cperl-close-paren-offset -4) + (setq cperl-indent-parents-as-block t) + (setq cperl-tab-always-indent t) + ;(setq cperl-brace-offset 0) + + (add-hook 'cperl-mode-hook + '(lambda () + (cperl-set-style "C++"))) + + ;(require 'template) + ;(template-initialize) + ;(require 'perlnow) + +#+END_SRC + +- auto insert +- run script + +Change the compile-command to set the default command run when call =compile= +Mapping =s-r= (on Mac, it's =Command + R= to run the script. Here =current-prefix-arg= is set +to call =compilation= interactively. + +#+BEGIN_SRC emacs-lisp :tangle yes :results silent + + (defun my-perl-hook () + (progn + (setq-local compilation-read-command nil) + (set (make-local-variable 'compile-command) + (concat "/usr/bin/perl " + (if buffer-file-name + (shell-quote-argument buffer-file-name)))) + (local-set-key (kbd "s-r") + (lambda () + (interactive) + ; (setq current-prefix-arg '(4)) ; C-u + (call-interactively 'compile))))) + + (add-hook 'cperl-mode-hook 'my-perl-hook) + + +#+END_SRC + +*** C & C++ + +#+BEGIN_SRC emacs-lisp :tangle yes :results silent + + (setq c-default-style "stroustrup" + c-basic-offset 4) + +#+END_SRC + +** Compile + +Set the environments vairables in compilation mode + +#+BEGIN_SRC emacs-lisp :tangle yes :results silent + + (use-package compile + :commands compile + :config + (setq compilation-environment (cons "LC_ALL=C" compilation-environment))) + +#+END_SRC + +** Auto-Insert + +Enable auto-insert mode -** Shell pop mode +#+BEGIN_SRC emacs-lisp :tangle yes :results silenc + + (auto-insert-mode t) + (setq auto-insert-query nil) + +#+END_SRC + +*** C++ Auto Insert + +#+BEGIN_SRC emacs-lisp :tangle yes :results silent + + (eval-after-load 'autoinsert + '(define-auto-insert '("\\.cpp\\'" . "C++ skeleton") + '( + "Short description:" + "/*" + "\n * " (file-name-nondirectory (buffer-file-name)) + "\n */" > \n \n + "#include " \n + "#include \"" + (file-name-sans-extension + (file-name-nondirectory (buffer-file-name))) + ".hpp\"" \n \n + "using namespace std;" \n \n + "int main ()" + "\n{" \n + > _ \n + "return 1;" + "\n}" > \n + ))) + + (eval-after-load 'autoinsert + '(define-auto-insert '("\\.c\\'" . "C skeleton") + '( + "Short description:" + "/*\n" + " * " (file-name-nondirectory (buffer-file-name)) "\n" + " */" > \n \n + "#include " \n + "#include \"" + (file-name-sans-extension + (file-name-nondirectory (buffer-file-name))) + ".h\"" \n \n + "int main ()\n" + "{" \n + > _ \n + "return 1;\n" + "}" > \n + ))) + +#+END_SRC + +*** Perl Auto Insert + +Refer [[https://www.emacswiki.org/emacs/AutoInsertMode][AutoInsertMode]] Wiki + +#+BEGIN_SRC emacs-lisp :tangle yes :results silent + + (eval-after-load 'autoinsert + '(define-auto-insert '("\\.pl\\'" . "Perl skeleton") + '( + "Description: " + "#!/usr/bin/perl -w" \n + \n + "use strict;" \n \n + ))) + +#+END_SRC -** Smartparens mode -**