summaryrefslogtreecommitdiffstats
path: root/emacs
diff options
context:
space:
mode:
authorGravatar Tom Willemsen2012-08-26 21:50:26 +0200
committerGravatar Tom Willemsen2012-08-26 21:50:26 +0200
commit8cf4fc59e7e25ca00b9691267e05b63997eaabee (patch)
tree3ee86e39f7667af20cc92a6f1512c542bbe15ee0 /emacs
parent54bf4091fde9efc3b816440f3d586a5ba72b6add (diff)
downloaddotfiles-8cf4fc59e7e25ca00b9691267e05b63997eaabee.tar.gz
dotfiles-8cf4fc59e7e25ca00b9691267e05b63997eaabee.zip
emacs
Diffstat (limited to 'emacs')
-rw-r--r--emacs/Makefile10
-rw-r--r--emacs/eshell-init.el64
-rw-r--r--emacs/init.el1511
3 files changed, 730 insertions, 855 deletions
diff --git a/emacs/Makefile b/emacs/Makefile
index 6d986ef..51a55a4 100644
--- a/emacs/Makefile
+++ b/emacs/Makefile
@@ -1,13 +1,13 @@
EMACS = emacs
-files = init.el init.elc eshell-init.el eshell-init.elc
-install-files = $(addprefix install-,$(files)) install-loaddefs.el
+files = init.el init.elc
+install-files = $(addprefix install-,$(files))
submodules = eshell
install-submodules = $(addprefix install-,$(submodules))
.PHONY: all $(submodules) install $(install-submodules) $(install-files)
-all: loaddefs.el $(files) $(submodules)
+all: $(files) $(submodules)
$(submodules):
$(MAKE) -C $@/
@@ -15,10 +15,6 @@ $(submodules):
$(filter %.elc,$(files)): %.elc: %.el
$(EMACS) -batch -eval "(byte-compile-file \"$^\")"
-loaddefs.el: $(files)
- $(EMACS) -batch -eval "(let ((generated-autoload-file \"${CURDIR}/loaddefs.el\")) \
- (update-directory-autoloads \"${CURDIR}\"))"
-
install: $(install-files) $(install-submodules)
$(install-files): install-%: $*
diff --git a/emacs/eshell-init.el b/emacs/eshell-init.el
deleted file mode 100644
index 9309b3f..0000000
--- a/emacs/eshell-init.el
+++ /dev/null
@@ -1,64 +0,0 @@
-;; Eshell settings
-(eval-when-compile
- '(load "init.el"))
-
-(eval-after-load "em-term"
- '(add-to-list 'eshell-visual-commands
- "unison"))
-
-(defun oni:eshell-mode-func ()
- "Function for `eshell-mode-hook'."
- (setq truncate-lines nil))
-
-(defun oni:eshell-prompt-function ()
- (let ((status (if (zerop eshell-last-command-status) ?+ ?-))
- (hostname (shell-command-to-string "hostname"))
- (dir (abbreviate-file-name (eshell/pwd)))
- (branch
- (shell-command-to-string
- "git branch --contains HEAD 2>/dev/null | sed -e '/^[^*]/d'"))
- (userstatus (if (zerop (user-uid)) ?# ?$)))
- (concat
- (propertize (char-to-string status)
- 'face `(:foreground ,(if (= status ?+)
- (oni:color chameleon-1)
- (oni:color scarlet-red-2))))
- " "
- (propertize (substring hostname 0 -1) 'face 'mode-line-buffer-id)
- " "
- (propertize (oni:shorten-dir dir) 'face 'font-lock-string-face)
- " "
- (when (not (string= branch ""))
- (propertize
- ;; Cut off "* " and "\n"
- (substring branch 2 -1)
- 'face 'font-lock-function-name-face))
- " \n"
- (propertize (char-to-string userstatus)
- 'face `(:foreground ,(oni:color sky-blue-1)))
- "> ")))
-
-;;;###autoload
-(defun oni:raise-eshell ()
- "Start or switch back to `eshell'. Also change directories to
- current working directory."
- (interactive)
- (let ((dir (file-name-directory
- (or (buffer-file-name) "~/")))
- (hasfile (not (eq (buffer-file-name) nil))))
- (eshell)
- (if (and hasfile (eq eshell-process-list nil))
- (progn
- (eshell/cd dir)
- (eshell-reset)))))
-
-(defun oni:shorten-dir (dir)
- "Shorten a directory, (almost) like fish does it."
- (while (string-match "\\(/\\.?[^./]\\)[^/]+/" dir)
- (setq dir (replace-match "\\1/" nil nil dir)))
- dir)
-
-(setq eshell-prompt-regexp "^[#$]> ")
-(setq eshell-highlight-prompt nil)
-(setq eshell-prompt-function 'oni:eshell-prompt-function)
-(add-hook 'eshell-mode-hook 'oni:eshell-mode-func)
diff --git a/emacs/init.el b/emacs/init.el
index 2b9594b..fb33134 100644
--- a/emacs/init.el
+++ b/emacs/init.el
@@ -1,3 +1,9 @@
+(require 'geiser-install)
+(require 'iso-transl)
+(require 'newcomment)
+(require 'uniquify)
+(require 'w3m-load)
+
(eval-and-compile
(package-initialize)
@@ -36,11 +42,26 @@
(require 'whitespace)
(require 'yasnippet))
+(autoload 'gtags-mode "gtags" nil t)
(autoload 'identica-mode "identica-mode" nil t)
(autoload 'mu4e "mu4e" nil t)
(autoload 'naquadah-get-colors "naquadah-theme")
+(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 'xmodmap-mode "xmodmap-mode" nil t)
+
(load (expand-file-name "~/.emacs.d/site-lisp/loaddefs.el"))
-(load (expand-file-name "~/.emacs.d/loaddefs.el"))
+
+(define-key key-translation-map (kbd "C-j") (kbd "C-l"))
+(define-key key-translation-map (kbd "C-l") (kbd "C-j"))
+
+(defadvice org-agenda-redo (after org-agenda-redo-add-appts)
+ "Pressing `r' on the agenda will also add appointments."
+ (progn
+ (setq appt-time-msg-list nil)
+ (org-agenda-to-appt)))
(defalias 'yes-or-no-p 'y-or-n-p)
@@ -51,6 +72,55 @@
"\\(?:\\s \\|\t\\|\n\\)\\(?:\\sw\\|_\\)+([^)]*)[^;\n]*$"))
"Regex for `outline-minor-mode' for `c-mode'.")
+(defconst oni:javascript-outline-regex "function \\(\\w\\|_\\)+("
+ "Regex for `outline-minor-mode' for `js-mode'.")
+
+(defconst oni:php-outline-regex
+ (eval-when-compile
+ (concat
+ "^ *\\(\\(?:namespace\\|interface\\) [a-zA-Z0-9_]\\|\\(\\(abstract"
+ "\\|final\\) \\)?class [a-zA-Z0-9_]+\\( extends [\\a-zA-Z0-9_]+\\)?"
+ "\\|\\(abstract \\)?\\(public\\|private\\|protected\\)?"
+ "\\( static\\)? function [a-zA-Z0-9_]+(\\|/\\*\\*\\)"))
+ "Regex for `outline-minor-mode' for `php-mode'.")
+
+(defconst oni:python-outline-regex
+ (eval-when-compile
+ (concat "^[ \t]*\\(?:@[a-zA-Z0-9_]+\\(?:([a-zA-Z0-9_=, ]*)\\)?"
+ "\n\\)*[ \t]*\\(?:\\(class\\|def\\)[ \t]+\\(\\sw\\|\\s_\\)+"
+ "\\(([^)]*):\\)?\\|\\#[ a-zA-Z0-9]*\\#\\)"))
+ "Regex for `outline-minor-mode' for `python-mode'.")
+
+(defface oni:mode-line-buffer-column
+ '((t (:inherit font-lock-type-face)))
+ "Face for the column number in the mode-line"
+ :group 'local)
+
+(defface oni:mode-line-buffer-line
+ '((t (:inherit font-lock-type-face)))
+ "Face for the line number in the mode-line"
+ :group 'local)
+
+(defface oni:mode-line-buffer-position
+ '((t (:inherit font-lock-constant-face)))
+ "Face for the buffer position in the mode-line"
+ :group 'local)
+
+(defface oni:mode-line-buffer-state
+ '((t (:inherit font-lock-preprocessor-face)))
+ "Face for the state of the buffer in the mode-line"
+ :group 'local)
+
+(defface oni:mode-line-mode
+ '((t (:inherit font-lock-string-face)))
+ "Face for the major mode in the mode-line"
+ :group 'local)
+
+(defface oni:mode-line-modified
+ '((t (:inherit font-lock-warning-face)))
+ "Face for the modified state in the mode-line"
+ :group 'local)
+
(defmacro oni:define-mailbox (name email &optional signature longname)
"Define a mailbox function."
`(defun ,(make-symbol (concat "oni:" name "-mailbox")) ()
@@ -114,6 +184,16 @@
(setq hs-adjust-block-beginning 'hs-c-like-adjust-block-beginning)
(hs-minor-mode))
+(defun oni:c-mode-func ()
+ "Function for `c-mode-hook'."
+ (local-set-key [f9] 'compile)
+ (local-set-key "\C-j" 'oni:newline-and-indent))
+
+(defun oni:close-client-window ()
+ "Close a client's frames."
+ (interactive)
+ (server-save-buffers-kill-terminal nil))
+
(defun oni:compile-el ()
"Compile the current buffer file if it is an .el file."
(let* ((full-file-name (buffer-file-name))
@@ -123,182 +203,6 @@
(string-equal suffix "el"))
(byte-compile-file full-file-name))))
-(defun oni:hs-minor-mode-func ()
- "Function for `hs-minor-mode-hook'."
- (local-set-key [C-tab] 'hs-toggle-hiding)
- (hs-hide-all))
-
-(defun oni:jabber-chat-mode-func ()
- "Function for `jabber-chat-mode-hook'."
- (visual-line-mode))
-
-(defun oni:mini-fix-timestamp-string (date-string)
- "A minimal version of Xah Lee's `fix-timestamp-string'
- function, found at http://xahlee.org/emacs/elisp_parse_time.html"
- (setq date-string (replace-regexp-in-string "Jan" "01" date-string)
- date-string (replace-regexp-in-string "Feb" "02" date-string)
- date-string (replace-regexp-in-string "Mar" "03" date-string)
- date-string (replace-regexp-in-string "Apr" "04" date-string)
- date-string (replace-regexp-in-string "May" "05" date-string)
- date-string (replace-regexp-in-string "Jun" "06" date-string)
- date-string (replace-regexp-in-string "Jul" "07" date-string)
- date-string (replace-regexp-in-string "Aug" "08" date-string)
- date-string (replace-regexp-in-string "Sep" "09" date-string)
- date-string (replace-regexp-in-string "Oct" "10" date-string)
- date-string (replace-regexp-in-string "Nov" "11" date-string)
- date-string (replace-regexp-in-string "Dec" "12" date-string))
- (string-match
- "^\\([0-9]\\{2\\}\\)-\\([0-9]\\{2\\}\\)-\\([0-9]\\{4\\}\\)$"
- date-string)
- (format "%s-%s-%s"
- (match-string 3 date-string)
- (match-string 2 date-string)
- (match-string 1 date-string)))
-
-(defun oni:myepisodes-formatter (plist)
- "Format RSS items from MyEpisodes as org tasks."
- (let ((str (plist-get plist :title)))
- (string-match
- "^\\[ \\([^\]]+\\) \\]\\[ \\([^\]]+\\) \\]\\[ \\([^\]]+\\) \\]\\[ \\([^\]]+\\) \\]$"
- str)
- (let* ((title (match-string 1 str))
- (episode (match-string 2 str))
- (name (match-string 3 str))
- (date (oni:mini-fix-timestamp-string (match-string 4 str))))
- (format "* ACQUIRE %s %s - %s <%s>" title episode name date))))
-
-(defun oni:prog-mode-func ()
- "Function for `prog-mode-hook'."
- (rainbow-delimiters-mode)
- (fci-mode)
- (pretty-symbols-mode))
-
-(defun oni:replace-html-special-chars ()
- (oni:replace-occurrences "é" "&eacute;"))
-
-(defun oni:replace-occurrences (from to)
- "Replace all occurrences of FROM with TO in the current buffer."
- (save-excursion
- (goto-char (point-min))
- (while (search-forward from nil t)
- (replace-match to))))
-
-(defun oni:required-packages-installed-p ()
- "Check if all the packages I need are installed."
- (let ((tmp-packages oni:required-packages)
- (result t))
- (while (and tmp-packages result)
- (if (not (package-installed-p (car tmp-packages)))
- (setq result nil))
- (setq tmp-packages (cdr tmp-packages)))
- result))
-
-(defun oni:view-mail ()
- "Show a menu with all mailbox options from `oni:mailbox-map'
-for easy selection."
- (interactive)
- (require 'tmm)
- (let* ((tmm-completion-prompt "Choose a mailbox\n")
- (inbox (tmm-prompt oni:mailbox-map)))
- (if inbox
- (progn
- (require 'mu4e)
- (funcall (intern (concat "oni:" inbox "-mailbox")))
- (mu4e)))))
-
-(eval-after-load "info"
- '(require 'info+))
-
-(eval-after-load "mu4e"
- '(add-to-list
- 'org-capture-templates
- '("c" "Contact" entry (file "~/documents/org/misc/contacts.org")
- (concat "* %(mu4e-view-snarf-from 'name)\n"
- " :PROPERTIES:\n"
- " :EMAIL: %(mu4e-view-snarf-from 'email)\n"
- " :END:"))))
-
-(oni:define-mailbox "aethon"
- (oni:email thomas at aethon dot nl)
- (expand-file-name "~/documents/work/aethon/signature.txt"))
-(oni:define-mailbox "gmail" (oni:email ryuslash at gmail dot com))
-(oni:define-mailbox "ninthfloor"
- (oni:email ryuslash at ninthfloor dot org))
-(oni:define-mailbox "ryuslash" (oni:email tom at ryuslash dot org)
- nil "ryuslash.org")
-
-(setq-default c-basic-offset 4)
-(setq-default fci-rule-column 73)
-
-(setq avandu-article-render-function #'avandu-view-w3m)
-(setq fci-rule-color "darkred")
-(setq inferior-lisp-program "sbcl")
-(setq jabber-account-list '(("ryuslash@jabber.org")))
-(setq jabber-chat-buffer-format "*jabber:%n*")
-(setq jabber-chat-buffer-show-avatar nil)
-(setq jabber-chat-fill-long-lines nil)
-(setq jabber-chat-foreign-prompt-format "[%t] < ")
-(setq jabber-chat-local-prompt-format "[%t] > ")
-(setq jabber-chatstates-confirm nil)
-(setq jabber-history-dir "~/.emacs.d/jabber")
-(setq jabber-roster-show-bindings nil)
-(setq mail-header-separator "")
-(setq mu4e-headers-date-format "%d-%m %H:%M")
-(setq mu4e-headers-fields '((:date . 11)
- (:flags . 6)
- (:to . 22)
- (:from . 22)
- (:subject)))
-(setq mu4e-headers-show-threads nil)
-(setq mu4e-headers-sort-revert nil)
-(setq mu4e-my-email-addresses (list
- (oni:email tom at ryuslash dot org)
- (oni:email ryuslash at gmail dot com)
- (oni:email ryuslash at ninthfloor dot org)
- (oni:email thomas at aethon dot nl)))
-(setq package-archives
- '(("melpa" . "http://melpa.milkbox.net/packages/")
- ("ELPA" . "http://tromey.com/elpa/")
- ("gnu" . "http://elpa.gnu.org/packages/")
- ("marmalade" . "http://marmalade-repo.org/packages/")))
-(setq package-load-list '((htmlize "1.39")
- all))
-(setq org-feed-alist
- '(("MyEpisodes"
- "http://www.myepisodes.com/rss.php?feed=mylist&uid=Slash&pwdmd5=04028968e1f0b7ee678b748a4320ac17"
- "~/documents/org/org" "MyEpisodes"
- :formatter oni:myepisodes-formatter)))
-(setq send-mail-function 'smtpmail-send-it)
-(setq sendmail-program "/usr/bin/msmtp")
-(setq yas-prompt-functions '(yas-ido-prompt))
-
-(add-hook 'after-save-hook 'oni:after-save-func)
-(add-hook 'before-save-hook 'oni:before-save-func)
-(add-hook 'c-mode-common-hook 'oni:c-mode-common-func)
-(add-hook 'hs-minor-mode-hook 'oni:hs-minor-mode-func)
-(add-hook 'jabber-chat-mode-hook 'oni:jabber-chat-mode-func)
-(add-hook 'prog-mode-hook 'oni:prog-mode-func)
-
-(global-set-key (kbd "<f6>") 'jabber-switch-to-roster-buffer)
-(global-set-key (kbd "<f8>") 'oni:raise-eshell)
-(global-set-key (kbd "M-n") 'idomenu)
-
-(unless (oni:required-packages-installed-p)
- (message "%s" "Refreshing package database...")
- (package-refresh-contents)
- (message "%s" " done.")
- (mapc #'(lambda (package)
- (when (not (package-installed-p package))
- (package-install package)))
- oni:required-packages))
-
-(defun oni:c-mode-func ()
- "Function for `c-mode-hook'."
- (local-set-key [f9] 'compile)
- (local-set-key "\C-j" 'oni:newline-and-indent))
-
-(add-hook 'c-mode-hook 'oni:c-mode-func)
-
(defun oni:css-mode-func ()
"Function for `css-mode-hook'."
(setq hs-adjust-block-beginning 'hs-c-like-adjust-block-beginning)
@@ -306,7 +210,9 @@ for easy selection."
(local-set-key "\C-j" 'oni:newline-and-indent)
(rainbow-mode))
-(add-hook 'css-mode-hook 'oni:css-mode-func)
+(defun oni:diary-display-func ()
+ "Function for `diary-display-hook'."
+ (diary-fancy-display))
(defun oni:emacs-lisp-mode-func ()
"Function for `emacs-lisp-mode-hook'."
@@ -314,240 +220,6 @@ for easy selection."
(when (buffer-file-name)
(hs-minor-mode)))
-(add-hook 'emacs-lisp-mode-hook 'oni:emacs-lisp-mode-func)
-
-(defun oni:go-mode-func ()
- "Function for `go-mode-hook'."
- (setq indent-tabs-mode nil)
- (local-set-key "\C-j" 'oni:newline-and-indent))
-
-(add-hook 'go-mode-hook 'oni:go-mode-func)
-
-(defun oni:html-mode-func ()
- "Function for `html-mode-hook'."
- (fci-mode))
-
-(add-hook 'html-mode-hook 'oni:html-mode-func)
-
-(defconst oni:javascript-outline-regex "function \\(\\w\\|_\\)+("
- "Regex for `outline-minor-mode' for `js-mode'.")
-
-(defun oni:js-mode-func ()
- "Function for `js-mode-hook'."
- (oni:generic-outline oni:javascript-outline-regex)
- (rainbow-delimiters-mode)
- (local-set-key "\C-j" 'oni:newline-and-indent))
-
-(add-hook 'js-mode-hook 'oni:js-mode-func)
-
-(add-to-list 'auto-mode-alist '("\\.js\\(on\\)?$" . js-mode))
-
-(defun oni:lisp-mode-func ()
- "Function for `lisp-mode-hook'."
- (hs-minor-mode))
-
-(add-hook 'lisp-mode-hook 'oni:lisp-mode-func)
-
-(defconst oni:python-outline-regex
- (eval-when-compile
- (concat "^[ \t]*\\(?:@[a-zA-Z0-9_]+\\(?:([a-zA-Z0-9_=, ]*)\\)?"
- "\n\\)*[ \t]*\\(?:\\(class\\|def\\)[ \t]+\\(\\sw\\|\\s_\\)+"
- "\\(([^)]*):\\)?\\|\\#[ a-zA-Z0-9]*\\#\\)"))
- "Regex for `outline-minor-mode' for `python-mode'.")
-
-(defun oni:python-mode-func ()
- "Function for `python-mode-hook'."
- (flymake-mode)
- (local-set-key (kbd "C->") 'python-indent-shift-right)
- (local-set-key (kbd "C-<") 'python-indent-shift-left)
- (local-set-key [C-tab] 'outline-toggle-children)
- (oni:generic-outline oni:python-outline-regex)
- (set (make-local-variable 'electric-indent-chars) nil)
- (rainbow-delimiters-mode)
- (fci-mode))
-
-(add-hook 'python-mode-hook 'oni:python-mode-func)
-
-(autoload 'pony-mode "pony-mode" nil t)
-
-(defconst oni:php-outline-regex
- (eval-when-compile
- (concat
- "^ *\\(\\(?:namespace\\|interface\\) [a-zA-Z0-9_]\\|\\(\\(abstract"
- "\\|final\\) \\)?class [a-zA-Z0-9_]+\\( extends [\\a-zA-Z0-9_]+\\)?"
- "\\|\\(abstract \\)?\\(public\\|private\\|protected\\)?"
- "\\( static\\)? function [a-zA-Z0-9_]+(\\|/\\*\\*\\)"))
- "Regex for `outline-minor-mode' for `php-mode'.")
-
-(defun oni:php-mode-func ()
- "Function for `php-mode-hook'."
- (flymake-mode)
- ;; (oni:gtags-for-php)
- (local-set-key "\C-j" 'oni:newline-and-indent)
- (c-set-offset 'arglist-intro '+)
- (c-set-offset 'arglist-close '0)
- (rainbow-delimiters-mode)
- (setq fci-rule-column 81))
-
-(autoload 'php-mode "php-mode" nil t)
-
-(setq-default php-mode-warn-if-mumamo-off nil)
-
-(setq php-function-call-face 'font-lock-function-name-face
- php-mode-force-pear t)
-
-(add-to-list 'auto-mode-alist '("\\.php[345]?$" . php-mode))
-
-(add-hook 'php-mode-hook 'oni:php-mode-func)
-
-(add-to-list 'auto-mode-alist '("\\.tpl$" . html-mode))
-
-(defun oni:scheme-mode-func ()
- "Function for `scheme-mode-hook'."
- (hs-minor-mode))
-
-(add-hook 'scheme-mode-hook 'oni:scheme-mode-func)
-
-(require 'geiser-install)
-
-(setq geiser-active-implementations '(guile)
- geiser-repl-history-filename "~/.emacs.d/geiser-history")
-
-(defun oni:java-mode-func ()
- "Function for `java-mode-hook'."
- (local-set-key "\C-j" 'oni:newline-and-indent))
-
-(add-hook 'java-mode-hook 'oni:java-mode-func)
-
-(defun oni:close-client-window ()
- "Close a client's frames."
- (interactive)
- (server-save-buffers-kill-terminal nil))
-
-(when (daemonp)
- (global-set-key "\C-x\C-c" 'oni:close-client-window))
-
-(defun oni:org-mode-func ()
- "Function for `org-mode-hook'."
- (flyspell-mode)
- (auto-fill-mode))
-
-(add-hook 'org-mode-hook 'oni:org-mode-func)
-
-(global-set-key "\C-ca" 'org-agenda)
-(global-set-key "\C-cc" 'org-capture)
-
-(eval-after-load "org"
- '(progn
- (require 'appt)
- (require 'org-protocol)
- (require 'org-habit)
- (require 'org-contacts)
-
- (add-to-list 'org-modules 'habit)
-
- (org-indent-mode t)
-
- (org-agenda-to-appt)
- (ad-activate 'org-agenda-redo)))
-
-(eval-after-load "org-crypt"
- '(org-crypt-use-before-save-magic))
-
-(setq org-hide-emphasis-markers t)
-
-(setq org-refile-allow-creating-parent-nodes t
- org-refile-targets '((nil . (:maxlevel . 6)))
- org-refile-use-outline-path 'file)
-
-(defadvice org-agenda-redo (after org-agenda-redo-add-appts)
- "Pressing `r' on the agenda will also add appointments."
- (progn
- (setq appt-time-msg-list nil)
- (org-agenda-to-appt)))
-
-(setq org-agenda-custom-commands
- '(("b" "Bookmarks to look at."
- todo "LOOKAT")
- ("w" "Work todo."
- tags-todo "CATEGORY=\"Work\"")))
-
-(setq org-directory (expand-file-name "~/documents/org"))
-
-(setq org-default-notes-file (concat org-directory "/org"))
-
-(setq org-agenda-files
- `(,(concat org-directory "/org")
- ,(concat org-directory "/misc/contacts.org")
- ,(concat org-directory "/misc/bookmarks.org")))
-
-(setq org-agenda-sorting-strategy ; How to sort my agenda.
- '((agenda habit-down time-up priority-down category-keep)
- (todo priority-down category-up)
- (tags priority-down category-keep)
- (search category-keep)))
-
-(setq org-capture-templates ; What to capture when.
- '(("t" "Task" entry (file+headline "" "tasks")
- "* TODO %^{Description}\n %u\n\n %?")
- ("T" "Task with link" entry (file+headline "" "tasks")
- "* TODO %^{Description}\n %u\n\n %a\n %?")
- ("h" "Habit" entry (file+headline "" "tasks")
- (concat "* TODO %^{Description}\n"
- " SCHEDULED: %^T\n"
- " :PROPERTIES:\n"
- " :STYLE: habit\n"
- " :END:")
- :immediate-finish t)
- ("l" "Log" entry (file+headline "" "notes")
- (concat "* %n %<%d-%m-%Y %H:%M:%S>\n"
- " %a\n\n"
- " %?")
- :prepend t :empty-lines 1)
- ("a" "Appointment" entry (file+headline "" "appointments")
- "* %^{Description} %^T" :immediate-finish t)
- ("b" "Bookmark" entry (file "~/documents/org/misc/bookmarks.org")
- "* %c\n\n %:initial")))
-
-(setq org-export-htmlize-output-type 'css
- org-outline-path-complete-in-steps t
- org-return-follows-link t
- org-src-fontify-natively t
- org-tags-exclude-from-inheritance '("crypt")
- org-use-fast-todo-selection t)
-
-(setq org-todo-keyword-faces
- '(("TODO" :foreground "red")
- ("IN PROGRESS" :foreground "yellow")
- ("DONE" :foreground "forest green")
- ("SUCCEEDED" :foreground "forest green")
- ("WAITING" :foreground "orange")
- ("CANCELLED" :foreground "orangered")
- ("FAILED" :foreground "orangered")))
-
-(setq org-todo-keywords
- '((sequence "TODO(t)" "IN PROGRESS" "WAITING(@/!)" "|"
- "DONE(!/!)" "CANCELLED(@/!)")))
-
-(defun oni:diary-display-func ()
- "Function for `diary-display-hook'."
- (diary-fancy-display))
-
-(add-hook 'diary-display-hook 'oni:diary-display-func)
-
-(setq appt-display-diary nil)
-
-(defun oni:newline-and-indent ()
- (interactive)
- (if (and (not (or (= (point) (point-max))
- (= (point) (point-min))))
- (or (and (char-equal (char-before) ?{)
- (char-equal (char-after) ?}))
- (and (char-equal (char-before) ?\()
- (char-equal (char-after) ?\)))))
- (save-excursion (newline-and-indent)))
- (newline-and-indent))
-
(defun oni:emms-toggle-playing ()
"Toggle between playing/paused states."
(interactive)
@@ -555,55 +227,49 @@ for easy selection."
(emms-start)
(emms-pause)))
-(eval-after-load "emms-source-file"
- '(progn
- (require 'emms-setup)
-
- (emms-standard)
- (require 'emms-player-mpd)
-
- (setq emms-player-mpd-server-name "localhost")
- (setq emms-player-mpd-server-port "6600")
-
- (add-to-list 'emms-info-functions 'emms-info-mpd)
- (add-to-list 'emms-player-list 'emms-player-mpd)
- (setq emms-player-mpd-music-directory "/mnt/music/mp3")))
-
-(setq emms-source-file-default-directory "/mnt/music/")
-
-(global-set-key [XF86AudioNext] 'emms-next)
-(global-set-key [XF86AudioPlay] 'oni:emms-toggle-playing)
-(global-set-key [XF86AudioPrev] 'emms-previous)
-(global-set-key [XF86AudioStop] 'emms-stop)
-(global-set-key [XF86Tools] 'emms)
-
(defun oni:erc-mode-func ()
"Function for `erc-mode-hook'."
(erc-fill-mode -1)
(visual-line-mode)
(setq truncate-lines nil))
-(setq erc-autojoin-channels-alist
- '(("freenode.net" "#herbstluftwm" "#ninthfloor" "#emacs"
- "#dispass")))
-
-(setq erc-nick "ryuslash")
-
-(add-hook 'erc-mode-hook 'oni:erc-mode-func)
-
-(setq erc-insert-timestamp-function 'erc-insert-timestamp-left
- erc-timestamp-format "[%H:%M] "
- erc-timestamp-only-if-changed-flag nil)
+(defun oni:eshell-mode-func ()
+ "Function for `eshell-mode-hook'."
+ (setq truncate-lines nil))
-(setq erc-hide-list '("JOIN" "PART" "QUIT"))
+(defun oni:eshell-prompt-function ()
+ (let ((status (if (zerop eshell-last-command-status) ?+ ?-))
+ (hostname (shell-command-to-string "hostname"))
+ (dir (abbreviate-file-name (eshell/pwd)))
+ (branch
+ (shell-command-to-string
+ "git branch --contains HEAD 2>/dev/null | sed -e '/^[^*]/d'"))
+ (userstatus (if (zerop (user-uid)) ?# ?$)))
+ (concat
+ (propertize (char-to-string status)
+ 'face `(:foreground ,(if (= status ?+)
+ (oni:color chameleon-1)
+ (oni:color scarlet-red-2))))
+ " "
+ (propertize (substring hostname 0 -1) 'face 'mode-line-buffer-id)
+ " "
+ (propertize (oni:shorten-dir dir) 'face 'font-lock-string-face)
+ " "
+ (when (not (string= branch ""))
+ (propertize
+ ;; Cut off "* " and "\n"
+ (substring branch 2 -1)
+ 'face 'font-lock-function-name-face))
+ " \n"
+ (propertize (char-to-string userstatus)
+ 'face `(:foreground ,(oni:color sky-blue-1)))
+ "> ")))
(defun oni:flymake-mode-func ()
"Function for `flymake-mode-hook'."
(local-set-key [M-P] 'flymake-goto-prev-error)
(local-set-key [M-N] 'flymake-goto-next-error))
-(add-hook 'flymake-mode-hook 'oni:flymake-mode-func)
-
(defun oni:flymake-pyflakes-init ()
"Initialize function for flymake with pyflakes."
(let* ((temp-file (flymake-init-create-temp-buffer-copy
@@ -612,63 +278,72 @@ for easy selection."
buffer-file-name))))
(list "pyflakes" (list local-file))))
-(eval-after-load "flymake"
- '(progn
- (require 'flymake-cursor)
-
- (add-to-list ; Make sure pyflakes is loaded
- 'flymake-allowed-file-name-masks ; for python files.
- '("\\.py\\'" oni:flymake-pyflakes-init))
-
- (add-to-list ; Error line repexp for go
- 'flymake-err-line-patterns ; compilation.
- '("^\\([a-zA-Z0-9_]+\\.go\\):\\([0-9]+\\):\\(.*\\)$"
- 1 2 nil 3))
-
- (add-to-list ; Go uses makefiles, makes
- 'flymake-allowed-file-name-masks ; flymaking 'easy'.
- '("\\.go$" flymake-simple-make-init))))
-
-(setq flymake-log-file-name (expand-file-name "~/.emacs.d/flymake.log")
- flymake-log-level 0
- flymake-gui-warnings-enabled nil)
-
-(autoload 'gtags-mode "gtags" nil t)
-
-(defun oni:gtags-create-or-update ()
- "Create or update the GNU Global tag file"
- (interactive)
- (if (not (= 0 (call-process "global" nil nil nil " -p")))
- (let ((olddir default-directory)
- (topdir (read-directory-name
- "gtags: top of source tree:" default-directory)))
- (cd topdir)
- (shell-command "~/bin/create_gtags")
- (cd olddir))
- ;; Tagfile already exists; update it
- (shell-command "~/bin/update_gtags")))
-
-(defun oni:gtags-for-php ()
- "Setup gtags for `php-mode'."
- (let* ((file-name (buffer-file-name))
- (fext (if (not (eq nil file-name))
- (file-name-extension (buffer-file-name))
- nil)))
- (if (equal fext "php")
- (progn
- (gtags-mode)
- (oni:gtags-create-or-update)))))
+(defun oni:go-mode-func ()
+ "Function for `go-mode-hook'."
+ (setq indent-tabs-mode nil)
+ (local-set-key "\C-j" 'oni:newline-and-indent))
(defun oni:gtags-mode-func ()
"Function for `gtags-mode-hook'."
(local-set-key "\M-," 'gtags-find-tag)
(local-set-key "\M-." 'gtags-find-rtag))
-(add-hook 'gtags-mode-hook 'oni:gtags-mode-func)
+(defun oni:hs-minor-mode-func ()
+ "Function for `hs-minor-mode-hook'."
+ (local-set-key [C-tab] 'hs-toggle-hiding)
+ (hs-hide-all))
-(setq gtags-auto-update t)
+(defun oni:html-mode-func ()
+ "Function for `html-mode-hook'."
+ (fci-mode))
-(require 'newcomment)
+(defun oni:indent-shift-left (start end &optional count)
+ (interactive
+ (if mark-active
+ (list (region-beginning) (region-end) current-prefix-arg)
+ (list (line-beginning-position)
+ (line-end-position)
+ current-prefix-arg)))
+ (if count
+ (setq count (prefix-numeric-value count))
+ (setq count tab-width))
+ (when (> count 0)
+ (let ((deactivate-mark nil))
+ (save-excursion
+ (goto-char start)
+ (while (< (point) end)
+ (if (and (< (current-indentation) count)
+ (not (looking-at "[ \t]*$")))
+ (error "Can't shift all lines enough"))
+ (forward-line))
+ (indent-rigidly start end (- count))))))
+
+(defun oni:indent-shift-right (start end &optional count)
+ (interactive
+ (if mark-active
+ (list (region-beginning) (region-end) current-prefix-arg)
+ (list (line-beginning-position)
+ (line-end-position)
+ current-prefix-arg)))
+ (let ((deactivate-mark nil))
+ (if count
+ (setq count (prefix-numeric-value count))
+ (setq count tab-width))
+ (indent-rigidly start end count)))
+
+(defun oni:jabber-chat-mode-func ()
+ "Function for `jabber-chat-mode-hook'."
+ (visual-line-mode))
+
+(defun oni:java-mode-func ()
+ "Function for `java-mode-hook'."
+ (local-set-key "\C-j" 'oni:newline-and-indent))
+
+(defun oni:js-mode-func ()
+ "Function for `js-mode-hook'."
+ (oni:generic-outline oni:javascript-outline-regex)
+ (rainbow-delimiters-mode)
+ (local-set-key "\C-j" 'oni:newline-and-indent))
(defun oni:kill-region-or-backward-char ()
"Kill either the active region, or delete the character left of
@@ -678,8 +353,6 @@ for easy selection."
(kill-region (region-beginning) (region-end))
(backward-delete-char-untabify 1)))
-(global-set-key "\C-w" 'oni:kill-region-or-backward-char)
-
(defun oni:kill-region-or-forward-char ()
"Kill either the active region, or delete the character right
of the cursor"
@@ -688,8 +361,6 @@ for easy selection."
(kill-region (region-beginning) (region-end))
(delete-forward-char 1)))
-(global-set-key "\C-d" 'oni:kill-region-or-forward-char)
-
(defun oni:kill-region-or-line ()
"Kill either the active region, or the rest of the line,
depending on whether or not `region-active-p' is t"
@@ -698,7 +369,55 @@ for easy selection."
(kill-region (region-beginning) (region-end))
(kill-line)))
-(global-set-key "\C-k" 'oni:kill-region-or-line)
+(defun oni:lisp-mode-func ()
+ "Function for `lisp-mode-hook'."
+ (hs-minor-mode))
+
+(defun oni:magit-log-edit-mode-func ()
+ "Function for `magit-log-edit-mode-hook'."
+ (auto-fill-mode)
+ (font-lock-add-keywords
+ nil
+ '(("\\`\\(.\\{,50\\}\\)\\(.*\\)\n?\\(.*\\)$"
+ (1 'git-commit-summary-face)
+ (2 'git-commit-overlong-summary-face)
+ (3 'git-commit-nonempty-second-line-face))
+ ("`\\([^']+\\)'" 1 font-lock-constant-face))
+ t))
+
+(defun oni:markdown-mode-func ()
+ "Function for `markdown-mode-hook'."
+ (auto-fill-mode)
+ (whitespace-mode))
+
+(defun oni:message-mode-func ()
+ "Function for `message-mode-hook'."
+ (auto-fill-mode)
+ (flyspell-mode)
+ (ispell-change-dictionary (read-string "New dictionary: ")))
+
+(defun oni:mini-fix-timestamp-string (date-string)
+ "A minimal version of Xah Lee's `fix-timestamp-string'
+ function, found at http://xahlee.org/emacs/elisp_parse_time.html"
+ (setq date-string (replace-regexp-in-string "Jan" "01" date-string)
+ date-string (replace-regexp-in-string "Feb" "02" date-string)
+ date-string (replace-regexp-in-string "Mar" "03" date-string)
+ date-string (replace-regexp-in-string "Apr" "04" date-string)
+ date-string (replace-regexp-in-string "May" "05" date-string)
+ date-string (replace-regexp-in-string "Jun" "06" date-string)
+ date-string (replace-regexp-in-string "Jul" "07" date-string)
+ date-string (replace-regexp-in-string "Aug" "08" date-string)
+ date-string (replace-regexp-in-string "Sep" "09" date-string)
+ date-string (replace-regexp-in-string "Oct" "10" date-string)
+ date-string (replace-regexp-in-string "Nov" "11" date-string)
+ date-string (replace-regexp-in-string "Dec" "12" date-string))
+ (string-match
+ "^\\([0-9]\\{2\\}\\)-\\([0-9]\\{2\\}\\)-\\([0-9]\\{4\\}\\)$"
+ date-string)
+ (format "%s-%s-%s"
+ (match-string 3 date-string)
+ (match-string 2 date-string)
+ (match-string 1 date-string)))
(defun oni:move-beginning-of-dwim ()
"Move to the beginning of line, either after the indentatoin of
@@ -709,8 +428,6 @@ for easy selection."
(if (= start (point))
(beginning-of-line))))
-(global-set-key "\C-a" 'oni:move-beginning-of-dwim)
-
(defun oni:move-end-of-dwim ()
"Move to the end of line, either before any comments or after
them."
@@ -729,68 +446,85 @@ for easy selection."
(end-of-line)))
(end-of-line))))
-(global-set-key "\C-e" 'oni:move-end-of-dwim)
+(defun oni:myepisodes-formatter (plist)
+ "Format RSS items from MyEpisodes as org tasks."
+ (let ((str (plist-get plist :title)))
+ (string-match
+ "^\\[ \\([^\]]+\\) \\]\\[ \\([^\]]+\\) \\]\\[ \\([^\]]+\\) \\]\\[ \\([^\]]+\\) \\]$"
+ str)
+ (let* ((title (match-string 1 str))
+ (episode (match-string 2 str))
+ (name (match-string 3 str))
+ (date (oni:mini-fix-timestamp-string (match-string 4 str))))
+ (format "* ACQUIRE %s %s - %s <%s>" title episode name date))))
-(defun oni:self-insert-dwim ()
- "Execute self insert, but when the region is active call self
- insert at the end of the region and at the beginning."
+(defun oni:newline-and-indent ()
(interactive)
- (if (region-active-p)
- (let ((electric-pair-mode nil)
- (beginning (region-beginning))
- (end (region-end)))
- (goto-char end)
- (self-insert-command 1)
- (save-excursion
- (goto-char beginning)
- (self-insert-command 1)))
- (self-insert-command 1)))
-
-(global-set-key "'" 'oni:self-insert-dwim)
-(global-set-key "\"" 'oni:self-insert-dwim)
-
-(global-set-key [f7] 'magit-status)
-
-(defun oni:magit-log-edit-mode-func ()
- "Function for `magit-log-edit-mode-hook'."
- (auto-fill-mode)
- (font-lock-add-keywords
- nil
- '(("\\`\\(.\\{,50\\}\\)\\(.*\\)\n?\\(.*\\)$"
- (1 'git-commit-summary-face)
- (2 'git-commit-overlong-summary-face)
- (3 'git-commit-nonempty-second-line-face))
- ("`\\([^']+\\)'" 1 font-lock-constant-face))
- t))
-
-(add-hook 'magit-log-edit-mode-hook 'oni:magit-log-edit-mode-func)
-
-(defun oni:markdown-mode-func ()
- "Function for `markdown-mode-hook'."
- (auto-fill-mode)
- (whitespace-mode))
-
-(add-hook 'markdown-mode-hook 'oni:markdown-mode-func)
-
-(add-to-list 'auto-mode-alist '("\\.m\\(ark\\)?do?wn$" . markdown-mode))
+ (if (and (not (or (= (point) (point-max))
+ (= (point) (point-min))))
+ (or (and (char-equal (char-before) ?{)
+ (char-equal (char-after) ?}))
+ (and (char-equal (char-before) ?\()
+ (char-equal (char-after) ?\)))))
+ (save-excursion (newline-and-indent)))
+ (newline-and-indent))
-(setq whitespace-style '(face trailing))
+(defun oni:org-capture-before-finalize-func ()
+ (save-excursion
+ (goto-char (point-min))
+ (while (re-search-forward "<<FIRSTLINE>>" nil t)
+ (let (beg end)
+ (save-match-data
+ (search-forward "\n\n")
+ (skip-syntax-forward " ")
+ (setq beg (point))
+ (search-forward "\n")
+ (setq end (1- (point))))
+ (replace-match (buffer-substring beg end) t t)))))
-(defun oni:message-mode-func ()
- "Function for `message-mode-hook'."
- (auto-fill-mode)
+(defun oni:org-mode-func ()
+ "Function for `org-mode-hook'."
(flyspell-mode)
- (ispell-change-dictionary (read-string "New dictionary: ")))
-
-(setq message-send-mail-function 'message-send-mail-with-sendmail)
+ (auto-fill-mode))
-(add-hook 'message-mode-hook 'oni:message-mode-func)
+(defun oni:php-mode-func ()
+ "Function for `php-mode-hook'."
+ (flymake-mode)
+ (local-set-key "\C-j" 'oni:newline-and-indent)
+ (c-set-offset 'arglist-intro '+)
+ (c-set-offset 'arglist-close '0)
+ (rainbow-delimiters-mode)
+ (setq fci-rule-column 81))
-(require 'w3m-load)
+(defun oni:prog-mode-func ()
+ "Function for `prog-mode-hook'."
+ (rainbow-delimiters-mode)
+ (fci-mode)
+ (pretty-symbols-mode))
-(require 'uniquify)
+(defun oni:python-mode-func ()
+ "Function for `python-mode-hook'."
+ (flymake-mode)
+ (local-set-key (kbd "C->") 'python-indent-shift-right)
+ (local-set-key (kbd "C-<") 'python-indent-shift-left)
+ (local-set-key [C-tab] 'outline-toggle-children)
+ (oni:generic-outline oni:python-outline-regex)
+ (set (make-local-variable 'electric-indent-chars) nil)
+ (rainbow-delimiters-mode)
+ (fci-mode))
-(setq uniquify-buffer-name-style 'post-forward)
+(defun oni:raise-eshell ()
+ "Start or switch back to `eshell'. Also change directories to
+ current working directory."
+ (interactive)
+ (let ((dir (file-name-directory
+ (or (buffer-file-name) "~/")))
+ (hasfile (not (eq (buffer-file-name) nil))))
+ (eshell)
+ (if (and hasfile (eq eshell-process-list nil))
+ (progn
+ (eshell/cd dir)
+ (eshell-reset)))))
(defun oni:raise-scratch (&optional mode)
"Show the *scratch* buffer. If called with a universal
@@ -814,307 +548,516 @@ its major mode."
(switch-to-buffer buffer)))
-(setq initial-major-mode 'emacs-lisp-mode
- initial-scratch-message nil)
-
-(global-set-key [XF86HomePage] 'oni:raise-scratch)
-
(defun oni:reload-buffer ()
"Reload current buffer."
(interactive)
(revert-buffer nil t nil))
-(global-set-key [f5] 'oni:reload-buffer)
+(defun oni:replace-html-special-chars ()
+ (oni:replace-occurrences "é" "&eacute;"))
+
+(defun oni:replace-occurrences (from to)
+ "Replace all occurrences of FROM with TO in the current buffer."
+ (save-excursion
+ (goto-char (point-min))
+ (while (search-forward from nil t)
+ (replace-match to))))
+
+(defun oni:required-packages-installed-p ()
+ "Check if all the packages I need are installed."
+ (let ((tmp-packages oni:required-packages)
+ (result t))
+ (while (and tmp-packages result)
+ (if (not (package-installed-p (car tmp-packages)))
+ (setq result nil))
+ (setq tmp-packages (cdr tmp-packages)))
+ result))
+
+(defun oni:scheme-mode-func ()
+ "Function for `scheme-mode-hook'."
+ (hs-minor-mode))
+
+(defun oni:self-insert-dwim ()
+ "Execute self insert, but when the region is active call self
+ insert at the end of the region and at the beginning."
+ (interactive)
+ (if (region-active-p)
+ (let ((electric-pair-mode nil)
+ (beginning (region-beginning))
+ (end (region-end)))
+ (goto-char end)
+ (self-insert-command 1)
+ (save-excursion
+ (goto-char beginning)
+ (self-insert-command 1)))
+ (self-insert-command 1)))
+
+(defun oni:shorten-dir (dir)
+ "Shorten a directory, (almost) like fish does it."
+ (while (string-match "\\(/\\.?[^./]\\)[^/]+/" dir)
+ (setq dir (replace-match "\\1/" nil nil dir)))
+ dir)
(defun oni:term-mode-func ()
"Function for `term-mode-hook'."
(setq truncate-lines nil))
-(add-hook 'term-mode-hook 'oni:term-mode-func)
-
(defun oni:texinfo-mode-func ()
"Function for `texinfo-mode-hook'."
(auto-fill-mode))
-(add-hook 'texinfo-mode-hook 'oni:texinfo-mode-func)
+(defun oni:view-mail ()
+ "Show a menu with all mailbox options from `oni:mailbox-map'
+for easy selection."
+ (interactive)
+ (require 'tmm)
+ (let* ((tmm-completion-prompt "Choose a mailbox\n")
+ (inbox (tmm-prompt oni:mailbox-map)))
+ (if inbox
+ (progn
+ (require 'mu4e)
+ (funcall (intern (concat "oni:" inbox "-mailbox")))
+ (mu4e)))))
-(autoload 'xmodmap-mode "xmodmap-mode" nil t)
-(add-to-list 'auto-mode-alist '("^\\.Xmodmap$" . xmodmap-mode))
+(defun oni:write-file-func ()
+ "Function for `write-file-hooks'."
+ (time-stamp))
-(defun oni:indent-shift-left (start end &optional count)
- (interactive
- (if mark-active
- (list (region-beginning) (region-end) current-prefix-arg)
- (list (line-beginning-position)
- (line-end-position)
- current-prefix-arg)))
- (if count
- (setq count (prefix-numeric-value count))
- (setq count tab-width))
- (when (> count 0)
- (let ((deactivate-mark nil))
- (save-excursion
- (goto-char start)
- (while (< (point) end)
- (if (and (< (current-indentation) count)
- (not (looking-at "[ \t]*$")))
- (error "Can't shift all lines enough"))
- (forward-line))
- (indent-rigidly start end (- count))))))
+(eval-after-load "ebuff-menu"
+ '(define-key electric-buffer-menu-mode-map
+ (kbd "C-s") 'isearch-forward))
-(add-to-list 'debug-ignored-errors "^Can't shift all lines enough")
+(eval-after-load "em-term"
+ '(add-to-list 'eshell-visual-commands
+ "unison"))
-(defun oni:indent-shift-right (start end &optional count)
- (interactive
- (if mark-active
- (list (region-beginning) (region-end) current-prefix-arg)
- (list (line-beginning-position)
- (line-end-position)
- current-prefix-arg)))
- (let ((deactivate-mark nil))
- (if count
- (setq count (prefix-numeric-value count))
- (setq count tab-width))
- (indent-rigidly start end count)))
+(eval-after-load "emms-source-file"
+ '(progn
+ (require 'emms-setup)
-(global-set-key (kbd "C-<") 'indent-shift-left)
-(global-set-key (kbd "C->") 'indent-shift-right)
+ (emms-standard)
+ (require 'emms-player-mpd)
-(autoload 'po-mode "po-mode" nil t)
-(add-to-list 'auto-mode-alist '("\\.po\\'\\|\\.po\\." . po-mode))
+ (setq emms-player-mpd-server-name "localhost")
+ (setq emms-player-mpd-server-port "6600")
-(autoload 'sawfish-mode "sawfish" nil t)
+ (add-to-list 'emms-info-functions 'emms-info-mpd)
+ (add-to-list 'emms-player-list 'emms-player-mpd)
+ (setq emms-player-mpd-music-directory "/mnt/music/mp3")))
-(add-to-list 'auto-mode-alist '("\\.jl$" . sawfish-mode))
+(eval-after-load "flymake"
+ '(progn
+ (require 'flymake-cursor)
-(electric-indent-mode)
-(electric-pair-mode)
-(show-paren-mode)
-(savehist-mode)
+ (add-to-list ; Make sure pyflakes is loaded
+ 'flymake-allowed-file-name-masks ; for python files.
+ '("\\.py\\'" oni:flymake-pyflakes-init))
-(blink-cursor-mode -1)
-(menu-bar-mode -1)
-(scroll-bar-mode -1)
-(tool-bar-mode -1)
-(tooltip-mode -1)
+ (add-to-list ; Error line repexp for go
+ 'flymake-err-line-patterns ; compilation.
+ '("^\\([a-zA-Z0-9_]+\\.go\\):\\([0-9]+\\):\\(.*\\)$"
+ 1 2 nil 3))
-(defun oni:write-file-func ()
- "Function for `write-file-hooks'."
- (time-stamp))
+ (add-to-list ; Go uses makefiles, makes
+ 'flymake-allowed-file-name-masks ; flymaking 'easy'.
+ '("\\.go$" flymake-simple-make-init))))
-(add-hook 'write-file-hooks 'oni:write-file-func)
+(eval-after-load "ido"
+ '(setq ido-ignore-buffers `(,@ido-ignore-buffers
+ "^\\*.*\\*$" "^irc\\." "^\\#")))
-(setq time-stamp-active t)
-(setq time-stamp-format "%04y-%02m-%02d %02H:%02M:%02S (%u)")
+(eval-after-load "info"
+ '(require 'info+))
-(ido-mode)
+(eval-after-load "mu4e"
+ '(add-to-list
+ 'org-capture-templates
+ '("c" "Contact" entry (file "~/documents/org/misc/contacts.org")
+ (concat "* %(mu4e-view-snarf-from 'name)\n"
+ " :PROPERTIES:\n"
+ " :EMAIL: %(mu4e-view-snarf-from 'email)\n"
+ " :END:"))))
-(setq ido-auto-merge-delay-time 1000000)
+(eval-after-load "org"
+ '(progn
+ (require 'appt)
+ (require 'org-protocol)
+ (require 'org-habit)
+ (require 'org-contacts)
-(setq ido-save-directory-list-file nil)
+ (add-to-list 'org-modules 'habit)
-(eval-after-load "ido"
- '(setq ido-ignore-buffers `(,@ido-ignore-buffers
- "^\\*.*\\*$" "^irc\\." "^\\#")))
+ (org-indent-mode t)
-(setq smex-save-file "~/.emacs.d/smex-items")
+ (org-agenda-to-appt)
+ (ad-activate 'org-agenda-redo)))
-(smex-initialize)
+(eval-after-load "org-crypt"
+ '(org-crypt-use-before-save-magic))
+
+(eval-after-load "sauron"
+ '(setq sauron-modules (append '(sauron-identica sauron-jabber)
+ sauron-modules)))
(eval-after-load "smex"
'(progn
(global-set-key (kbd "M-x") 'smex)
(global-set-key (kbd "C-M-x") 'smex-major-mode-commands)))
-(require 'iso-transl)
+(oni:define-mailbox "aethon"
+ (oni:email thomas at aethon dot nl)
+ (expand-file-name "~/documents/work/aethon/signature.txt"))
+(oni:define-mailbox "gmail" (oni:email ryuslash at gmail dot com))
+(oni:define-mailbox "ninthfloor"
+ (oni:email ryuslash at ninthfloor dot org))
+(oni:define-mailbox "ryuslash" (oni:email tom at ryuslash dot org)
+ nil "ryuslash.org")
-(setq-default bidi-paragraph-direction 'left-to-right)
+(put 'upcase-region 'disabled nil)
+(put 'downcase-region 'disabled nil)
+(put 'narrow-to-region 'disabled nil)
+(setq-default bidi-paragraph-direction 'left-to-right)
+(setq-default c-basic-offset 4)
+(setq-default fci-rule-column 73)
(setq-default gac-automatically-push-p t)
-
-(setq-default indent-tabs-mode nil
- tab-width 4)
-
+(setq-default indent-tabs-mode nil)
+(setq-default mode-line-format
+ (list
+ '(:eval
+ (if (and (buffer-modified-p) (buffer-file-name))
+ (propertize "!"
+ 'face 'oni:mode-line-modified
+ 'help-echo "Buffer has been modified")
+ " "))
+
+ '(:eval (propertize "%m"
+ 'face 'oni:mode-line-mode
+ 'help-echo buffer-file-coding-system))
+
+ ": "
+
+ '(:eval (propertize "%b "
+ 'face 'mode-line-buffer-id
+ 'help-echo (buffer-file-name)))
+
+ "("
+ (propertize "%p" 'face 'oni:mode-line-buffer-position) ":"
+ (propertize "%04l" 'face 'oni:mode-line-buffer-line) ","
+ (propertize "%02c" 'face 'oni:mode-line-buffer-column)
+ ") "
+
+ "["
+ '(:eval (propertize
+ (if buffer-read-only
+ "R"
+ (if overwrite-mode "O" "I"))
+ 'face 'oni:mode-line-buffer-state
+ 'help-echo (concat "Buffer is "
+ (if buffer-read-only
+ "read-only"
+ (if overwrite-mode
+ "in overwrite mode"
+ "in insert mode")))))
+
+ "] "
+
+ '(:eval
+ (propertize (format-time-string "%H:%M")
+ 'help-echo
+ (concat (format-time-string "%c; ")
+ (emacs-uptime "Uptime: %hh"))))
+ " --"
+ '(:eval global-mode-string)))
+(setq-default php-mode-warn-if-mumamo-off nil)
(setq-default require-final-newline t)
-
+(setq-default tab-width 4)
(setq-default truncate-lines t)
-(add-to-list 'auto-mode-alist '("^PKGBUILD$" . shell-script-mode))
-
+(setq appt-display-diary nil)
(setq auto-mode-case-fold nil)
-
(setq auto-save-file-name-transforms
- `((".*" ,temporary-file-directory t))
-
- backup-directory-alist
+ `((".*" ,temporary-file-directory t)))
+(setq avandu-article-render-function #'avandu-view-w3m)
+(setq backup-directory-alist
`((".*" . ,temporary-file-directory)))
-
-(setq browse-url-browser-function 'browse-url-generic
- browse-url-generic-program (getenv "BROWSER"))
-
+(setq browse-url-browser-function 'browse-url-generic)
+(setq browse-url-generic-program (getenv "BROWSER"))
(setq custom-file "~/.emacs.d/custom.el")
-
(setq custom-theme-directory "~/.emacs.d/themes")
-(add-to-list 'custom-theme-load-path
- (concat custom-theme-directory "/naquadah-theme"))
-(load-theme 'naquadah t)
-
-(setq
- default-frame-alist
- `((border-width . 0)
- (internal-border-width . 0)
- (vertical-scroll-bars . nil)
- (menu-bar-lines . nil)
- (tool-bar-lines . nil)
- (font . "DejaVu Sans Mono:pixelsize=18")
- (left-fringe . 0)))
-
+(setq default-frame-alist
+ `((border-width . 0)
+ (internal-border-width . 0)
+ (vertical-scroll-bars . nil)
+ (menu-bar-lines . nil)
+ (tool-bar-lines . nil)
+ (font . "DejaVu Sans Mono:pixelsize=18")
+ (left-fringe . 0)))
+(setq emms-source-file-default-directory "/mnt/music/")
+(setq erc-autojoin-channels-alist
+ '(("freenode.net" "#herbstluftwm" "#ninthfloor" "#emacs"
+ "#dispass")))
+(setq erc-hide-list '("JOIN" "PART" "QUIT"))
+(setq erc-insert-timestamp-function 'erc-insert-timestamp-left)
+(setq erc-nick "ryuslash")
+(setq erc-timestamp-format "[%H:%M] ")
+(setq erc-timestamp-only-if-changed-flag nil)
+(setq eshell-highlight-prompt nil)
+(setq eshell-prompt-function 'oni:eshell-prompt-function)
+(setq eshell-prompt-regexp "^[#$]> ")
+(setq fci-rule-color "darkred")
+(setq flymake-gui-warnings-enabled nil)
+(setq flymake-log-file-name (expand-file-name "~/.emacs.d/flymake.log"))
+(setq flymake-log-level 0)
(setq frame-title-format '(:eval (concat "emacs: " (buffer-name))))
-
+(setq geiser-active-implementations '(guile))
+(setq geiser-repl-history-filename "~/.emacs.d/geiser-history")
+(setq gtags-auto-update t)
(setq help-at-pt-display-when-idle t)
-(help-at-pt-set-timer)
-
-(setq sauron-max-line-length 189)
-
-(eval-after-load "sauron"
- '(setq sauron-modules (append '(sauron-identica sauron-jabber)
- sauron-modules)))
-
-(setq sauron-column-alist ; I don't need as much
- '((timestamp . 6) ; information as the default.
- (message)))
-
-(setq sauron-hide-mode-line t)
-(setq sauron-timestamp-format "%H:%M")
-(setq sauron-watch-nicks '("ryuslash"))
-(setq sauron-watch-patterns '("ryuslash"))
-(setq special-display-buffer-names '("*Sauron*"))
-(setq special-display-frame-alist
- '((minibuffer . nil)
- (right-fringe . 0)))
-
+(setq ido-auto-merge-delay-time 1000000)
+(setq ido-save-directory-list-file nil)
+(setq inferior-lisp-program "sbcl")
(setq inhibit-default-init t)
-
(setq inhibit-local-menu-bar-menus t)
-
(setq inhibit-startup-message t)
-
+(setq initial-major-mode 'emacs-lisp-mode)
+(setq initial-scratch-message nil)
+(setq jabber-account-list '(("ryuslash@jabber.org")))
+(setq jabber-chat-buffer-format "*jabber:%n*")
+(setq jabber-chat-buffer-show-avatar nil)
+(setq jabber-chat-fill-long-lines nil)
+(setq jabber-chat-foreign-prompt-format "[%t] < ")
+(setq jabber-chat-local-prompt-format "[%t] > ")
+(setq jabber-chatstates-confirm nil)
+(setq jabber-history-dir "~/.emacs.d/jabber")
+(setq jabber-roster-show-bindings nil)
(setq jit-lock-defer-time 0.2)
-
+(setq mail-header-separator "")
(setq message-log-max 1000)
-
+(setq message-send-mail-function 'message-send-mail-with-sendmail)
+(setq mu4e-headers-date-format "%d-%m %H:%M")
+(setq mu4e-headers-fields '((:date . 11)
+ (:flags . 6)
+ (:to . 22)
+ (:from . 22)
+ (:subject)))
+(setq mu4e-headers-show-threads nil)
+(setq mu4e-headers-sort-revert nil)
+(setq mu4e-my-email-addresses (list
+ (oni:email tom at ryuslash dot org)
+ (oni:email ryuslash at gmail dot com)
+ (oni:email ryuslash at ninthfloor dot org)
+ (oni:email thomas at aethon dot nl)))
+(setq org-agenda-custom-commands
+ '(("b" "Bookmarks to look at."
+ todo "LOOKAT")
+ ("w" "Work todo."
+ tags-todo "CATEGORY=\"Work\"")))
+(setq org-agenda-sorting-strategy
+ '((agenda habit-down time-up priority-down category-keep)
+ (todo priority-down category-up)
+ (tags priority-down category-keep)
+ (search category-keep)))
+(setq org-capture-templates
+ '(("t" "Task" entry (file "")
+ "* TODO <<FIRSTLINE>>
+ :PROPERTIES:
+ :DIRECTORY: %(directory-file-name (or (org-capture-get :original-file) org-default-notes-file))
+ :FILE: %f
+ :END:
+ %u
+
+ %?%a")
+ ("h" "Habit" entry (file "")
+ (concat "* TODO %^{Description}\n"
+ " SCHEDULED: %^T\n"
+ " :PROPERTIES:\n"
+ " :STYLE: habit\n"
+ " :END:")
+ :immediate-finish t)
+ ("l" "Log" entry (file+headline "" "notes")
+ (concat "* %n %<%d-%m-%Y %H:%M:%S>\n"
+ " %a\n\n"
+ " %?")
+ :prepend t :empty-lines 1)
+ ("a" "Appointment" entry (file+headline "" "appointments")
+ "* %^{Description} %^T" :immediate-finish t)
+ ("b" "Bookmark" entry (file "~/documents/org/misc/bookmarks.org")
+ "* %c\n\n %:initial")))
(setq org-contacts-files '("~/documents/org/misc/contacts.org"))
-
+(setq org-directory (expand-file-name "~/documents/org"))
+(setq org-agenda-files
+ `(,(concat org-directory "/org")
+ ,(concat org-directory "/misc/contacts.org")
+ ,(concat org-directory "/misc/bookmarks.org")))
+(setq org-default-notes-file (concat org-directory "/org"))
+(setq org-export-htmlize-output-type 'css)
+(setq org-feed-alist
+ '(("MyEpisodes"
+ "http://www.myepisodes.com/rss.php?feed=mylist&uid=Slash&pwdmd5=04028968e1f0b7ee678b748a4320ac17"
+ "~/documents/org/org" "MyEpisodes"
+ :formatter oni:myepisodes-formatter)))
+(setq org-hide-emphasis-markers t)
+(setq org-outline-path-complete-in-steps t)
+(setq org-refile-allow-creating-parent-nodes t)
+(setq org-refile-targets '((nil . (:maxlevel . 6))))
+(setq org-refile-use-outline-path 'file)
+(setq org-return-follows-link t)
+(setq org-src-fontify-natively t)
+(setq org-tags-exclude-from-inheritance '("crypt"))
+(setq org-todo-keyword-faces
+ '(("TODO" :foreground "red")
+ ("IN PROGRESS" :foreground "yellow")
+ ("DONE" :foreground "forest green")
+ ("SUCCEEDED" :foreground "forest green")
+ ("WAITING" :foreground "orange")
+ ("CANCELLED" :foreground "orangered")
+ ("FAILED" :foreground "orangered")))
+(setq org-todo-keywords
+ '((sequence "TODO(t)" "IN PROGRESS" "WAITING(@/!)" "|"
+ "DONE(!/!)" "CANCELLED(@/!)")))
+(setq org-use-fast-todo-selection t)
+(setq package-archives
+ '(("melpa" . "http://melpa.milkbox.net/packages/")
+ ("ELPA" . "http://tromey.com/elpa/")
+ ("gnu" . "http://elpa.gnu.org/packages/")
+ ("marmalade" . "http://marmalade-repo.org/packages/")))
+(setq package-load-list '((htmlize "1.39")
+ all))
+(setq php-function-call-face 'font-lock-function-name-face)
+(setq php-mode-force-pear t)
(setq rainbow-delimiters-max-face-count 12)
-
(setq redisplay-dont-pause t)
+(setq sauron-column-alist '((timestamp . 6)
+ (message)))
+(setq sauron-hide-mode-line t)
+(setq sauron-max-line-length 189)
+(setq sauron-timestamp-format "%H:%M")
+(setq sauron-watch-nicks '("ryuslash"))
+(setq sauron-watch-patterns '("ryuslash"))
+(setq scroll-conservatively 101)
+(setq send-mail-function 'smtpmail-send-it)
+(setq sendmail-program "/usr/bin/msmtp")
+(setq smex-save-file "~/.emacs.d/smex-items")
+(setq special-display-buffer-names '("*Sauron*"))
+(setq special-display-frame-alist '((minibuffer . nil)
+ (right-fringe . 0)))
+(setq time-stamp-active t)
+(setq time-stamp-format "%04y-%02m-%02d %02H:%02M:%02S (%u)")
+(setq uniquify-buffer-name-style 'post-forward)
+(setq use-dialog-box nil)
+(setq user-full-name "Tom Willemsen")
+(setq whitespace-style '(face trailing))
+(setq yas-prompt-functions '(yas-ido-prompt))
-(put 'upcase-region 'disabled nil)
-(put 'downcase-region 'disabled nil)
-(put 'narrow-to-region 'disabled nil)
+(add-hook 'after-save-hook 'oni:after-save-func)
+(add-hook 'before-save-hook 'oni:before-save-func)
+(add-hook 'c-mode-common-hook 'oni:c-mode-common-func)
+(add-hook 'c-mode-hook 'oni:c-mode-func)
+(add-hook 'css-mode-hook 'oni:css-mode-func)
+(add-hook 'diary-display-hook 'oni:diary-display-func)
+(add-hook 'emacs-lisp-mode-hook 'oni:emacs-lisp-mode-func)
+(add-hook 'erc-mode-hook 'oni:erc-mode-func)
+(add-hook 'eshell-mode-hook 'oni:eshell-mode-func)
+(add-hook 'flymake-mode-hook 'oni:flymake-mode-func)
+(add-hook 'go-mode-hook 'oni:go-mode-func)
+(add-hook 'gtags-mode-hook 'oni:gtags-mode-func)
+(add-hook 'hs-minor-mode-hook 'oni:hs-minor-mode-func)
+(add-hook 'html-mode-hook 'oni:html-mode-func)
+(add-hook 'jabber-chat-mode-hook 'oni:jabber-chat-mode-func)
+(add-hook 'java-mode-hook 'oni:java-mode-func)
+(add-hook 'js-mode-hook 'oni:js-mode-func)
+(add-hook 'lisp-mode-hook 'oni:lisp-mode-func)
+(add-hook 'magit-log-edit-mode-hook 'oni:magit-log-edit-mode-func)
+(add-hook 'markdown-mode-hook 'oni:markdown-mode-func)
+(add-hook 'message-mode-hook 'oni:message-mode-func)
+(add-hook 'org-capture-before-finalize-hook
+ 'oni:org-capture-before-finalize-func)
+(add-hook 'org-mode-hook 'oni:org-mode-func)
+(add-hook 'php-mode-hook 'oni:php-mode-func)
+(add-hook 'prog-mode-hook 'oni:prog-mode-func)
+(add-hook 'python-mode-hook 'oni:python-mode-func)
+(add-hook 'scheme-mode-hook 'oni:scheme-mode-func)
+(add-hook 'term-mode-hook 'oni:term-mode-func)
+(add-hook 'texinfo-mode-hook 'oni:texinfo-mode-func)
+(add-hook 'write-file-hooks 'oni:write-file-func)
+(global-set-key (kbd "'") 'oni:self-insert-dwim)
+(global-set-key (kbd "<XF86AudioNext>") 'emms-next)
+(global-set-key (kbd "<XF86AudioPlay>") 'oni:emms-toggle-playing)
+(global-set-key (kbd "<XF86AudioPrev>") 'emms-previous)
+(global-set-key (kbd "<XF86AudioStop>") 'emms-stop)
+(global-set-key (kbd "<XF86HomePage>") 'oni:raise-scratch)
+(global-set-key (kbd "<XF86Mail>") 'oni:view-mail)
+(global-set-key (kbd "<XF86Tools>") 'emms)
+(global-set-key (kbd "<f5>") 'oni:reload-buffer)
+(global-set-key (kbd "<f6>") 'jabber-switch-to-roster-buffer)
+(global-set-key (kbd "<f7>") 'magit-status)
+(global-set-key (kbd "<f8>") 'oni:raise-eshell)
+(global-set-key (kbd "C-<") 'indent-shift-left)
+(global-set-key (kbd "C->") 'indent-shift-right)
(global-set-key (kbd "C-@") 'er/expand-region)
+(global-set-key (kbd "C-M-d") 'kill-word)
+(global-set-key (kbd "C-M-w") 'backward-kill-word)
+(global-set-key (kbd "C-S-k") 'kill-whole-line)
+(global-set-key (kbd "C-a") 'oni:move-beginning-of-dwim)
+(global-set-key (kbd "C-c a") 'org-agenda)
+(global-set-key (kbd "C-c c") 'org-capture)
+(global-set-key (kbd "C-c i p") 'identica-update-status-interactive)
+(global-set-key (kbd "C-d") 'oni:kill-region-or-forward-char)
+(global-set-key (kbd "C-e") 'oni:move-end-of-dwim)
+(global-set-key (kbd "C-k") 'oni:kill-region-or-line)
+(global-set-key (kbd "C-w") 'oni:kill-region-or-backward-char)
+(global-set-key (kbd "C-x C-b") 'electric-buffer-list)
+(global-set-key (kbd "M-n") 'idomenu)
+(global-set-key (kbd "\"") 'oni:self-insert-dwim)
-(defface oni:mode-line-modified
- '((t (:inherit font-lock-warning-face)))
- "Face for the modified state in the mode-line"
- :group 'local)
-
-(defface oni:mode-line-mode
- '((t (:inherit font-lock-string-face)))
- "Face for the major mode in the mode-line"
- :group 'local)
-
-(defface oni:mode-line-buffer-position
- '((t (:inherit font-lock-constant-face)))
- "Face for the buffer position in the mode-line"
- :group 'local)
-
-(defface oni:mode-line-buffer-line
- '((t (:inherit font-lock-type-face)))
- "Face for the line number in the mode-line"
- :group 'local)
+(when (daemonp)
+ (global-set-key "\C-x\C-c" 'oni:close-client-window))
-(defface oni:mode-line-buffer-column
- '((t (:inherit font-lock-type-face)))
- "Face for the column number in the mode-line"
- :group 'local)
+(when (or window-system (daemonp))
+ (global-unset-key "\C-z"))
-(defface oni:mode-line-buffer-state
- '((t (:inherit font-lock-preprocessor-face)))
- "Face for the state of the buffer in the mode-line"
- :group 'local)
+(add-to-list 'auto-mode-alist '("\\.jl$" . sawfish-mode))
+(add-to-list 'auto-mode-alist '("\\.js\\(on\\)?$" . js-mode))
+(add-to-list 'auto-mode-alist '("\\.m\\(ark\\)?do?wn$" . markdown-mode))
+(add-to-list 'auto-mode-alist '("\\.php[345]?$" . php-mode))
+(add-to-list 'auto-mode-alist '("\\.po\\'\\|\\.po\\." . po-mode))
+(add-to-list 'auto-mode-alist '("\\.tpl$" . html-mode))
+(add-to-list 'auto-mode-alist '("^PKGBUILD$" . shell-script-mode))
+(add-to-list 'auto-mode-alist '("^\\.Xmodmap$" . xmodmap-mode))
-(setq-default
- mode-line-format
- (list
- '(:eval (if (and (buffer-modified-p) (buffer-file-name))
- (propertize "!"
- 'face 'oni:mode-line-modified
- 'help-echo "Buffer has been modified")
- " "))
-
- '(:eval (propertize "%m"
- 'face 'oni:mode-line-mode
- 'help-echo buffer-file-coding-system))
-
- ": "
-
- '(:eval (propertize "%b "
- 'face 'mode-line-buffer-id
- 'help-echo (buffer-file-name)))
-
- "("
- (propertize "%p" 'face 'oni:mode-line-buffer-position) ":"
- (propertize "%04l" 'face 'oni:mode-line-buffer-line) ","
- (propertize "%02c" 'face 'oni:mode-line-buffer-column)
- ") "
-
- "["
- '(:eval (propertize
- (if buffer-read-only
- "R"
- (if overwrite-mode "O" "I"))
- 'face 'oni:mode-line-buffer-state
- 'help-echo (concat "Buffer is "
- (if buffer-read-only
- "read-only"
- (if overwrite-mode
- "in overwrite mode"
- "in insert mode")))))
-
- "] "
-
- '(:eval (propertize (format-time-string "%H:%M")
- 'help-echo
- (concat (format-time-string "%c; ")
- (emacs-uptime "Uptime: %hh"))))
- " --"
- '(:eval global-mode-string)))
+(add-to-list 'custom-theme-load-path
+ (concat custom-theme-directory "/naquadah-theme"))
-(setq scroll-conservatively 101)
+(add-to-list 'debug-ignored-errors "^Can't shift all lines enough")
-(setq use-dialog-box nil)
+(unless (oni:required-packages-installed-p)
+ (message "%s" "Refreshing package database...")
+ (package-refresh-contents)
+ (message "%s" " done.")
+ (mapc #'(lambda (package)
+ (when (not (package-installed-p package))
+ (package-install package)))
+ oni:required-packages))
-(setq user-full-name "Tom Willemsen")
+(blink-cursor-mode -1)
+(menu-bar-mode -1)
+(scroll-bar-mode -1)
+(tool-bar-mode -1)
+(tooltip-mode -1)
-(define-key key-translation-map (kbd "C-j") (kbd "C-l"))
-(define-key key-translation-map (kbd "C-l") (kbd "C-j"))
+(electric-indent-mode)
+(electric-pair-mode)
+(ido-mode)
+(savehist-mode)
+(show-paren-mode)
-(global-set-key "\C-x\C-b" 'electric-buffer-list)
-(global-set-key "\C-\M-d" 'kill-word)
-(global-set-key "\C-\M-w" 'backward-kill-word)
-(global-set-key (kbd "C-S-k") 'kill-whole-line)
-(global-set-key [XF86Mail] 'oni:view-mail)
-(global-set-key "\C-cip" 'identica-update-status-interactive)
+(smex-initialize)
+(help-at-pt-set-timer)
-(when (or window-system (daemonp))
- (global-unset-key "\C-z"))
+(load-theme 'naquadah t)
(load custom-file)
(load "rudel-loaddefs.el")
(load (expand-file-name "~/quicklisp/slime-helper.el"))
-
-;; Local Variables:
-;; no-update-autoloads: t
-;; End: