diff options
-rw-r--r-- | src/Partitioning.h | 20 | ||||
-rw-r--r-- | test/unit/testPartitioning.cxx | 26 |
2 files changed, 46 insertions, 0 deletions
diff --git a/src/Partitioning.h b/src/Partitioning.h index 11c64bc83..195daae9b 100644 --- a/src/Partitioning.h +++ b/src/Partitioning.h @@ -122,6 +122,26 @@ public: stepPartition++; } + void InsertPartitions(T partition, const T *positions, size_t length) { + if (stepPartition < partition) { + ApplyStep(partition); + } + body->InsertFromArray(partition, positions, 0, length); + stepPartition += static_cast<T>(length); + } + + void InsertPartitionsWithCast(T partition, const ptrdiff_t *positions, size_t length) { + // Used for 64-bit builds when T is 32-bits + if (stepPartition < partition) { + ApplyStep(partition); + } + T *pInsertion = body->InsertEmpty(partition, length); + for (size_t i = 0; i < length; i++) { + pInsertion[i] = static_cast<T>(positions[i]); + } + stepPartition += static_cast<T>(length); + } + void SetPartitionStartPosition(T partition, T pos) noexcept { ApplyStep(partition+1); if ((partition < 0) || (partition > body->Length())) { diff --git a/test/unit/testPartitioning.cxx b/test/unit/testPartitioning.cxx index 5a416f799..6abb6da44 100644 --- a/test/unit/testPartitioning.cxx +++ b/test/unit/testPartitioning.cxx @@ -95,6 +95,32 @@ TEST_CASE("Partitioning") { REQUIRE(8 == part.PositionFromPartition(2)); } + SECTION("InsertMultiple") { + part.InsertText(0, 10); + const Sci::Position positions[] { 2, 5, 7 }; + part.InsertPartitions(1, positions, std::size(positions)); + REQUIRE(4 == part.Partitions()); + REQUIRE(0 == part.PositionFromPartition(0)); + REQUIRE(2 == part.PositionFromPartition(1)); + REQUIRE(5 == part.PositionFromPartition(2)); + REQUIRE(7 == part.PositionFromPartition(3)); + REQUIRE(10 == part.PositionFromPartition(4)); + } + + SECTION("InsertMultipleWithCast") { + part.InsertText(0, 9); + REQUIRE(1 == part.Partitions()); + const ptrdiff_t positionsp[]{ 2, 4, 6, 8 }; + part.InsertPartitionsWithCast(1, positionsp, std::size(positionsp)); + REQUIRE(5 == part.Partitions()); + REQUIRE(0 == part.PositionFromPartition(0)); + REQUIRE(2 == part.PositionFromPartition(1)); + REQUIRE(4 == part.PositionFromPartition(2)); + REQUIRE(6 == part.PositionFromPartition(3)); + REQUIRE(8 == part.PositionFromPartition(4)); + REQUIRE(9 == part.PositionFromPartition(5)); + } + SECTION("InsertReversed") { part.InsertText(0, 3); part.InsertPartition(1, 2); |