aboutsummaryrefslogtreecommitdiffhomepage
path: root/test/unit/testSparseVector.cxx
diff options
context:
space:
mode:
authorNeil <nyamatongwe@gmail.com>2019-12-02 08:34:47 +1100
committerNeil <nyamatongwe@gmail.com>2019-12-02 08:34:47 +1100
commite9f310d4043e58739c9e661159a35847a7ba5df5 (patch)
tree8254897533f01e93c3cc4f9baf7a5d57dd678862 /test/unit/testSparseVector.cxx
parent2892e0d04bcf02fe249939f7c22fe8c6d780233a (diff)
downloadscintilla-mirror-e9f310d4043e58739c9e661159a35847a7ba5df5.tar.gz
Backport: Add SparseVector::IndexAfter for efficiently finding elements in a range.
Backport of changeset 7779:67b7e8f152a9.
Diffstat (limited to 'test/unit/testSparseVector.cxx')
-rw-r--r--test/unit/testSparseVector.cxx17
1 files changed, 17 insertions, 0 deletions
diff --git a/test/unit/testSparseVector.cxx b/test/unit/testSparseVector.cxx
index 4d3b872e1..c9fc58bf1 100644
--- a/test/unit/testSparseVector.cxx
+++ b/test/unit/testSparseVector.cxx
@@ -248,6 +248,23 @@ TEST_CASE("SparseTextInt") {
REQUIRE(0 == st.ValueAt(4));
st.Check();
}
+
+ SECTION("IndexAfter") {
+ st.InsertSpace(0, 5);
+ REQUIRE(1 == st.Elements());
+ REQUIRE(0 == st.IndexAfter(-1));
+ REQUIRE(0 == st.PositionOfElement(0));
+ REQUIRE(1 == st.IndexAfter(0));
+ REQUIRE(5 == st.PositionOfElement(1));
+ st.SetValueAt(3, 3);
+ REQUIRE(2 == st.Elements());
+ REQUIRE(0 == st.IndexAfter(-1));
+ REQUIRE(0 == st.PositionOfElement(0));
+ REQUIRE(1 == st.IndexAfter(0));
+ REQUIRE(3 == st.PositionOfElement(1));
+ REQUIRE(2 == st.IndexAfter(3));
+ REQUIRE(5 == st.PositionOfElement(2));
+ }
}
TEST_CASE("SparseTextString") {