summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Tom Willemsen2013-01-03 23:55:57 +0100
committerGravatar Tom Willemsen2013-01-03 23:55:57 +0100
commit5b4684f3356b0394925b2f783e5e98f0632012c1 (patch)
treeb4f875e0ceed0da06cc4025de2b730c8fd5cbd95
parentf4fdaef0eea5305433faa7f7e4cee1584385108e (diff)
downloaddotfiles-5b4684f3356b0394925b2f783e5e98f0632012c1.tar.gz
dotfiles-5b4684f3356b0394925b2f783e5e98f0632012c1.zip
Emacs: Start with literate configuration again
-rw-r--r--.emacs.d/init.el40
-rw-r--r--.emacs.d/init.org315
2 files changed, 316 insertions, 39 deletions
diff --git a/.emacs.d/init.el b/.emacs.d/init.el
index d1e8c50..e0e73f1 100644
--- a/.emacs.d/init.el
+++ b/.emacs.d/init.el
@@ -6,45 +6,7 @@
;;; Code:
-(eval-and-compile
- (package-initialize)
-
- (mapc #'(lambda (directory)
- (add-to-list 'load-path directory)
- (let ((default-directory directory))
- (normal-top-level-add-subdirs-to-load-path)))
- '("/usr/share/emacs/site-lisp" "~/.emacs.d/site-lisp"
- "/usr/local/emacs/share/emacs/site-lisp"))
- (mapc #'(lambda (directory)
- (add-to-list 'load-path directory)
- (let ((loaddefs (concat directory "/loaddefs.el")))
- (when (file-exists-p loaddefs)
- (load loaddefs))))
- '("~/var/src/emacs/dispass.el" "~/var/src/emacs/mode-icons"))
- (mapc #'(lambda (dir)
- (add-to-list 'custom-theme-load-path dir))
- '("~/var/src/emacs/yoshi-theme")))
-
-(require 'auto-complete-config)
-(require 'ext)
-(require 'geiser-install)
-(require 'oni)
-(require 'uniquify)
-
-(autoload 'define-slime-contrib "slime")
-(autoload 'gtags-mode "gtags" nil t)
-(autoload 'jabber-connect "jabber" nil t)
-(autoload 'php-mode "php-mode" nil t)
-(autoload 'po-mode "po-mode" nil t)
-(autoload 'pony-mode "pony-mode" nil t)
-(autoload 'sawfish-mode "sawfish" nil t)
-(autoload 'server-running-p "server")
-(autoload 'slime-js-minor-mode "slime-js" nil t)
-(autoload 'xmodmap-mode "xmodmap-mode" nil t)
-(autoload 'w3m-bookmark-view "w3m" nil t)
-(autoload 'w3m-goto-url "w3m" nil t)
-
-(load (expand-file-name "~/.emacs.d/site-lisp/loaddefs.el"))
+(load (concat user-emacs-directory "init2"))
(define-key key-translation-map (kbd "C-j") (kbd "C-l"))
(define-key key-translation-map (kbd "C-l") (kbd "C-j"))
diff --git a/.emacs.d/init.org b/.emacs.d/init.org
new file mode 100644
index 0000000..2041f5a
--- /dev/null
+++ b/.emacs.d/init.org
@@ -0,0 +1,315 @@
+#+TITLE: Emacs init
+#+STYLE: <link href="http://ryuslash.ninth.su/test2.css" rel="stylesheet">
+#+OPTIONS: author:nil
+
+* Startup
+
+ Startup requires a bit of customization to handle all my
+ customizations.
+
+** Load paths
+
+ I have two versions of Emacs installed on my main computer. I have
+ a daily build of Emacs's ~trunk~ (or currently ~emacs-24~) branch from
+ bazaar and I have the official ~emacs~ package from archlinux
+ installed. I keep that second one around so that the occasional
+ emacs package that I install using ~pacman~ will recognize it as a
+ dependency and so that if there has been some horrible mistake in
+ the ~trunk~ branch I still have a stable version to fall back
+ on[fn:1].
+
+*** Package initialization
+
+ In order for packages installed through ELPA to be included
+ without having to mess with load paths and such, use:
+
+ #+NAME: package-initialize
+ #+BEGIN_SRC emacs-lisp
+ (package-initialize)
+ #+END_SRC
+
+*** site-lisp
+
+ Because of the setup I wrote about I need to have both the
+ self-built ~site-lisp~ directory in my load path *and* the "official"
+ one.
+
+ #+NAME: load-site-lisps
+ #+BEGIN_SRC emacs-lisp
+ (mapc #'oni:add-all-to-load-path
+ '("/usr/share/emacs/site-lisp"
+ "/usr/local/emacs/share/emacs/site-lisp"))
+ #+END_SRC
+
+ The =oni:add-all-to-load-path= function just binds =default-directory=
+ to the given directory and calls
+ =normal-top-level-add-subdirs-to-load-path= to add it and all its
+ subdirectories to the load path.
+
+ #+NAME: add-all
+ #+BEGIN_SRC emacs-lisp
+ (defun oni:add-all-to-load-path (dir)
+ (add-to-list 'load-path dir)
+ (let ((default-directory dir))
+ (normal-top-level-add-subdirs-to-load-path)))
+ #+END_SRC
+
+**** TODO Add load paths in different order depending on version
+
+ The officially installed version should load
+ =/usr/share/emacs/site-lisp= before
+ =/usr/local/emacs/share/emacs/sit-lisp= and the bzr version should
+ do the reversed.
+
+*** Projects
+
+ Then there are some projects I'm working on, which I use on a
+ daily basis, these should also be added so I don't have to
+ constantly remove and re-install them through ~package.el~ when
+ working on them. And there is the ~load-defs.el~ in my personal
+ ~site-lisp~ directory of course.
+
+ #+NAME: load-projects
+ #+BEGIN_SRC emacs-lisp
+ (mapc #'oni:add-to-load-path-maybe-load-defs
+ '("~/projects/emacs/dispass.el" "~/var/src/emacs/mode-icons"
+ "~/.emacs.d/site-lisp"))
+ #+END_SRC
+
+ The =oni:add-to-load-path-maybe-load-defs= function just adds the
+ given directory to the load path and then looks for a file named
+ ~loaddefs.el~ within that directory, if it exists it loads it.
+
+ #+NAME: add-with-loaddefs
+ #+BEGIN_SRC emacs-lisp
+ (defun oni:add-to-load-path-maybe-load-defs (dir)
+ (add-to-list 'load-path dir)
+ (let ((loaddefs (concat dir "/loaddefs.el")))
+ (when (file-exists-p loaddefs)
+ (load loaddefs))))
+ #+END_SRC
+
+*** Themes
+
+ And, finally, I'm also working on a color theme for emacs, this
+ should be added to ~custom-theme-load-path~. By using =mapc= here as
+ well I'm keeping in mind that this isn't the first theme I've
+ worked on and it might not be the last either.
+
+ #+NAME: load-themes
+ #+BEGIN_SRC emacs-lisp
+ (mapc #'oni:add-to-custom-theme-load-path
+ '("~/projects/emacs/yoshi-theme"))
+ #+END_SRC
+
+ The =oni:add-to-custom-theme-load-path= just adds the given
+ directory to the cutom theme load path.
+
+ #+NAME: add-themes
+ #+BEGIN_SRC emacs-lisp
+ (defun oni:add-to-custom-theme-load-path (dir)
+ (add-to-list 'custom-theme-load-path dir))
+ #+END_SRC
+
+*** Evaluation
+
+ Because during byte-compilation certain parts loaded so far might
+ also be required I put it in an =eval-and-compile= form, so that all
+ components are loaded with ~emacs -Q~ as well. Without this
+ compilation might fail at certain points.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el :noweb yes
+ (eval-and-compile
+ <<add-all>>
+
+ <<add-with-loaddefs>>
+
+ <<add-themes>>
+
+ <<package-initialize>>
+ <<load-site-lisps>>
+ <<load-projects>>
+ <<load-themes>>)
+ #+END_SRC
+
+** Modules
+
+ While I try to use =eval-after-load= and =autoload= as much as
+ possible, some things require direct =require='ing to be of use.
+
+*** Require
+
+ - ~auto-complete-config~ :: This sets up some default settings to
+ make ~auto-complete~ work for most[fn:2] of the modes it
+ supports.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el
+ (require 'auto-complete-config)
+ #+END_SRC
+
+ - ~geiser-install~ :: Sets up geiser autoloads and such.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el
+ (require 'geiser-install)
+ #+END_SRC
+
+ - ~uniquify~ :: Provides more helpful buffer name uniquification.
+ The default of using ~buffer-name<2>~ is boring and
+ uninformative, ~uniquify~ fixes this.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el
+ (require 'uniquify)
+ #+END_SRC
+
+ - ~ext~ :: Functions from external sources.
+ - ~oni~ :: Functions written personally.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el
+ (require 'ext)
+ (require 'oni)
+ #+END_SRC
+
+*** Autoload
+
+ These might not be used at all in a session, so they should only
+ be loaded when necessary.
+
+ =define-slime-contrib= was used by some module that didn't autoload
+ or require it[fn:3]. But since I don't use whichever model it
+ was every day, it is of no use to load it every single time.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el
+ (autoload 'define-slime-contrib "slime")
+ #+END_SRC
+
+ I installed ~global~ with ~pacman~, but this doesn't add anything to
+ any =loaddefs.el=, so doesn't create any autoloads.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el
+ (autoload 'gtags-mode "gtags" nil t)
+ #+END_SRC
+
+ ~jabber.el~ does create ~jabber-autoloads.el~, but I only ever start
+ using it through ~jabber-connect~, so anything else isn't really
+ necessary.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el
+ (autoload 'jabber-connect "jabber" nil t)
+ #+END_SRC
+
+ I used to work a bit on ~php-mode~, but that was a while ago, so
+ it's still in my ~site-lisp~ directory.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el
+ (autoload 'php-mode "php-mode" nil t)
+ #+END_SRC
+
+ The same that goes for ~gtags.el~ also goes for ~po-mode.el~.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el
+ (autoload 'po-mode "po-mode" nil t)
+ #+END_SRC
+
+ And the same that went for ~php-mode~ also goes for ~pony-mode~,
+ except I'm still working on it and I was too lazy to put it with
+ my other projects. I should still do that.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el
+ (autoload 'pony-mode "pony-mode" nil t)
+ #+END_SRC
+
+ ~sawfish.el~ has the same problem that ~gtags.el~ and ~po-mode.el~ have.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el
+ (autoload 'sawfish-mode "sawfish" nil t)
+ #+END_SRC
+
+ I use =server-running-p= to check whether or not I should start a
+ new server, but this function isn't autoloaded by default.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el
+ (autoload 'server-running-p "server")
+ #+END_SRC
+
+ I was starting to try ~slime-js~ to make JavaScript programming
+ more interesting, but I haven't gotten around to trying it out
+ fully, yet. It shares issues with ~gtags.el~, ~po-mode.el~ and
+ ~sawfish.el~.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el
+ (autoload 'slime-js-minor-mode "slime-js" nil t)
+ #+END_SRC
+
+ I found ~xmodmap-mode~ on the [[http://emacswiki.org][EmacsWiki]] some time ago, it was
+ simple and a good example of how to use ~define-generic-mode~, but
+ since it's not really my project and it's really small it just
+ sits in my ~site-lisp~ directory.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el
+ (autoload 'xmodmap-mode "xmodmap-mode" nil t)
+ #+END_SRC
+
+ ~w3m~ also has a setup module like ~geiser-install~, but since I only
+ ever use these two functions to start it, there is no real need
+ for anything else.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el
+ (autoload 'w3m-bookmark-view "w3m" nil t)
+ (autoload 'w3m-goto-url "w3m" nil t)
+ #+END_SRC
+
+* Aliases
+
+ There are some functions that are just better than others, no
+ matter how politically incorrect it might be to admit.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el
+ (defalias 'yes-or-no-p 'y-or-n-p)
+ (defalias 'list-buffers 'ibuffer)
+ (defalias 'dabbrev-expand 'hippie-expand)
+ #+END_SRC
+
+* Faces
+
+ Define faces for use with ~magit~ log edit mode.
+
+ #+BEGIN_SRC emacs-lisp :tangle init2.el
+ (defface git-commit-summary-face
+ '((t (:inherit org-level-1)))
+ "Face for the git title line."
+ :group 'local)
+
+ (defface git-commit-overlong-summary-face
+ '((t (:background "#873732")))
+ "Face for commit titles that are too long."
+ :group 'local)
+
+ (defface git-commit-nonempty-second-line-face
+ '((t (:inherit git-commit-overlong-summary-face)))
+ "Face for the supposedly empty line in commit messages."
+ :group 'local)
+ #+END_SRC
+
+* Keys
+
+ With the awesome power of Emacs comes the need for lots of
+ keybindings.
+
+** Translation
+
+ Since the ~C-l~ combination is so much easier than ~C-j~ when using
+ the [[http://colemak.com][colemak]] keyboard layout and ~C-j~ is used so much more, switch
+ them.
+
+ #+BEGIN_SRC emacs-lisp tangle init2.el
+ (define-key key-translation-map (kbd "C-j") (kbd "C-l"))
+ (define-key key-translation-map (kbd "C-l") (kbd "C-j"))
+ #+END_SRC
+* Footnotes
+
+[fn:1] Though it doesn't happen often that ~trunk~ is so messed up that
+I can't use it.
+
+[fn:2] Or perhaps all.
+
+[fn:3] I think it was ~slime-js-minor-mode~, but I'm not sure.