diff options
| author | yuzu-eva <stevenhu@web.de> | 2022-12-07 12:48:11 +0100 |
|---|---|---|
| committer | yuzu-eva <stevenhu@web.de> | 2022-12-07 12:48:11 +0100 |
| commit | cae62a4c0bc3e09c5d74124d160d0f02bf8cf4fb (patch) | |
| tree | 37e61b1cf05c40943d7766e0eb725a9a9eae48f6 /.emacs.d/packages.el | |
| parent | 96c8d201349fe8b41ca6bfc38317a42169e07cb7 (diff) | |
added files
Diffstat (limited to '.emacs.d/packages.el')
| -rw-r--r-- | .emacs.d/packages.el | 330 |
1 files changed, 330 insertions, 0 deletions
diff --git a/.emacs.d/packages.el b/.emacs.d/packages.el new file mode 100644 index 0000000..3e84067 --- /dev/null +++ b/.emacs.d/packages.el @@ -0,0 +1,330 @@ +;; Initialize melpa repo +(require 'package) +(setq package-enable-at-startup nil) +(add-to-list 'package-archives + '("melpa" . "https://melpa.org/packages/")) +(package-initialize) + +;; Initialize use-package +(unless (package-installed-p 'use-package) + (package-refresh-contents) + (package-install 'use-package)) +(use-package org + :config + (add-hook 'org-mode-hook 'org-indent-mode) + (add-hook 'org-mode-hook + '(lambda () + (visual-line-mode 1)))) + +(use-package org-indent + :diminish org-indent-mode) + +(use-package htmlize + :ensure t) + +(use-package auto-package-update + :defer nil + :ensure t + :config + (setq auto-package-update-delete-old-versions t) + (setq auto-package-update-hide-results t) + (auto-package-update-maybe)) + +(use-package diminish + :ensure t) + +(use-package spaceline + :ensure t) + +(use-package powerline + :ensure t + :init + (spaceline-spacemacs-theme) + :hook + ('after-init-hook) . 'powerline-reset) + +(use-package dashboard + :ensure t + :defer nil + :preface + (defun update-config () + "Update Witchmacs to the latest version." + (interactive) + (let ((dir (expand-file-name user-emacs-directory))) + (if (file-exists-p dir) + (progn + (message "Witchmacs is updating!") + (cd dir) + (shell-command "git pull") + (message "Update finished. Switch to the messages buffer to see changes and then restart Emacs")) + (message "\"%s\" doesn't exist." dir)))) + + (defun create-scratch-buffer () + "Create a scratch buffer" + (interactive) + (switch-to-buffer (get-buffer-create "*scratch*")) + (lisp-interaction-mode)) + :config + (dashboard-setup-startup-hook) + (setq dashboard-items '((recents . 5))) + (setq dashboard-banner-logo-title "W I T C H M A C S - The cutest Emacs distribution!") + (setq dashboard-startup-banner "~/.emacs.d/marivector.png") + (setq dashboard-center-content t) + (setq dashboard-show-shortcuts nil) + (setq dashboard-set-init-info t) + (setq dashboard-init-info (format "%d packages loaded in %s" + (length package-activated-list) (emacs-init-time))) + (setq dashboard-set-footer nil) + (setq dashboard-set-navigator t) + (setq dashboard-navigator-buttons + `(;; line1 + ((,nil + "Witchmacs on github" + "Open Witchmacs' github page on your browser" + (lambda (&rest _) (browse-url "https://github.com/snackon/witchmacs")) + 'default) + (nil + "Witchmacs crash course" + "Open Witchmacs' introduction to Emacs" + (lambda (&rest _) (find-file "~/.emacs.d/Witcheat.org")) + 'default) + (nil + "Update Witchmacs" + "Get the latest Witchmacs update. Check out the github commits for changes!" + (lambda (&rest _) (update-config)) + 'default) + ) + ;; line 2 + ((,nil + "Open scratch buffer" + "Switch to the scratch buffer" + (lambda (&rest _) (create-scratch-buffer)) + 'default) + (nil + "Open config.el" + "Open Witchmacs' configuration file for easy editing" + (lambda (&rest _) (find-file "~/.emacs.d/config.el")) + 'default) + (nil + "Open init.el" + "Open init file" + (lambda (&rest _) (find-file "~/.emacs.d/init.el")) + 'default))))) + + +;(insert (concat +; (propertize (format "%d packages loaded in %s" +; (length package-activated-list) (emacs-init-time)) +; 'face 'font-lock-comment-face))) +; +;(dashboard-center-line) + +(use-package which-key + :ensure t + :diminish which-key-mode + :init + (which-key-mode)) + +(use-package swiper + :ensure t + :bind ("C-s" . 'swiper)) + +(use-package evil + :ensure t + :defer nil + :init + (setq evil-want-keybinding nil) + (setq evil-want-C-u-scroll t) + :config + (evil-mode 1)) + +;(use-package evil-collection +; :after evil +; :ensure t +; :config +; (evil-collection-init)) + +(use-package beacon + :ensure t + :diminish beacon-mode + :init + (beacon-mode 1)) + +(use-package avy + :ensure t + :bind + ("M-s" . avy-goto-char)) + +(use-package switch-window + :ensure t + :config + (setq switch-window-input-style 'minibuffer) + (setq switch-window-increase 4) + (setq switch-window-threshold 2) + (setq switch-window-shortcut-style 'qwerty) + (setq switch-window-qwerty-shortcuts + '("a" "s" "d" "f" "j" "k" "l")) + :bind + ([remap other-window] . switch-window)) + +(use-package ido + :init + (ido-mode 1) + :config + (setq ido-enable-flex-matching nil) + (setq ido-create-new-buffer 'always) + (setq ido-everywhere t)) + +(use-package ido-vertical-mode + :ensure t + :init + (ido-vertical-mode 1)) +; This enables arrow keys to select while in ido mode. If you want to +; instead use the default Emacs keybindings, change it to +; "'C-n-and-C-p-only" +(setq ido-vertical-define-keys 'C-n-C-p-up-and-down) + +(use-package async + :ensure t + :init + (dired-async-mode 1)) + +(use-package page-break-lines + :ensure t + :diminish (page-break-lines-mode visual-line-mode)) + +(use-package undo-tree + :ensure t + :diminish undo-tree-mode) + +(use-package treemacs + :ensure t + :defer t + :init + (with-eval-after-load 'winum + (define-key winum-keymap (kbd "M-0") #'treemacs-select-window)) + :config + (progn + (setq treemacs-collapse-dirs (if (executable-find "python3") 3 0) + treemacs-deferred-git-apply-delay 0.5 + treemacs-display-in-side-window t + treemacs-eldoc-display t + treemacs-file-event-delay 5000 + treemacs-file-follow-delay 0.2 + treemacs-follow-after-init t + treemacs-git-command-pipe "" + treemacs-goto-tag-strategy 'refetch-index + treemacs-indentation 2 + treemacs-indentation-string " " + treemacs-is-never-other-window nil + treemacs-max-git-entries 5000 + treemacs-missing-project-action 'ask + treemacs-no-png-images nil + treemacs-no-delete-other-windows t + treemacs-project-follow-cleanup nil + treemacs-persist-file (expand-file-name ".cache/treemacs-persist" user-emacs-directory) + treemacs-recenter-distance 0.1 + treemacs-recenter-after-file-follow nil + treemacs-recenter-after-tag-follow nil + treemacs-recenter-after-project-jump 'always + treemacs-recenter-after-project-expand 'on-distance + treemacs-show-cursor nil + treemacs-show-hidden-files t + treemacs-silent-filewatch nil + treemacs-silent-refresh nil + treemacs-sorting 'alphabetic-desc + treemacs-space-between-root-nodes t + treemacs-tag-follow-cleanup t + treemacs-tag-follow-delay 1.5 + treemacs-width 30) + (treemacs-resize-icons 11) + + (treemacs-follow-mode t) + (treemacs-filewatch-mode t) + (treemacs-fringe-indicator-mode t) + (pcase (cons (not (null (executable-find "git"))) + (not (null (executable-find "python3")))) + (`(t . t) + (treemacs-git-mode 'deferred)) + (`(t . _) + (treemacs-git-mode 'simple)))) + :bind + (:map global-map + ("M-0" . treemacs-select-window) + ("C-x t 1" . treemacs-delete-other-windows) + ("C-x t t" . treemacs) + ("C-x t B" . treemacs-bookmark) + ("C-x t C-t" . treemacs-find-file) + ("C-x t M-t" . treemacs-find-tag))) + +(use-package treemacs-evil + :after treemacs evil + :ensure t) + + (use-package treemacs-icons-dired + :after treemacs dired + :ensure t + :config (treemacs-icons-dired-mode)) + +(use-package magit + :ensure t) + +(use-package eldoc + :diminish eldoc-mode) + +(use-package abbrev + :diminish abbrev-mode) + +(use-package company + :ensure t + :diminish (meghanada-mode company-mode irony-mode) + :config + (setq company-idle-delay 0) + (setq company-minimum-prefix-length 3) + (define-key company-active-map (kbd "M-n") nil) + (define-key company-active-map (kbd "M-p") nil) + (define-key company-active-map (kbd "C-n") #'company-select-next) + (define-key company-active-map (kbd "C-p") #'company-select-previous) + (define-key company-active-map (kbd "SPC") #'company-abort) + :hook + ((java-mode c-mode c++-mode) . company-mode)) + +(use-package yasnippet + :ensure t + :diminish yas-minor-mode + :hook + ((c-mode c++-mode) . yas-minor-mode) + :config + (yas-reload-all)) + +(use-package yasnippet-snippets + :ensure t) + +(use-package company-c-headers + :defer nil + :ensure t) + +(use-package company-irony + :defer nil + :ensure t + :config + (setq company-backends '((company-c-headers + company-dabbrev-code + company-irony)))) +(use-package irony + :defer nil + :ensure t + :config + :hook + ((c++-mode c-mode) . irony-mode) + ('irony-mode-hook) . 'irony-cdb-autosetup-compile-options) + +(use-package meghanada + :ensure t + :defer nil + :config + (add-hook 'java-mode-hook + (lambda () + (meghanada-mode t))) + (setq meghanada-java-path "java") + (setq meghanada-maven-path "mvn")) |
