fix bug that treebox.clear only rm the 1st node
This commit is contained in:
parent
a22954d8d8
commit
eb7ae0d635
@ -1,7 +1,7 @@
|
||||
/**
|
||||
* A Categorize Implementation
|
||||
* Nana C++ Library(http://www.nanapro.org)
|
||||
* Copyright(C) 2003-2016 Jinhao(cnjinhao@hotmail.com)
|
||||
* Copyright(C) 2003-2017 Jinhao(cnjinhao@hotmail.com)
|
||||
*
|
||||
* Distributed under the Boost Software License, Version 1.0.
|
||||
* (See accompanying file LICENSE_1_0.txt or copy at
|
||||
|
||||
@ -1,6 +1,6 @@
|
||||
/*
|
||||
* A Tree Container class implementation
|
||||
* Copyright(C) 2003-2016 Jinhao(cnjinhao@hotmail.com)
|
||||
* Copyright(C) 2003-2017 Jinhao(cnjinhao@hotmail.com)
|
||||
*
|
||||
* Distributed under the Boost Software License, Version 1.0.
|
||||
* (See accompanying file LICENSE_1_0.txt or copy at
|
||||
@ -76,12 +76,17 @@ namespace detail
|
||||
|
||||
~tree_cont()
|
||||
{
|
||||
clear();
|
||||
clear(&root_);
|
||||
}
|
||||
|
||||
void clear()
|
||||
void clear(node_type* node)
|
||||
{
|
||||
remove(root_.child);
|
||||
while (node->child)
|
||||
{
|
||||
//If there is a sibling of child, the root_.child
|
||||
//will be assigned with the sibling.
|
||||
remove(node->child);
|
||||
}
|
||||
}
|
||||
|
||||
bool verify(const node_type* node) const
|
||||
|
||||
@ -201,6 +201,9 @@ namespace nana
|
||||
/// Set the check state, and it returns itself.
|
||||
item_proxy& check(bool);
|
||||
|
||||
/// Clears the child nodes
|
||||
item_proxy& clear();
|
||||
|
||||
/// Return true when the node is expanded \todo change to expanded ??
|
||||
bool expanded() const;
|
||||
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
/*
|
||||
* A Categorize Implementation
|
||||
* Nana C++ Library(http://www.nanapro.org)
|
||||
* Copyright(C) 2003-2016 Jinhao(cnjinhao@hotmail.com)
|
||||
* Copyright(C) 2003-2017 Jinhao(cnjinhao@hotmail.com)
|
||||
*
|
||||
* Distributed under the Boost Software License, Version 1.0.
|
||||
* (See accompanying file LICENSE_1_0.txt or copy at
|
||||
@ -343,7 +343,7 @@ namespace nana
|
||||
{
|
||||
if(tree_.get_root()->child)
|
||||
{
|
||||
tree_.clear();
|
||||
tree_.clear(tree_.get_root());
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
|
||||
@ -2175,8 +2175,8 @@ namespace nana
|
||||
|
||||
void treebox::clear()
|
||||
{
|
||||
auto impl = get_drawer_trigger().impl();
|
||||
impl->attr.tree_cont.clear();
|
||||
auto& tree_cont = get_drawer_trigger().impl()->attr.tree_cont;
|
||||
tree_cont.clear(tree_cont.get_root());
|
||||
get_drawer_trigger().draw();
|
||||
}
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user