;;; km-abbrev.el --- Abbrev mode extesions ;; Copyright (C) 2012-2018 Kyle Meyer ;; Author: Kyle Meyer ;; URL: https://gitlab.com/kyleam/emacs.d ;; This program is free software; you can redistribute it and/or modify ;; it under the terms of the GNU General Public License as published by ;; the Free Software Foundation, either version 3 of the License, or ;; (at your option) any later version. ;; This program is distributed in the hope that it will be useful, ;; but WITHOUT ANY WARRANTY; without even the implied warranty of ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ;; GNU General Public License for more details. ;; You should have received a copy of the GNU General Public License ;; along with this program. If not, see . ;;; Code: (require 'abbrev) ;;;###autoload (defun km/abbrev-add-case-global () "Define lower abbreviation for the word before point. Like `add-global-abbrev', but always make the abbreviation the lower case variant of the word before point." (interactive) ;; Modified from `add-abbrev'. (let* ((table global-abbrev-table) (exp (buffer-substring-no-properties (point) (save-excursion (forward-word -1) (point)))) (name (downcase exp))) (when (or (not (abbrev-expansion name table)) (y-or-n-p (format "%s expands to \"%s\"; redefine? " name (abbrev-expansion name table)))) (define-abbrev table name exp)))) ;;;###autoload (defun km/abbrev-inverse-add-uppercase-global () "Define uppercase expansion for the word before point. Like `inverse-add-global-abbrev', but always use the lower case version of the word before point as the abbreviation and the upper case version as the expansion." (interactive) ;; Modified from `inverse-add-abbrev'. (let* ((table global-abbrev-table) (end (point)) (start (save-excursion (forward-word -1) (point))) (name (downcase (buffer-substring-no-properties start end))) (exp (upcase name))) (when (or (not (abbrev-expansion name table)) (y-or-n-p (format "%s expands to \"%s\"; redefine? " name (abbrev-expansion name table)))) (define-abbrev table name exp) (save-excursion (goto-char end) (expand-abbrev))))) (provide 'km-abbrev) ;;; km-abbrev.el ends here