about summary refs log tree commit diff
path: root/arrays.lisp
diff options
context:
space:
mode:
Diffstat (limited to 'arrays.lisp')
-rw-r--r--arrays.lisp18
1 files changed, 18 insertions, 0 deletions
diff --git a/arrays.lisp b/arrays.lisp
new file mode 100644
index 0000000000..76c18791ad
--- /dev/null
+++ b/arrays.lisp
@@ -0,0 +1,18 @@
+(in-package :alexandria)
+
+(defun copy-array (array &key (element-type (array-element-type array))
+                              (fill-pointer (and (array-has-fill-pointer-p array)
+                                                 (fill-pointer array)))
+                              (adjustable (adjustable-array-p array)))
+  "Returns an undisplaced copy of ARRAY, with same fill-pointer and
+adjustability (if any) as the original, unless overridden by the keyword
+arguments."
+ (let* ((dimensions (array-dimensions array))
+        (new-array (make-array dimensions
+                               :element-type element-type
+                               :adjustable adjustable
+                               :fill-pointer fill-pointer)))
+   (dotimes (i (array-total-size array))
+     (setf (row-major-aref new-array i)
+           (row-major-aref array i)))
+   new-array))