From 26c2dcaefcf9a178731141b0da677c2aad4e5641 Mon Sep 17 00:00:00 2001 From: Pavel Koneski Date: Wed, 4 Dec 2024 09:56:16 -0800 Subject: [PATCH] Correct error raised when slicing CLI arrays (#1827) --- Src/IronPython/Runtime/Operations/ArrayOps.cs | 6 +++++- Tests/test_array.py | 12 +++++++----- 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/Src/IronPython/Runtime/Operations/ArrayOps.cs b/Src/IronPython/Runtime/Operations/ArrayOps.cs index 60d2993b2..c58b2c435 100644 --- a/Src/IronPython/Runtime/Operations/ArrayOps.cs +++ b/Src/IronPython/Runtime/Operations/ArrayOps.cs @@ -429,7 +429,11 @@ private static Array GetSlice(Array data, Slice slice) { private static int[] TupleToIndices(Array a, IList tuple) { int[] indices = new int[tuple.Count]; for (int i = 0; i < indices.Length; i++) { - int iindex = Converter.ConvertToInt32(tuple[i]); + object? oindex = tuple[i]; + if (a.Rank != 1 && oindex is Slice) { + throw PythonOps.NotImplementedError("slice on multi-dimensional array"); + } + int iindex = Converter.ConvertToInt32(oindex); indices[i] = i < a.Rank ? FixIndex(a, iindex, i) : int.MinValue; } return indices; diff --git a/Tests/test_array.py b/Tests/test_array.py index 97d0bc902..4c71aaf55 100644 --- a/Tests/test_array.py +++ b/Tests/test_array.py @@ -166,12 +166,14 @@ def test_slice(self): def f(): array1[::2] = [x * 2 for x in range(11)] self.assertRaises(ValueError, f) - # slices on non-1-dim arrays are not supported + # slices on non-1D arrays are not supported yet array2 = System.Array.CreateInstance(int, 20, 20) - self.assertRaises(NotImplementedError, lambda: array2[:]) # TODO: TypeError? - self.assertRaises(TypeError, lambda: array2[:, :]) # TODO: NotImplementedError? This would work in Numpy and Sympy - self.assertRaises(TypeError, lambda: array2[:, :, :]) # OK - + # TODO: memoryview can slice ND views with a single slice + self.assertRaises(NotImplementedError, lambda: array2[:]) + # TODO: Numpy and Sympy can slice ND arrays with exactly N slices + self.assertRaises(NotImplementedError, lambda: array2[:, :]) + # TODO: Error matches memoryview; if slicing of ND arrays were supported, TypeError here would be expected + self.assertRaises(NotImplementedError, lambda: array2[:, :, :]) def test_creation(self): t = System.Array