[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Emacs-diffs] Changes to lisp/nxml/rng-util.el
From: |
Mark A. Hershberger |
Subject: |
[Emacs-diffs] Changes to lisp/nxml/rng-util.el |
Date: |
Fri, 23 Nov 2007 06:58:21 +0000 |
CVSROOT: /sources/emacs
Module name: emacs
Changes by: Mark A. Hershberger <hexmode> 07/11/23 06:58:00
Index: lisp/nxml/rng-util.el
===================================================================
RCS file: lisp/nxml/rng-util.el
diff -N lisp/nxml/rng-util.el
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ lisp/nxml/rng-util.el 23 Nov 2007 06:57:51 -0000 1.1
@@ -0,0 +1,172 @@
+;;; rng-util.el --- utility functions for RELAX NG library
+
+;; Copyright (C) 2003 Free Software Foundation, Inc.
+
+;; Author: James Clark
+;; Keywords: XML, RelaxNG
+
+;; 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 2 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, write to the Free
+;; Software Foundation, Inc., 59 Temple Place, Suite 330, Boston,
+;; MA 02111-1307 USA
+
+;;; Commentary:
+
+;;; Code:
+
+(defun rng-make-datatypes-uri (uri)
+ (if (string-equal uri "")
+ ;; The spec doesn't say to do this, but it's perfectly conformant
+ ;; and better than using nil, I think.
+ 'http://relaxng.org/ns/structure/1.0
+ (intern uri)))
+
+(defconst rng-xsd-datatypes-uri
+ (rng-make-datatypes-uri "http://www.w3.org/2001/XMLSchema-datatypes"))
+
+(defconst rng-builtin-datatypes-uri (rng-make-datatypes-uri ""))
+
+(defun rng-uniquify-eq (list)
+ "Destructively remove any element from LIST that is eq to
+its predecessor."
+ (and list
+ (let ((head list))
+ (while (cdr head)
+ (if (eq (car head) (cadr head))
+ (setcdr head (cddr head)))
+ (setq head (cdr head)))
+ list)))
+
+(defun rng-uniquify-equal (list)
+ "Destructively remove any element from LIST that is equal to
+its predecessor."
+ (and list
+ (let ((head list))
+ (while (cdr head)
+ (if (equal (car head) (cadr head))
+ (setcdr head (cddr head)))
+ (setq head (cdr head)))
+ list)))
+
+(defun rng-blank-p (str) (string-match "\\`[ \t\n\r]*\\'" str))
+
+(defun rng-substq (new old list)
+ "Replace first member of LIST (if any) that is eq to OLD by NEW.
+LIST is not modified."
+ (cond ((null list) nil)
+ ((eq (car list) old)
+ (cons new (cdr list)))
+ (t
+ (let ((tail (cons (car list)
+ nil))
+ (rest (cdr list)))
+ (setq list tail)
+ (while rest
+ (let ((item (car rest)))
+ (setq rest (cdr rest))
+ (cond ((eq item old)
+ (setcdr tail
+ (cons new rest))
+ (setq rest nil))
+ (t
+ (setq tail
+ (setcdr tail
+ (cons item nil))))))))
+ list)))
+
+(defun rng-complete-before-point (start table prompt &optional predicate hist)
+ "Complete text between START and point.
+Replaces the text between START and point with a string chosen using a
+completion table and, when needed, input read from the user with the
+minibuffer.
+Returns the new string if either a complete and unique completion was
+determined automatically or input was read from the user. Otherwise,
+returns nil.
+TABLE is an alist, a symbol bound to a function or an obarray as with
+the function `completing-read'.
+PROMPT is the string to prompt with if user input is needed.
+PREDICATE is nil or a function as with `completing-read'.
+HIST, if non-nil, specifies a history list as with `completing-read'."
+ (let* ((orig (buffer-substring-no-properties start (point)))
+ (completion (try-completion orig table predicate)))
+ (cond ((not completion)
+ (if (string= orig "")
+ (message "No completions available")
+ (message "No completion for %s" (rng-quote-string orig)))
+ (ding)
+ nil)
+ ((eq completion t) orig)
+ ((not (string= completion orig))
+ (delete-region start (point))
+ (insert completion)
+ (cond ((not (rng-completion-exact-p completion table predicate))
+ (message "Incomplete")
+ nil)
+ ((eq (try-completion completion table predicate) t)
+ completion)
+ (t
+ (message "Complete but not unique")
+ nil)))
+ (t
+ (setq completion
+ (let ((saved-minibuffer-setup-hook
+ (default-value 'minibuffer-setup-hook)))
+ (add-hook 'minibuffer-setup-hook
+ 'minibuffer-completion-help
+ t)
+ (unwind-protect
+ (completing-read prompt
+ table
+ predicate
+ nil
+ orig
+ hist)
+ (setq-default minibuffer-setup-hook
+ saved-minibuffer-setup-hook))))
+ (delete-region start (point))
+ (insert completion)
+ completion))))
+
+(defun rng-completion-exact-p (string table predicate)
+ (cond ((symbolp table)
+ (funcall table string predicate 'lambda))
+ ((vectorp table)
+ (intern-soft string table))
+ (t (assoc string table))))
+
+(defun rng-quote-string (s)
+ (concat "\"" s "\""))
+
+(defun rng-escape-string (s)
+ (replace-regexp-in-string "[&\"<>]"
+ (lambda (match)
+ (cdr (assoc match
+ '(("&" . "&")
+ ("\"" . """)
+ (">" . ">")
+ ("<" . "<")))))
+ s
+ t))
+
+(defun rng-collapse-space (string)
+ (setq string
+ (replace-regexp-in-string "[ \t\r\n]+" " " string t t))
+ (when (string-match "\\` " string)
+ (setq string (substring string 1)))
+ (when (string-match " \\'" string)
+ (setq string (substring string 0 -1)))
+ string)
+
+(provide 'rng-util)
+
+;;; rng-util.el ends here
[Prev in Thread] |
Current Thread |
[Next in Thread] |
- [Emacs-diffs] Changes to lisp/nxml/rng-util.el,
Mark A. Hershberger <=