API Documentation

BRefFilter

BRefFilter

Hook Functions

Filter()

virtual bool BRefFilter::Filter(const entry_ref *ref, BNode *node, struct stat *st, const char *filetype)

Filter() is a hook function that’s invoked whenever the file panel to which it’s been assigned reads the entries in its “panel directory.” The function is invoked once for each entry in the directory. All the arguments to the function refer to the entry currently under consideration. (Note that the function is never sent an abstract entry, so the node, st, and filetype arguments will always be valid.)

Your implementation of Filter() can use any or all of the arguments to figure out if the entry is a valid candidate for display in the file panel’s file list. Simply return true or false to indicate if the entry is a winner or a loser.

Technically, Filter() is invoked when…

  • …the file panel’s panel directory is set, either through the BFilePanel constructor or the SetPanelDirectory(), and when…

  • …the file panel’s Refresh() function is called.

A BRefFilter can be assigned to more than one BFilePanel object (assignation is performed through BFilePanel’s constructor or SetRefFilter() function). But it’s not probably not a great idea to do so: At any particular invocation of Filter(), the BRefFilter doesn’t which BFilePanel object it’s working for.

You maintain ownership of the BRefFilter objects that you create. Assigning a ref filter to a file panel does not hand ownership of the BRefFilter to the BFilePanel. You shouldn’t delete a BRefFilter while a BFilePanel is still using it; but it’s your responsibility to delete it when it’s done.