diff options
| author | Neil <nyamatongwe@gmail.com> | 2019-12-02 08:39:52 +1100 | 
|---|---|---|
| committer | Neil <nyamatongwe@gmail.com> | 2019-12-02 08:39:52 +1100 | 
| commit | cf150e2082ff95d8da6f8f74e1d15e1b33ab2e19 (patch) | |
| tree | bd1cbe389c47c6e7a6b1663d2be5254e17d5f61b /test/unit/testSparseVector.cxx | |
| parent | e9f310d4043e58739c9e661159a35847a7ba5df5 (diff) | |
| download | scintilla-mirror-cf150e2082ff95d8da6f8f74e1d15e1b33ab2e19.tar.gz | |
Backport: Add SparseVector::DeleteRange for efficiently removing ranges.
Backport of changeset 7780:88e65c696c40.
Diffstat (limited to 'test/unit/testSparseVector.cxx')
| -rw-r--r-- | test/unit/testSparseVector.cxx | 106 | 
1 files changed, 106 insertions, 0 deletions
| diff --git a/test/unit/testSparseVector.cxx b/test/unit/testSparseVector.cxx index c9fc58bf1..c5e991a69 100644 --- a/test/unit/testSparseVector.cxx +++ b/test/unit/testSparseVector.cxx @@ -217,6 +217,112 @@ TEST_CASE("SparseVector") {  		REQUIRE("-" == Representation(st));  	} +	SECTION("DeleteRange") { +		REQUIRE(1 == st.Elements()); +		st.InsertSpace(0, 10); +		st.SetValueAt(9, UniqueStringCopy("9")); +		st.SetValueAt(7, UniqueStringCopy("7")); +		st.SetValueAt(4, UniqueStringCopy("4")); +		st.SetValueAt(3, UniqueStringCopy("3")); +		REQUIRE(5 == st.Elements()); +		REQUIRE(10 == st.Length()); +		REQUIRE("---34--7-9-" == Representation(st)); +		// Delete in space +		st.DeleteRange(1, 1); +		REQUIRE(5 == st.Elements()); +		REQUIRE(9 == st.Length()); +		REQUIRE("--34--7-9-" == Representation(st)); +		// Delete 2 values +		st.DeleteRange(3, 4); +		REQUIRE(3 == st.Elements()); +		REQUIRE(5 == st.Length()); +		REQUIRE("--3-9-" == Representation(st)); +		// Deletion at start +		st.DeleteRange(0, 1); +		REQUIRE(3 == st.Elements()); +		REQUIRE(4 == st.Length()); +		REQUIRE("-3-9-" == Representation(st)); +	} + +	SECTION("DeleteRangeAtEnds") { +		// There are always elements at start and end although they can be nulled +		REQUIRE(1 == st.Elements()); +		st.InsertSpace(0, 4); +		REQUIRE(4 == st.Length()); +		st.SetValueAt(1, UniqueStringCopy("3")); +		st.SetValueAt(4, UniqueStringCopy("9")); +		REQUIRE("-3--9" == Representation(st)); +		REQUIRE(2 == st.Elements()); +		// Empty deletion at end -> no effect +		st.DeleteRange(4, 0); +		REQUIRE(2 == st.Elements()); +		REQUIRE(4 == st.Length()); +		REQUIRE("-3--9" == Representation(st)); +		// Delete value at start +		st.InsertSpace(0, 1); +		st.SetValueAt(0, UniqueStringCopy("0")); +		REQUIRE(2 == st.Elements()); +		REQUIRE(5 == st.Length()); +		REQUIRE("0-3--9" == Representation(st)); +		st.DeleteRange(0, 1); +		REQUIRE(2 == st.Elements()); +		REQUIRE(4 == st.Length()); +		REQUIRE("03--9" == Representation(st)); +		// Empty deletion at start -> no effect +		st.InsertSpace(0, 1); +		st.SetValueAt(0, UniqueStringCopy("1")); +		REQUIRE(3 == st.Elements()); +		REQUIRE(5 == st.Length()); +		REQUIRE("103--9" == Representation(st)); +		st.DeleteRange(0, 0); +		REQUIRE(3 == st.Elements()); +		REQUIRE(5 == st.Length()); +		REQUIRE("103--9" == Representation(st)); +	} + +	SECTION("DeleteStartingRange") { +		REQUIRE(1 == st.Elements()); +		st.InsertSpace(0, 2); +		st.SetValueAt(0, UniqueStringCopy("1")); +		st.SetValueAt(1, UniqueStringCopy("2")); +		REQUIRE(2 == st.Length()); +		REQUIRE("12-" == Representation(st)); +		st.DeleteRange(0,1); +		REQUIRE(1 == st.Length()); +		REQUIRE("2-" == Representation(st)); +		st.DeleteRange(0,1); +		REQUIRE(0 == st.Length()); +		REQUIRE("-" == Representation(st)); +		st.InsertSpace(0, 2); +		st.SetValueAt(1, UniqueStringCopy("1")); +		REQUIRE(2 == st.Length()); +		REQUIRE("-1-" == Representation(st)); +		st.DeleteRange(0, 2); +		REQUIRE("-" == Representation(st)); +		st.InsertSpace(0, 4); +		st.SetValueAt(1, UniqueStringCopy("1")); +		st.SetValueAt(3, UniqueStringCopy("3")); +		REQUIRE(4 == st.Length()); +		REQUIRE("-1-3-" == Representation(st)); +		st.DeleteRange(0, 3); +		REQUIRE("3-" == Representation(st)); +		st.DeleteRange(0, 1); +		REQUIRE("-" == Representation(st)); +		st.InsertSpace(0, 4); +		st.SetValueAt(1, UniqueStringCopy("1")); +		st.SetValueAt(4, UniqueStringCopy("4")); +		st.SetValueAt(3, UniqueStringCopy("3")); +		REQUIRE("-1-34" == Representation(st)); +		st.DeleteRange(1, 3); +		REQUIRE("-4" == Representation(st)); +		st.InsertSpace(1, 3); +		REQUIRE("----4" == Representation(st)); +		st.SetValueAt(4, UniqueStringCopy("4")); +		st.SetValueAt(3, UniqueStringCopy("3")); +		REQUIRE("---34" == Representation(st)); +		st.DeleteRange(1, 3); +		REQUIRE("-4" == Representation(st)); +	}  }  TEST_CASE("SparseTextInt") { | 
