bool NotifyDoubleClick(ListBox listBox, int x, int y, Modifiers mods)
{
+ bool result = !(selection && selection.type.isFolder && bits.navigateFolders);
OpenNode();
- return false;
+ return result;
}
bool NotifyKeyDown(ListBox listBox, DataRow row, Key key, unichar ch)
{
bool result;
if(selection && selection.type.isFolder && bits.navigateFolders)
- {
property::path = selection.path;
- result = true;
- }
- else
- result = NotifyNodeOpen(this.master, this, selection);
+ result = NotifyNodeOpen(this.master, this, selection);
return result;
}
(bits.filesOnly && listing.stats.attribs.isFile))
{
FileSystemNode node = MakeFileSystemNode(listing.stats, listing.name, listing.path, bits.previewPictures, displaySystem);
- DataRow row = list.AddRow();
- row.tag = (int)node;
- row.SetData(nameField, node);
- if(bits.details)
- {
- row.SetData(typeField, node.extension);
- row.SetData(sizeField, (void *)node.stats.size);
- }
+ AddNode(node);
}
}
list.Sort(nameField, 1);
parent.childrenLoaded = true;
}
+ void AddNode(FileSystemNode node)
+ {
+ DataRow row = list.AddRow();
+ row.tag = (int)node;
+ row.SetData(nameField, node);
+ if(bits.details)
+ {
+ row.SetData(typeField, node.extension);
+ row.SetData(sizeField, (void *)node.stats.size);
+ }
+ }
+
void AddTreeNode(FileSystemNode node, bool loaded, bool addLoader, FileSystemNode addTo)
{
DataRow row = (addTo && addTo.row) ? addTo.row.AddRow() : list.AddRow();
row.tag = (int)node;
node.row = row;
row.SetData(null, node);
+ if(bits.details)
+ {
+ row.SetData(typeField, node.extension);
+ row.SetData(sizeField, (void *)node.stats.size);
+ }
node.loaded = loaded;
if(addLoader)