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.
(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."
;; Skip over the '"'
(json-advance)
(if characters
- (apply 'string (nreverse characters))
+ (concat (nreverse characters))
"")))
;; String encoding
(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