mirror of
https://github.com/cjcliffe/CubicSDR.git
synced 2024-11-23 12:18:37 -05:00
Bookmarks: cleanup item data properly
This commit is contained in:
parent
5fe844b8af
commit
c1184d24db
@ -703,6 +703,7 @@ AppFrame::AppFrame() :
|
|||||||
}
|
}
|
||||||
|
|
||||||
AppFrame::~AppFrame() {
|
AppFrame::~AppFrame() {
|
||||||
|
|
||||||
waterfallDataThread->terminate();
|
waterfallDataThread->terminate();
|
||||||
t_FFTData->join();
|
t_FFTData->join();
|
||||||
}
|
}
|
||||||
|
@ -67,7 +67,6 @@ void BookmarkMgr::saveToFile(std::string bookmarkFn, bool backup) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool BookmarkMgr::loadFromFile(std::string bookmarkFn, bool backup) {
|
bool BookmarkMgr::loadFromFile(std::string bookmarkFn, bool backup) {
|
||||||
wxFileName loadFile(wxGetApp().getConfig()->getConfigDir(), bookmarkFn);
|
wxFileName loadFile(wxGetApp().getConfig()->getConfigDir(), bookmarkFn);
|
||||||
wxFileName failFile(wxGetApp().getConfig()->getConfigDir(), bookmarkFn + ".failedload");
|
wxFileName failFile(wxGetApp().getConfig()->getConfigDir(), bookmarkFn + ".failedload");
|
||||||
@ -324,12 +323,16 @@ BookmarkList BookmarkMgr::getBookmarks(std::string group) {
|
|||||||
|
|
||||||
|
|
||||||
void BookmarkMgr::getGroups(BookmarkNames &arr) {
|
void BookmarkMgr::getGroups(BookmarkNames &arr) {
|
||||||
|
std::lock_guard < std::mutex > lockData(busy_lock);
|
||||||
|
|
||||||
for (BookmarkMap::iterator i = bmData.begin(); i!= bmData.end(); ++i) {
|
for (BookmarkMap::iterator i = bmData.begin(); i!= bmData.end(); ++i) {
|
||||||
arr.push_back(i->first);
|
arr.push_back(i->first);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void BookmarkMgr::getGroups(wxArrayString &arr) {
|
void BookmarkMgr::getGroups(wxArrayString &arr) {
|
||||||
|
std::lock_guard < std::mutex > lockData(busy_lock);
|
||||||
|
|
||||||
for (BookmarkMap::iterator i = bmData.begin(); i!= bmData.end(); ++i) {
|
for (BookmarkMap::iterator i = bmData.begin(); i!= bmData.end(); ++i) {
|
||||||
arr.push_back(i->first);
|
arr.push_back(i->first);
|
||||||
}
|
}
|
||||||
@ -350,6 +353,7 @@ bool BookmarkMgr::getExpandState(std::string groupName) {
|
|||||||
|
|
||||||
|
|
||||||
void BookmarkMgr::updateActiveList() {
|
void BookmarkMgr::updateActiveList() {
|
||||||
|
|
||||||
BookmarkView *bmv = wxGetApp().getAppFrame()->getBookmarkView();
|
BookmarkView *bmv = wxGetApp().getAppFrame()->getBookmarkView();
|
||||||
|
|
||||||
if (bmv) {
|
if (bmv) {
|
||||||
@ -358,6 +362,9 @@ void BookmarkMgr::updateActiveList() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void BookmarkMgr::updateBookmarks() {
|
void BookmarkMgr::updateBookmarks() {
|
||||||
|
|
||||||
|
std::lock_guard < std::mutex > lockData(busy_lock);
|
||||||
|
|
||||||
BookmarkView *bmv = wxGetApp().getAppFrame()->getBookmarkView();
|
BookmarkView *bmv = wxGetApp().getAppFrame()->getBookmarkView();
|
||||||
|
|
||||||
if (bmv) {
|
if (bmv) {
|
||||||
@ -366,6 +373,9 @@ void BookmarkMgr::updateBookmarks() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void BookmarkMgr::updateBookmarks(std::string group) {
|
void BookmarkMgr::updateBookmarks(std::string group) {
|
||||||
|
|
||||||
|
std::lock_guard < std::mutex > lockData(busy_lock);
|
||||||
|
|
||||||
BookmarkView *bmv = wxGetApp().getAppFrame()->getBookmarkView();
|
BookmarkView *bmv = wxGetApp().getAppFrame()->getBookmarkView();
|
||||||
|
|
||||||
if (bmv) {
|
if (bmv) {
|
||||||
@ -376,6 +386,7 @@ void BookmarkMgr::updateBookmarks(std::string group) {
|
|||||||
|
|
||||||
void BookmarkMgr::addRecent(DemodulatorInstance *demod) {
|
void BookmarkMgr::addRecent(DemodulatorInstance *demod) {
|
||||||
std::lock_guard < std::mutex > lock(busy_lock);
|
std::lock_guard < std::mutex > lock(busy_lock);
|
||||||
|
|
||||||
recents.push_back(demodToBookmarkEntry(demod));
|
recents.push_back(demodToBookmarkEntry(demod));
|
||||||
|
|
||||||
trimRecents();
|
trimRecents();
|
||||||
@ -403,7 +414,7 @@ void BookmarkMgr::removeRecent(BookmarkEntryPtr be) {
|
|||||||
|
|
||||||
|
|
||||||
BookmarkList BookmarkMgr::getRecents() {
|
BookmarkList BookmarkMgr::getRecents() {
|
||||||
|
std::lock_guard < std::mutex > lockData(busy_lock);
|
||||||
return BookmarkList(recents.rbegin(), recents.rend());
|
return BookmarkList(recents.rbegin(), recents.rend());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -113,7 +113,6 @@ public:
|
|||||||
BookmarkRangeList getRanges();
|
BookmarkRangeList getRanges();
|
||||||
void clearRanges();
|
void clearRanges();
|
||||||
|
|
||||||
|
|
||||||
static std::wstring getBookmarkEntryDisplayName(BookmarkEntryPtr bmEnt);
|
static std::wstring getBookmarkEntryDisplayName(BookmarkEntryPtr bmEnt);
|
||||||
static std::wstring getActiveDisplayName(DemodulatorInstance *demod);
|
static std::wstring getActiveDisplayName(DemodulatorInstance *demod);
|
||||||
|
|
||||||
|
@ -158,6 +158,16 @@ BookmarkView::BookmarkView( wxWindow* parent, wxWindowID id, const wxPoint& pos,
|
|||||||
mouseTracker.setTarget(this);
|
mouseTracker.setTarget(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BookmarkView::~BookmarkView() {
|
||||||
|
|
||||||
|
dragItem = nullptr;
|
||||||
|
dragItemId = nullptr;
|
||||||
|
editingLabel = false;
|
||||||
|
|
||||||
|
visualDragItem = nullptr;
|
||||||
|
nextEnt = nullptr;
|
||||||
|
nextDemod = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
void BookmarkView::onUpdateTimer( wxTimerEvent& /* event */ ) {
|
void BookmarkView::onUpdateTimer( wxTimerEvent& /* event */ ) {
|
||||||
if (!this->IsShown()) {
|
if (!this->IsShown()) {
|
||||||
@ -260,7 +270,7 @@ wxTreeItemId BookmarkView::refreshBookmarks() {
|
|||||||
tvi->type = TreeViewItem::TREEVIEW_ITEM_TYPE_GROUP;
|
tvi->type = TreeViewItem::TREEVIEW_ITEM_TYPE_GROUP;
|
||||||
tvi->groupName = gn_i;
|
tvi->groupName = gn_i;
|
||||||
wxTreeItemId group_itm = m_treeView->AppendItem(bookmarkBranch, gn_i);
|
wxTreeItemId group_itm = m_treeView->AppendItem(bookmarkBranch, gn_i);
|
||||||
m_treeView->SetItemData(group_itm, tvi);
|
SetTreeItemData(group_itm, tvi);
|
||||||
groups[gn_i] = group_itm;
|
groups[gn_i] = group_itm;
|
||||||
if (prevSel != nullptr && prevSel->type == TreeViewItem::TREEVIEW_ITEM_TYPE_GROUP && gn_i == prevSel->groupName) {
|
if (prevSel != nullptr && prevSel->type == TreeViewItem::TREEVIEW_ITEM_TYPE_GROUP && gn_i == prevSel->groupName) {
|
||||||
bmSelFound = group_itm;
|
bmSelFound = group_itm;
|
||||||
@ -304,7 +314,7 @@ wxTreeItemId BookmarkView::refreshBookmarks() {
|
|||||||
tvi->groupName = gn_i;
|
tvi->groupName = gn_i;
|
||||||
|
|
||||||
wxTreeItemId itm = m_treeView->AppendItem(groupItem, labelVal);
|
wxTreeItemId itm = m_treeView->AppendItem(groupItem, labelVal);
|
||||||
m_treeView->SetItemData(itm, tvi);
|
SetTreeItemData(itm, tvi);
|
||||||
if (prevSel != nullptr && prevSel->type == TreeViewItem::TREEVIEW_ITEM_TYPE_BOOKMARK && prevSel->bookmarkEnt == bmEnt && groupExpanded) {
|
if (prevSel != nullptr && prevSel->type == TreeViewItem::TREEVIEW_ITEM_TYPE_BOOKMARK && prevSel->bookmarkEnt == bmEnt && groupExpanded) {
|
||||||
bmSelFound = itm;
|
bmSelFound = itm;
|
||||||
}
|
}
|
||||||
@ -331,7 +341,7 @@ void BookmarkView::doUpdateActiveList() {
|
|||||||
TreeViewItem *prevSel = itemToTVI(m_treeView->GetSelection());
|
TreeViewItem *prevSel = itemToTVI(m_treeView->GetSelection());
|
||||||
|
|
||||||
// Actives
|
// Actives
|
||||||
m_treeView->DeleteChildren(activeBranch);
|
DeleteChildrenOfItem(activeBranch);
|
||||||
|
|
||||||
bool activeExpandState = expandState["active"];
|
bool activeExpandState = expandState["active"];
|
||||||
bool searchState = (searchKeywords.size() != 0);
|
bool searchState = (searchKeywords.size() != 0);
|
||||||
@ -362,7 +372,7 @@ void BookmarkView::doUpdateActiveList() {
|
|||||||
tvi->demod = demod_i;
|
tvi->demod = demod_i;
|
||||||
|
|
||||||
wxTreeItemId itm = m_treeView->AppendItem(activeBranch,activeLabel);
|
wxTreeItemId itm = m_treeView->AppendItem(activeBranch,activeLabel);
|
||||||
m_treeView->SetItemData(itm, tvi);
|
SetTreeItemData(itm, tvi);
|
||||||
|
|
||||||
if (nextDemod != nullptr && nextDemod == demod_i) {
|
if (nextDemod != nullptr && nextDemod == demod_i) {
|
||||||
selItem = itm;
|
selItem = itm;
|
||||||
@ -375,7 +385,7 @@ void BookmarkView::doUpdateActiveList() {
|
|||||||
bool rangeExpandState = searchState?false:expandState["range"];
|
bool rangeExpandState = searchState?false:expandState["range"];
|
||||||
|
|
||||||
BookmarkRangeList bmRanges = wxGetApp().getBookmarkMgr().getRanges();
|
BookmarkRangeList bmRanges = wxGetApp().getBookmarkMgr().getRanges();
|
||||||
m_treeView->DeleteChildren(rangeBranch);
|
DeleteChildrenOfItem(rangeBranch);
|
||||||
|
|
||||||
for (auto &re_i: bmRanges) {
|
for (auto &re_i: bmRanges) {
|
||||||
TreeViewItem* tvi = new TreeViewItem();
|
TreeViewItem* tvi = new TreeViewItem();
|
||||||
@ -390,7 +400,7 @@ void BookmarkView::doUpdateActiveList() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
wxTreeItemId itm = m_treeView->AppendItem(rangeBranch, labelVal);
|
wxTreeItemId itm = m_treeView->AppendItem(rangeBranch, labelVal);
|
||||||
m_treeView->SetItemData(itm, tvi);
|
SetTreeItemData(itm, tvi);
|
||||||
|
|
||||||
if (nextRange == re_i) {
|
if (nextRange == re_i) {
|
||||||
selItem = itm;
|
selItem = itm;
|
||||||
@ -405,7 +415,7 @@ void BookmarkView::doUpdateActiveList() {
|
|||||||
|
|
||||||
// Recents
|
// Recents
|
||||||
BookmarkList bmRecents = wxGetApp().getBookmarkMgr().getRecents();
|
BookmarkList bmRecents = wxGetApp().getBookmarkMgr().getRecents();
|
||||||
m_treeView->DeleteChildren(recentBranch);
|
DeleteChildrenOfItem(recentBranch);
|
||||||
|
|
||||||
for (auto &bmr_i: bmRecents) {
|
for (auto &bmr_i: bmRecents) {
|
||||||
TreeViewItem* tvi = new TreeViewItem();
|
TreeViewItem* tvi = new TreeViewItem();
|
||||||
@ -438,7 +448,7 @@ void BookmarkView::doUpdateActiveList() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
wxTreeItemId itm = m_treeView->AppendItem(recentBranch, labelVal);
|
wxTreeItemId itm = m_treeView->AppendItem(recentBranch, labelVal);
|
||||||
m_treeView->SetItemData(itm, tvi);
|
SetTreeItemData(itm, tvi);
|
||||||
|
|
||||||
if (nextEnt == bmr_i) {
|
if (nextEnt == bmr_i) {
|
||||||
selItem = itm;
|
selItem = itm;
|
||||||
@ -473,7 +483,8 @@ void BookmarkView::doUpdateActiveList() {
|
|||||||
void BookmarkView::onTreeBeginLabelEdit( wxTreeEvent& event ) {
|
void BookmarkView::onTreeBeginLabelEdit( wxTreeEvent& event ) {
|
||||||
TreeViewItem* tvi = dynamic_cast<TreeViewItem*>(m_treeView->GetItemData(event.GetItem()));
|
TreeViewItem* tvi = dynamic_cast<TreeViewItem*>(m_treeView->GetItemData(event.GetItem()));
|
||||||
|
|
||||||
if (!tvi) {
|
//if edition do not work, m_treeView->GetEditControl() may be null...
|
||||||
|
if (!tvi || (m_treeView->GetEditControl() == NULL)) {
|
||||||
event.Veto();
|
event.Veto();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -496,6 +507,12 @@ void BookmarkView::onTreeEndLabelEdit( wxTreeEvent& event ) {
|
|||||||
wxTreeItemId itm = event.GetItem();
|
wxTreeItemId itm = event.GetItem();
|
||||||
TreeViewItem* tvi = dynamic_cast<TreeViewItem*>(m_treeView->GetItemData(itm));
|
TreeViewItem* tvi = dynamic_cast<TreeViewItem*>(m_treeView->GetItemData(itm));
|
||||||
|
|
||||||
|
//if edition do not work, m_treeView->GetEditControl() may be null...
|
||||||
|
if (m_treeView->GetEditControl() == NULL) {
|
||||||
|
event.Veto();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
std::wstring newText = m_treeView->GetEditControl()->GetValue().ToStdWstring();
|
std::wstring newText = m_treeView->GetEditControl()->GetValue().ToStdWstring();
|
||||||
|
|
||||||
editingLabel = false;
|
editingLabel = false;
|
||||||
@ -1155,7 +1172,7 @@ void BookmarkView::onRemoveActive( wxCommandEvent& /* event */ ) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
doRemoveActive(curSel->demod);
|
doRemoveActive(curSel->demod);
|
||||||
m_treeView->Delete(m_treeView->GetSelection());
|
DeleteSingleItem(m_treeView->GetSelection());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1186,9 +1203,10 @@ void BookmarkView::onActivateRecent( wxCommandEvent& /* event */ ) {
|
|||||||
TreeViewItem *curSel = itemToTVI(m_treeView->GetSelection());
|
TreeViewItem *curSel = itemToTVI(m_treeView->GetSelection());
|
||||||
|
|
||||||
if (curSel && curSel->type == TreeViewItem::TREEVIEW_ITEM_TYPE_RECENT) {
|
if (curSel && curSel->type == TreeViewItem::TREEVIEW_ITEM_TYPE_RECENT) {
|
||||||
|
|
||||||
wxGetApp().getBookmarkMgr().removeRecent(curSel->bookmarkEnt);
|
wxGetApp().getBookmarkMgr().removeRecent(curSel->bookmarkEnt);
|
||||||
activateBookmark(curSel->bookmarkEnt);
|
activateBookmark(curSel->bookmarkEnt);
|
||||||
m_treeView->Delete(m_treeView->GetSelection());
|
DeleteSingleItem(m_treeView->GetSelection());
|
||||||
wxGetApp().getBookmarkMgr().updateActiveList();
|
wxGetApp().getBookmarkMgr().updateActiveList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1203,7 +1221,7 @@ void BookmarkView::onRemoveRecent ( wxCommandEvent& /* event */ ) {
|
|||||||
|
|
||||||
if (curSel && curSel->type == TreeViewItem::TREEVIEW_ITEM_TYPE_RECENT) {
|
if (curSel && curSel->type == TreeViewItem::TREEVIEW_ITEM_TYPE_RECENT) {
|
||||||
wxGetApp().getBookmarkMgr().removeRecent(curSel->bookmarkEnt);
|
wxGetApp().getBookmarkMgr().removeRecent(curSel->bookmarkEnt);
|
||||||
m_treeView->Delete(m_treeView->GetSelection());
|
DeleteSingleItem(m_treeView->GetSelection());
|
||||||
wxGetApp().getBookmarkMgr().updateActiveList();
|
wxGetApp().getBookmarkMgr().updateActiveList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1401,7 +1419,8 @@ void BookmarkView::onTreeEndDrag( wxTreeEvent& event ) {
|
|||||||
doBookmarkActive(tvi->groupName, dragItem->demod);
|
doBookmarkActive(tvi->groupName, dragItem->demod);
|
||||||
} else if (dragItem && dragItem->type == TreeViewItem::TREEVIEW_ITEM_TYPE_RECENT) { // Recent -> Group Item
|
} else if (dragItem && dragItem->type == TreeViewItem::TREEVIEW_ITEM_TYPE_RECENT) { // Recent -> Group Item
|
||||||
doBookmarkRecent(tvi->groupName, dragItem->bookmarkEnt);
|
doBookmarkRecent(tvi->groupName, dragItem->bookmarkEnt);
|
||||||
m_treeView->Delete(dragItemId);
|
|
||||||
|
DeleteSingleItem(dragItemId);
|
||||||
} else if (dragItem && dragItem->type == TreeViewItem::TREEVIEW_ITEM_TYPE_BOOKMARK) { // Bookmark -> Group Item
|
} else if (dragItem && dragItem->type == TreeViewItem::TREEVIEW_ITEM_TYPE_BOOKMARK) { // Bookmark -> Group Item
|
||||||
doMoveBookmark(dragItem->bookmarkEnt, tvi->groupName);
|
doMoveBookmark(dragItem->bookmarkEnt, tvi->groupName);
|
||||||
}
|
}
|
||||||
@ -1410,7 +1429,7 @@ void BookmarkView::onTreeEndDrag( wxTreeEvent& event ) {
|
|||||||
doBookmarkActive(tvi->groupName, dragItem->demod);
|
doBookmarkActive(tvi->groupName, dragItem->demod);
|
||||||
} else if (dragItem && dragItem->type == TreeViewItem::TREEVIEW_ITEM_TYPE_RECENT) { // Recent -> Same Group
|
} else if (dragItem && dragItem->type == TreeViewItem::TREEVIEW_ITEM_TYPE_RECENT) { // Recent -> Same Group
|
||||||
doBookmarkRecent(tvi->groupName, dragItem->bookmarkEnt);
|
doBookmarkRecent(tvi->groupName, dragItem->bookmarkEnt);
|
||||||
m_treeView->Delete(dragItemId);
|
DeleteSingleItem(dragItemId);
|
||||||
} else if (dragItem && dragItem->type == TreeViewItem::TREEVIEW_ITEM_TYPE_BOOKMARK) { // Bookmark -> Same Group
|
} else if (dragItem && dragItem->type == TreeViewItem::TREEVIEW_ITEM_TYPE_BOOKMARK) { // Bookmark -> Same Group
|
||||||
doMoveBookmark(dragItem->bookmarkEnt, tvi->groupName);
|
doMoveBookmark(dragItem->bookmarkEnt, tvi->groupName);
|
||||||
}
|
}
|
||||||
@ -1571,3 +1590,52 @@ BookmarkRangeEntryPtr BookmarkView::makeActiveRangeEntry() {
|
|||||||
|
|
||||||
return re;
|
return re;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void BookmarkView::DeleteSingleItem(wxTreeItemId item) {
|
||||||
|
|
||||||
|
//free the associated TreeItemData*, because contrary to doc, the associated data is not freed automatically by m_treeView->Delete(item) !
|
||||||
|
// this is needed to dec the ref count of shared_ptr within TreeViewItem.
|
||||||
|
// (see source of vxWidgets 3.1)
|
||||||
|
TreeViewItem *itemData = itemToTVI(item);
|
||||||
|
if (itemData != NULL) {
|
||||||
|
|
||||||
|
delete itemData;
|
||||||
|
m_treeView->SetItemData(item, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
m_treeView->Delete(item);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void BookmarkView::DeleteChildrenOfItem(wxTreeItemId item) {
|
||||||
|
|
||||||
|
wxTreeItemIdValue cookieSearch;
|
||||||
|
wxTreeItemId currentChild = m_treeView->GetFirstChild(item, cookieSearch);
|
||||||
|
|
||||||
|
while (currentChild.IsOk()) {
|
||||||
|
|
||||||
|
TreeViewItem *itemData = itemToTVI(currentChild);
|
||||||
|
if (itemData != NULL) {
|
||||||
|
|
||||||
|
delete itemData;
|
||||||
|
m_treeView->SetItemData(currentChild, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
currentChild = m_treeView->GetNextChild(item, cookieSearch);
|
||||||
|
}
|
||||||
|
|
||||||
|
m_treeView->DeleteChildren(item);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void BookmarkView::SetTreeItemData(const wxTreeItemId& item, wxTreeItemData *data) {
|
||||||
|
|
||||||
|
TreeViewItem *itemData = itemToTVI(item);
|
||||||
|
if (itemData != NULL) {
|
||||||
|
|
||||||
|
delete itemData;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_treeView->SetItemData(item, data);
|
||||||
|
}
|
||||||
|
@ -21,14 +21,22 @@ public:
|
|||||||
};
|
};
|
||||||
|
|
||||||
TreeViewItem() {
|
TreeViewItem() {
|
||||||
bookmarkEnt = nullptr;
|
|
||||||
demod = nullptr;
|
demod = nullptr;
|
||||||
|
bookmarkEnt = nullptr;
|
||||||
|
rangeEnt = nullptr;
|
||||||
|
};
|
||||||
|
|
||||||
|
virtual ~TreeViewItem() {
|
||||||
|
//dec ref count manually ???
|
||||||
|
bookmarkEnt = nullptr;
|
||||||
rangeEnt = nullptr;
|
rangeEnt = nullptr;
|
||||||
};
|
};
|
||||||
|
|
||||||
TreeViewItemType type;
|
TreeViewItemType type;
|
||||||
|
|
||||||
BookmarkEntryPtr bookmarkEnt;
|
BookmarkEntryPtr bookmarkEnt;
|
||||||
BookmarkRangeEntryPtr rangeEnt;
|
BookmarkRangeEntryPtr rangeEnt;
|
||||||
|
|
||||||
DemodulatorInstance* demod;
|
DemodulatorInstance* demod;
|
||||||
std::string groupName;
|
std::string groupName;
|
||||||
};
|
};
|
||||||
@ -45,6 +53,8 @@ class BookmarkView : public BookmarkPanel {
|
|||||||
public:
|
public:
|
||||||
BookmarkView( wxWindow* parent, wxWindowID id = wxID_ANY, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxSize( -1, -1 ), long style = wxTAB_TRAVERSAL );
|
BookmarkView( wxWindow* parent, wxWindowID id = wxID_ANY, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxSize( -1, -1 ), long style = wxTAB_TRAVERSAL );
|
||||||
|
|
||||||
|
virtual ~BookmarkView();
|
||||||
|
|
||||||
void updateActiveList();
|
void updateActiveList();
|
||||||
void updateBookmarks();
|
void updateBookmarks();
|
||||||
bool isKeywordMatch(std::wstring str, std::vector<std::wstring> &keywords);
|
bool isKeywordMatch(std::wstring str, std::vector<std::wstring> &keywords);
|
||||||
@ -141,6 +151,10 @@ protected:
|
|||||||
|
|
||||||
TreeViewItem *itemToTVI(wxTreeItemId item);
|
TreeViewItem *itemToTVI(wxTreeItemId item);
|
||||||
|
|
||||||
|
void SetTreeItemData(const wxTreeItemId& item, wxTreeItemData *data);
|
||||||
|
void DeleteSingleItem(wxTreeItemId item);
|
||||||
|
void DeleteChildrenOfItem(wxTreeItemId item);
|
||||||
|
|
||||||
MouseTracker mouseTracker;
|
MouseTracker mouseTracker;
|
||||||
|
|
||||||
wxTreeItemId rootBranch, activeBranch, bookmarkBranch, recentBranch, rangeBranch;
|
wxTreeItemId rootBranch, activeBranch, bookmarkBranch, recentBranch, rangeBranch;
|
||||||
|
Loading…
Reference in New Issue
Block a user