Revamp Geary.FolderPath implementation

Convert getters that look like properties into actual properties,
remove unused and redundant public and internal API, convert
implementation to use a tree that aucyally maintains references between
steps, rather than each creating a new list of path steps and
manipulating that.
This commit is contained in:
Michael Gratton 2019-01-14 17:26:18 +11:00 committed by Michael James Gratton
parent 423a1dcbf0
commit ddbe6e0b09
10 changed files with 323 additions and 293 deletions

View file

@ -17,10 +17,12 @@ public class Geary.FolderPathTest : TestCase {
add_test("get_child_from_child", get_child_from_child);
add_test("root_is_root", root_is_root);
add_test("child_is_not_root", root_is_root);
add_test("as_list", as_list);
add_test("as_array", as_array);
add_test("is_top_level", is_top_level);
add_test("path_to_string", path_to_string);
add_test("path_parent", path_parent);
add_test("path_equal", path_equal);
add_test("path_hash", path_hash);
add_test("path_compare", path_compare);
add_test("path_compare_normalised", path_compare_normalised);
}
@ -35,15 +37,15 @@ public class Geary.FolderPathTest : TestCase {
public void get_child_from_root() throws GLib.Error {
assert_string(
">test",
this.root.get_child("test").to_string()
"test",
this.root.get_child("test").name
);
}
public void get_child_from_child() throws GLib.Error {
assert_string(
">test1>test2",
this.root.get_child("test1").get_child("test2").to_string()
"test2",
this.root.get_child("test1").get_child("test2").name
);
}
@ -55,17 +57,32 @@ public class Geary.FolderPathTest : TestCase {
assert_false(this.root.get_child("test").is_root);
}
public void as_list() throws GLib.Error {
assert_true(this.root.as_list().size == 1, "Root list");
public void as_array() throws GLib.Error {
assert_true(this.root.as_array().length == 0, "Root list");
assert_int(
2,
this.root.get_child("test").as_list().size,
"Child list size"
1,
this.root.get_child("test").as_array().length,
"Child array length"
);
assert_string(
"test",
this.root.get_child("test").as_list()[1],
"Child list contents"
this.root.get_child("test").as_array()[0],
"Child array contents"
);
assert_int(
2,
this.root.get_child("test1").get_child("test2").as_array().length,
"Descendent array length"
);
assert_string(
"test1",
this.root.get_child("test1").get_child("test2").as_array()[0],
"Descendent first child"
);
assert_string(
"test2",
this.root.get_child("test1").get_child("test2").as_array()[1],
"Descendent second child"
);
}
@ -81,15 +98,24 @@ public class Geary.FolderPathTest : TestCase {
);
}
public void path_to_string() throws GLib.Error {
assert_string(">", this.root.to_string());
assert_string(">test", this.root.get_child("test").to_string());
assert_string(
">test1>test2",
this.root.get_child("test1").get_child("test2").to_string()
);
}
public void path_parent() throws GLib.Error {
assert_null(this.root.get_parent(), "Root parent");
assert_null(this.root.parent, "Root parent");
assert_string(
"",
this.root.get_child("test").get_parent().basename,
this.root.get_child("test").parent.name,
"Root child parent");
assert_string(
"test1",
this.root.get_child("test1").get_child("test2").get_parent().basename,
this.root.get_child("test1").get_child("test2").parent.name,
"Child parent");
}
@ -110,6 +136,17 @@ public class Geary.FolderPathTest : TestCase {
);
}
public void path_hash() throws GLib.Error {
assert_true(
this.root.hash() !=
this.root.get_child("test").hash()
);
assert_true(
this.root.get_child("test1").hash() !=
this.root.get_child("test2").hash()
);
}
public void path_compare() throws GLib.Error {
assert_int(0, this.root.compare_to(this.root), "Root equality");
assert_int(0,