From a1019cb2ccde131d2466f2d70076a00059e3c71d Mon Sep 17 00:00:00 2001 From: Nathan Froyd Date: Wed, 19 Dec 2012 23:10:42 -0500 Subject: [PATCH] lazily compute MIN-EXTENSION for VECTOR-PUSH-EXTEND This change avoids a full call to LENGTH on every call to VECTOR-PUSH-EXTEND. --- src/code/array.lisp | 17 ++++++++--------- 1 file changed, 8 insertions(+), 9 deletions(-) diff --git a/src/code/array.lisp b/src/code/array.lisp index 0d44b09..8a4ddfe 100644 --- a/src/code/array.lisp +++ b/src/code/array.lisp @@ -836,18 +836,17 @@ of specialized arrays is supported." (setf (%array-fill-pointer array) (1+ fill-pointer)) fill-pointer)))) -(defun vector-push-extend (new-element - vector - &optional - (min-extension - (let ((length (length vector))) - (min (1+ length) - (- array-dimension-limit length))))) - (declare (fixnum min-extension)) +(defun vector-push-extend (new-element vector &optional min-extension) + (declare (type (or null fixnum) min-extension)) (let ((fill-pointer (fill-pointer vector))) (declare (fixnum fill-pointer)) (when (= fill-pointer (%array-available-elements vector)) - (adjust-array vector (+ fill-pointer (max 1 min-extension)))) + (let ((min-extension + (or min-extension + (let ((length (length vector))) + (min (1+ length) + (- array-dimension-limit length)))))) + (adjust-array vector (+ fill-pointer (max 1 min-extension))))) ;; disable bounds checking (locally (declare (optimize (safety 0))) (setf (aref vector fill-pointer) new-element)) -- 1.7.10.4