]> git.eshelyaron.com Git - emacs.git/commitdiff
Tiny JSON performance improvement
authorMark Oteiza <mvoteiza@udel.edu>
Mon, 14 Aug 2017 05:54:11 +0000 (01:54 -0400)
committerMark Oteiza <mvoteiza@udel.edu>
Mon, 14 Aug 2017 05:54:11 +0000 (01:54 -0400)
Get rid of some needless uses of apply.  Measuring with
  (benchmark-run 10 (json-read-file "test.json"))
showed 1.5-2.5% reduction of execution time.
* lisp/json.el (json-peek): Nix let-binding.
(json-read-string): Use concat for making a string from chars.
(json-read-array): Use cond and more appropriate conversion instead
of blindly applying.

lisp/json.el

index 3def94ce0426b01cf76d38400396319a52364bd9..627e65efa45e67e9e1f2dcf64e4dc1bceb2f607a 100644 (file)
@@ -193,8 +193,7 @@ Unlike `reverse', this keeps the property-value pairs intact."
 
 (defsubst json-peek ()
   "Return the character at point."
-  (let ((char (char-after (point))))
-    (or char :json-eof)))
+  (or (char-after (point)) :json-eof))
 
 (defsubst json-pop ()
   "Advance past the character at point, returning it."
@@ -415,7 +414,7 @@ representation will be parsed correctly."
     ;; Skip over the '"'
     (json-advance)
     (if characters
-        (apply 'string (nreverse characters))
+        (concat (nreverse characters))
       "")))
 
 ;; String encoding
@@ -639,7 +638,9 @@ become JSON objects."
           (signal 'json-error (list 'bleah)))))
     ;; Skip over the "]"
     (json-advance)
-    (apply json-array-type (nreverse elements))))
+    (pcase json-array-type
+      (`vector (nreverse (vconcat elements)))
+      (`list (nreverse elements)))))
 
 ;; Array encoding