;; column number
(column-number-mode 1)
+;; font
+;; (set-default-font "Inconsolata-12")
+
;; Don't let Emacs hurt your ears
(setq visible-bell t)
;; This is bound to f11 in Emacs 24.4
;; (toggle-frame-fullscreen)
(custom-set-variables
- '(initial-frame-alist (quote ((fullscreen . maximized)))))
+ ;; 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.
+ '(haskell-process-auto-import-loaded-modules t)
+ '(haskell-process-log t)
+ '(haskell-process-suggest-remove-import-lines t)
+ '(haskell-process-type (quote cabal-repl))
+ '(initial-frame-alist (quote ((fullscreen . maximized))))
+ '(send-mail-function (quote smtpmail-send-it)))
;; Who use the bar to scroll?
(when (display-graphic-p)
(progn
(setq package-list '(go-mode
rust-mode
haskell-mode
- clojure-mode
ghc
restclient
tangotango-theme
- cider
fill-column-indicator
paredit
- leuven-theme))
+ leuven-theme
+ notmuch
+ railscasts-theme
+ racket-mode
+ auto-complete
+ magit
+ ledger-mode))
; install the missing packages
(dolist (package package-list)
(package-install package)))
;; tangotango
-; (load-theme 'tangotango t)
-(load-theme 'leuven t)
+;; (load-theme 'tangotango t)
+;; (load-theme 'railscasts t)
+;; (load-theme 'leuven t)
;; erc
(require 'erc)
(erc-autojoin-mode t)
(setq erc-autojoin-channels-alist
- '((".*\\.freenode.net" "#tahoe-lafs")
+ '((".*\\.freenode.net" "#tahoe-lafs" "#plan9chan" "#cat-v")
(".*\\.oftc.net" "#LeastAuthority")))
;; check channels
(add-hook 'haskell-mode-hook 'turn-on-haskell-indentation)
;; haskell mode
-(custom-set-variables
- '(haskell-process-suggest-remove-import-lines t)
- '(haskell-process-auto-import-loaded-modules t)
- '(haskell-process-log t))
-(eval-after-load 'haskell-mode '(progn
- (define-key haskell-mode-map (kbd "C-c C-l") 'haskell-process-load-or-reload)
- (define-key haskell-mode-map (kbd "C-c C-z") 'haskell-interactive-switch)
- (define-key haskell-mode-map (kbd "C-c C-n C-t") 'haskell-process-do-type)
- (define-key haskell-mode-map (kbd "C-c C-n C-i") 'haskell-process-do-info)
- (define-key haskell-mode-map (kbd "C-c C-n C-c") 'haskell-process-cabal-build)
- (define-key haskell-mode-map (kbd "C-c C-n c") 'haskell-process-cabal)
- (define-key haskell-mode-map (kbd "SPC") 'haskell-mode-contextual-space)))
-(eval-after-load 'haskell-cabal '(progn
- (define-key haskell-cabal-mode-map (kbd "C-c C-z") 'haskell-interactive-switch)
- (define-key haskell-cabal-mode-map (kbd "C-c C-k") 'haskell-interactive-mode-clear)
- (define-key haskell-cabal-mode-map (kbd "C-c C-c") 'haskell-process-cabal-build)
- (define-key haskell-cabal-mode-map (kbd "C-c c") 'haskell-process-cabal)))
-
-(eval-after-load 'haskell-mode
- '(define-key haskell-mode-map (kbd "C-c C-o") 'haskell-compile))
-(eval-after-load 'haskell-cabal
- '(define-key haskell-cabal-mode-map (kbd "C-c C-o") 'haskell-compile))
-
-(eval-after-load 'haskell-mode
- '(define-key haskell-mode-map [f8] 'haskell-navigate-imports))
-
-(custom-set-variables '(haskell-process-type 'cabal-repl))
+(require 'haskell-interactive-mode)
+(require 'haskell-process)
+(add-hook 'haskell-mode-hook 'interactive-haskell-mode)
+
+
+
+(eval-after-load "haskell-mode"
+ '(progn
+ (define-key haskell-mode-map (kbd "C-c C-l") 'haskell-process-load-or-reload)
+ (define-key haskell-mode-map (kbd "C-`") 'haskell-interactive-bring)
+ (define-key haskell-mode-map (kbd "C-c C-t") 'haskell-process-do-type)
+ (define-key haskell-mode-map (kbd "C-c C-i") 'haskell-process-do-info)
+ (define-key haskell-mode-map (kbd "C-c C-c") 'haskell-process-cabal-build)
+ (define-key haskell-mode-map (kbd "C-c C-k") 'haskell-interactive-mode-clear)
+ (define-key haskell-mode-map (kbd "C-c c") 'haskell-process-cabal)
+ (define-key haskell-mode-map (kbd "SPC") 'haskell-mode-contextual-space)
+
+ (define-key haskell-cabal-mode-map (kbd "C-`") 'haskell-interactive-bring)
+ (define-key haskell-cabal-mode-map (kbd "C-c C-k") 'haskell-interactive-mode-clear)
+ (define-key haskell-cabal-mode-map (kbd "C-c C-c") 'haskell-process-cabal-build)
+ (define-key haskell-cabal-mode-map (kbd "C-c c") 'haskell-process-cabal)))
;; ghc-mod
(autoload 'ghc-init "ghc" nil t)
(autoload 'ghc-debug "ghc" nil t)
+(setq ghc-debug t)
(add-hook 'haskell-mode-hook (lambda () (ghc-init)))
-(custom-set-variables
- '(haskell-process-type 'cabal-repl))
+
;; ido
(setq ido-enable-flex-matching t)
;; line-number-mode
(global-linum-mode t)
-(global-hl-line-mode t)
+(global-hl-line-mode 0)
;; fci -- fill-column-indicator
(setq fci-rule-column 81)
(setq fci-rule-width 1)
(setq fci-rule-color "darkblue")
+
+;; turn off electric-indent-mode
+(when (fboundp 'electric-indent-mode) (electric-indent-mode -1))
+
+;; notmuch
+(setq mail-user-agent 'message-user-agent)
+(setq user-mail-address "ram@rkrishnan.org"
+ user-full-name "Ramakrishnan Muthukrishnan")
+
+;; smtp
+(setq smtpmail-stream-type 'ssl
+ smtpmail-smtp-server "mail.messagingengine.com"
+ smtpmail-smtp-service 465)
+
+;; addressbook
+(require 'notmuch-address)
+(setq notmuch-address-command "/usr/bin/notmuch-addrlookup")
+(notmuch-address-message-insinuate)
+
+(require 'smtpmail)
+(setq message-send-mail-function 'smtpmail-send-it)
+(require 'starttls)
+
+;; sign all emails
+(add-hook 'message-setup-hook 'mml-secure-message-sign-pgp)
+
+(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.
+ )
+
+;; auto complete
+(ac-config-default)
+(ac-linum-workaround)