123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- ;;; ede/util.el --- EDE utilities
- ;; Copyright (C) 2000, 2005, 2009-2012 Free Software Foundation, Inc.
- ;; Author: Eric M. Ludlam <zappo@gnu.org>
- ;; Keywords: project, make
- ;; This file is part of GNU Emacs.
- ;; GNU Emacs 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.
- ;; GNU Emacs 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 GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
- ;;; Commentary:
- ;;
- ;; Utilities that may not require project specific help, and operate
- ;; on generic EDE structures. Provide user level commands for activities
- ;; not directly related to source code organization or makefile generation.
- (require 'ede)
- ;;; Code:
- ;;; Updating the version of a project.
- ;;;###autoload
- (defun ede-update-version (newversion)
- "Update the current projects main version number.
- Argument NEWVERSION is the version number to use in the current project."
- (interactive (list (let* ((o (ede-toplevel))
- (v (oref o version)))
- (read-string (format "Update Version (was %s): " v)
- v nil v))))
- (let ((ede-object (ede-toplevel)))
- ;; Don't update anything if there was no change.
- (unless (string= (oref ede-object :version) newversion)
- (oset ede-object :version newversion)
- (project-update-version ede-object)
- (ede-update-version-in-source ede-object newversion))))
- (defmethod project-update-version ((ot ede-project))
- "The :version of the project OT has been updated.
- Handle saving, or other detail."
- (error "project-update-version not supported by %s" (object-name ot)))
- (defmethod ede-update-version-in-source ((this ede-project) version)
- "Change occurrences of a version string in sources.
- In project THIS, cycle over all targets to give them a chance to set
- their sources to VERSION."
- (ede-map-targets this (lambda (targ)
- (ede-update-version-in-source targ version))))
- (defmethod ede-update-version-in-source ((this ede-target) version)
- "In sources for THIS, change version numbers to VERSION."
- (if (and (slot-boundp this 'versionsource)
- (oref this versionsource))
- (let ((vs (oref this versionsource)))
- (while vs
- (with-current-buffer (find-file-noselect
- (ede-expand-filename this (car vs)))
- (goto-char (point-min))
- (let ((case-fold-search t))
- (if (re-search-forward "version:\\s-*\\([^ \t\n]+\\)" nil t)
- (progn
- (save-match-data
- (ede-make-buffer-writable))
- (delete-region (match-beginning 1)
- (match-end 1))
- (goto-char (match-beginning 1))
- (insert version)))))
- (setq vs (cdr vs))))))
- ;;; Writable files
- ;;
- ;; Utils for EDE when it needs to write a file that could be covered by a
- ;; version control system.
- (defun ede-make-buffer-writable (&optional buffer)
- "Make sure that BUFFER is writable.
- If BUFFER isn't specified, use the current buffer."
- (save-excursion
- (if buffer (set-buffer buffer))
- (toggle-read-only -1)))
- (provide 'ede/util)
- ;; Local variables:
- ;; generated-autoload-file: "loaddefs.el"
- ;; generated-autoload-load-name: "ede/util"
- ;; End:
- ;;; ede/util.el ends here
|