diff options
| author | Ted Zlatanov <tzz@lifelogs.com> | 2011-10-17 13:40:27 -0400 | 
|---|---|---|
| committer | Ted Zlatanov <tzz@lifelogs.com> | 2011-10-17 13:40:27 -0400 | 
| commit | 0bc0638017ff5ddcfc4ba2467d7fa2d291583551 (patch) | |
| tree | f9d25f47929f75ca2f1e2f6263070a5317fb64f5 | |
| parent | f1bfb0db9821863101364e2369200ca2e545bd31 (diff) | |
| download | emacs-0bc0638017ff5ddcfc4ba2467d7fa2d291583551.tar.gz | |
* json.el: Bump version to 1.3; (json-alist-p, json-plist-p): Rewrite to avoid recursion.
| -rw-r--r-- | lisp/ChangeLog | 5 | ||||
| -rw-r--r-- | lisp/json.el | 21 | 
2 files changed, 18 insertions, 8 deletions
| diff --git a/lisp/ChangeLog b/lisp/ChangeLog index e3daabae644..8034cebf0e5 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,8 @@ +2011-10-17  Teodor Zlatanov  <tzz@lifelogs.com> + +	* json.el: Bump version to 1.3 and note change in History. +	(json-alist-p, json-plist-p): Rewrite to avoid recursion. +  2011-10-17  Stefan Monnier  <monnier@iro.umontreal.ca>  	* comint.el (comint-insert-input, comint-send-input) diff --git a/lisp/json.el b/lisp/json.el index 47448f4702a..33e985abbee 100644 --- a/lisp/json.el +++ b/lisp/json.el @@ -3,7 +3,7 @@  ;; Copyright (C) 2006-2011 Free Software Foundation, Inc.  ;; Author: Edward O'Connor <ted@oconnor.cx> -;; Version: 1.2 +;; Version: 1.3  ;; Keywords: convenience  ;; This file is part of GNU Emacs. @@ -47,6 +47,7 @@  ;;              other cleanups, bugfixes, and improvements.  ;; 2006-12-29 - XEmacs support, from Aidan Kehoe <kehoea@parhasard.net>.  ;; 2008-02-21 - Installed in GNU Emacs. +;; 2011-10-17 - Patch `json-alist-p' and `json-plist-p' to avoid recursion -tzz  ;;; Code: @@ -108,16 +109,20 @@ this around your call to `json-read' instead of `setq'ing it.")  (defun json-alist-p (list)    "Non-null if and only if LIST is an alist." -  (or (null list) -      (and (consp (car list)) -           (json-alist-p (cdr list))))) +  (while (consp list) +    (setq list (if (consp (car list)) +                   (cdr list) +                 'not-alist))) +  (null list))  (defun json-plist-p (list)    "Non-null if and only if LIST is a plist." -  (or (null list) -      (and (keywordp (car list)) -           (consp (cdr list)) -           (json-plist-p (cddr list))))) +  (while (consp list) +    (setq list (if (and (keywordp (car list)) +                        (consp (cdr list))) +                   (cddr list) +                 'not-plist))) +  (null list))  ;; Reader utilities | 
