mirror of
https://github.com/TTimo/GtkRadiant.git
synced 2025-01-25 02:41:22 +00:00
Fixing filters.
I didn't realize they were so broken. The fix is safe and should not break plugins or anything else. git-svn-id: svn://svn.icculus.org/gtkradiant/GtkRadiant/trunk@437 8a3a26a2-13c4-0310-b231-cf6edde360e5
This commit is contained in:
parent
9aa5e96c63
commit
3d4ac1ba23
4 changed files with 96 additions and 35 deletions
|
@ -30,14 +30,38 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
|
|
||||||
// type 1 = texture filter (name)
|
/*
|
||||||
// type 3 = entity filter (name)
|
Rambetter on Sun Jan 23, 2011:
|
||||||
// type 2 = QER_* shader flags
|
|
||||||
// type 4 = entity classes
|
What follows is a discussion of the introduction to some new members and functions
|
||||||
// type 5 = surface flags (q2)
|
such as baseFilters, baseFilterExcludes, FilterAddImpl(), and so on.
|
||||||
// type 6 = content flags (q2)
|
|
||||||
// type 7 = content flags - no match (q2)
|
There was a problem that "base" filters were not taking effect as a result of
|
||||||
bfilter_t *FilterAdd(bfilter_t *pFilter, int type, int bmask, const char *str, int exclude)
|
user action such as clicking a filter checkbox. The reason why the base filters
|
||||||
|
were not being updated is because the previous logic of updating the filters had
|
||||||
|
been commented out. It was commented out because the previous logic deleted ALL
|
||||||
|
filters (including plugin filters) and re-created only the base filters. So in
|
||||||
|
effect, all plugin filters would be deleted whenever a filter checkbox was altered.
|
||||||
|
|
||||||
|
So, we need some way of knowing which are the base filters so that we can take
|
||||||
|
action when a filter checkbox is marked [or unmarked]. Then we can update
|
||||||
|
the base filters by either deleting and recreating them, or by changing their
|
||||||
|
active state in an intelligent manner. I am choosing to do the latter.
|
||||||
|
|
||||||
|
My goal here is to preserve the structure bfilter_t completely as it has been
|
||||||
|
historically. I feel that modifying bfilter_t is dangerous with respect to breaking
|
||||||
|
plugins. So what I'm doing instead is tracking which are the base filters via
|
||||||
|
external array, baseFilters. The array baseFilterExcludes keeps track of the "exclude"
|
||||||
|
parameter for the corresponding filter.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define MAX_BASE_FILTERS 32
|
||||||
|
static bfilter_t *baseFilters[MAX_BASE_FILTERS];
|
||||||
|
static int baseFilterExcludes[MAX_BASE_FILTERS];
|
||||||
|
static int numBaseFilters = 0;
|
||||||
|
|
||||||
|
// This shall not be called from outside filters.cpp.
|
||||||
|
bfilter_t *FilterAddImpl(bfilter_t *pFilter, int type, int bmask, const char *str, int exclude, bool baseFilter)
|
||||||
{
|
{
|
||||||
bfilter_t *pNew = new bfilter_t;
|
bfilter_t *pNew = new bfilter_t;
|
||||||
pNew->next = pFilter;
|
pNew->next = pFilter;
|
||||||
|
@ -48,9 +72,29 @@ bfilter_t *FilterAdd(bfilter_t *pFilter, int type, int bmask, const char *str, i
|
||||||
pNew->active = true;
|
pNew->active = true;
|
||||||
else
|
else
|
||||||
pNew->active = false;
|
pNew->active = false;
|
||||||
|
if (baseFilter)
|
||||||
|
{
|
||||||
|
if (numBaseFilters >= MAX_BASE_FILTERS)
|
||||||
|
Error("Base filters count exceeds MAX_BASE_FILTERS");
|
||||||
|
baseFilters[numBaseFilters] = pNew;
|
||||||
|
baseFilterExcludes[numBaseFilters] = exclude;
|
||||||
|
numBaseFilters++;
|
||||||
|
}
|
||||||
return pNew;
|
return pNew;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// type 1 = texture filter (name)
|
||||||
|
// type 3 = entity filter (name)
|
||||||
|
// type 2 = QER_* shader flags
|
||||||
|
// type 4 = entity classes
|
||||||
|
// type 5 = surface flags (q2)
|
||||||
|
// type 6 = content flags (q2)
|
||||||
|
// type 7 = content flags - no match (q2)
|
||||||
|
bfilter_t *FilterAdd(bfilter_t *pFilter, int type, int bmask, const char *str, int exclude)
|
||||||
|
{
|
||||||
|
return FilterAddImpl(pFilter, type, bmask, str, exclude, false);
|
||||||
|
}
|
||||||
|
|
||||||
bfilter_t *FilterCreate (int type, int bmask, const char *str, int exclude)
|
bfilter_t *FilterCreate (int type, int bmask, const char *str, int exclude)
|
||||||
{
|
{
|
||||||
g_qeglobals.d_savedinfo.filters = FilterAdd(g_qeglobals.d_savedinfo.filters, type, bmask, str, exclude);
|
g_qeglobals.d_savedinfo.filters = FilterAdd(g_qeglobals.d_savedinfo.filters, type, bmask, str, exclude);
|
||||||
|
@ -67,6 +111,8 @@ void FiltersActivate (void)
|
||||||
}
|
}
|
||||||
|
|
||||||
// removes the filter list at *pFilter, returns NULL pointer
|
// removes the filter list at *pFilter, returns NULL pointer
|
||||||
|
// IMPORTANT NOTE: Some plugins add filters, and those will be removed here as well.
|
||||||
|
// Therefore, this function should rarely be used.
|
||||||
bfilter_t *FilterListDelete(bfilter_t *pFilter)
|
bfilter_t *FilterListDelete(bfilter_t *pFilter)
|
||||||
{
|
{
|
||||||
if (pFilter != NULL)
|
if (pFilter != NULL)
|
||||||
|
@ -74,31 +120,52 @@ bfilter_t *FilterListDelete(bfilter_t *pFilter)
|
||||||
FilterListDelete(pFilter->next);
|
FilterListDelete(pFilter->next);
|
||||||
delete pFilter;
|
delete pFilter;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
memset(baseFilters, 0, sizeof(baseFilters)); // Strictly speaking we don't really need this.
|
||||||
|
memset(baseFilterExcludes, 0, sizeof(baseFilterExcludes)); // Strictly speaking we don't really need this.
|
||||||
|
numBaseFilters = 0; // We do need this.
|
||||||
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//spog - FilterUpdate is called each time the filters are changed by menu or shortcuts
|
bfilter_t *FilterAddBase(bfilter_t *pFilter)
|
||||||
bfilter_t *FilterUpdate(bfilter_t *pFilter)
|
|
||||||
{
|
{
|
||||||
pFilter = FilterAdd(pFilter,1,0,"clip",EXCLUDE_CLIP);
|
pFilter = FilterAddImpl(pFilter,1,0,"clip",EXCLUDE_CLIP,true);
|
||||||
pFilter = FilterAdd(pFilter,1,0,"caulk",EXCLUDE_CAULK);
|
pFilter = FilterAddImpl(pFilter,1,0,"caulk",EXCLUDE_CAULK,true);
|
||||||
pFilter = FilterAdd(pFilter,1,0,"liquids",EXCLUDE_LIQUIDS);
|
pFilter = FilterAddImpl(pFilter,1,0,"liquids",EXCLUDE_LIQUIDS,true);
|
||||||
pFilter = FilterAdd(pFilter,1,0,"hint",EXCLUDE_HINTSSKIPS);
|
pFilter = FilterAddImpl(pFilter,1,0,"hint",EXCLUDE_HINTSSKIPS,true);
|
||||||
pFilter = FilterAdd(pFilter,1,0,"clusterportal",EXCLUDE_CLUSTERPORTALS);
|
pFilter = FilterAddImpl(pFilter,1,0,"clusterportal",EXCLUDE_CLUSTERPORTALS,true);
|
||||||
pFilter = FilterAdd(pFilter,1,0,"areaportal",EXCLUDE_AREAPORTALS);
|
pFilter = FilterAddImpl(pFilter,1,0,"areaportal",EXCLUDE_AREAPORTALS,true);
|
||||||
pFilter = FilterAdd(pFilter,2,QER_TRANS,NULL,EXCLUDE_TRANSLUCENT);
|
pFilter = FilterAddImpl(pFilter,2,QER_TRANS,NULL,EXCLUDE_TRANSLUCENT,true);
|
||||||
pFilter = FilterAdd(pFilter,3,0,"trigger",EXCLUDE_TRIGGERS);
|
pFilter = FilterAddImpl(pFilter,3,0,"trigger",EXCLUDE_TRIGGERS,true);
|
||||||
pFilter = FilterAdd(pFilter,3,0,"misc_model",EXCLUDE_MODELS);
|
pFilter = FilterAddImpl(pFilter,3,0,"misc_model",EXCLUDE_MODELS,true);
|
||||||
pFilter = FilterAdd(pFilter,3,0,"misc_gamemodel",EXCLUDE_MODELS);
|
pFilter = FilterAddImpl(pFilter,3,0,"misc_gamemodel",EXCLUDE_MODELS,true);
|
||||||
pFilter = FilterAdd(pFilter,4,ECLASS_LIGHT,NULL,EXCLUDE_LIGHTS);
|
pFilter = FilterAddImpl(pFilter,4,ECLASS_LIGHT,NULL,EXCLUDE_LIGHTS,true);
|
||||||
pFilter = FilterAdd(pFilter,4,ECLASS_PATH,NULL,EXCLUDE_PATHS);
|
pFilter = FilterAddImpl(pFilter,4,ECLASS_PATH,NULL,EXCLUDE_PATHS,true);
|
||||||
pFilter = FilterAdd(pFilter,1,0,"lightgrid",EXCLUDE_LIGHTGRID);
|
pFilter = FilterAddImpl(pFilter,1,0,"lightgrid",EXCLUDE_LIGHTGRID,true);
|
||||||
pFilter = FilterAdd(pFilter,1,0,"botclip",EXCLUDE_BOTCLIP);
|
pFilter = FilterAddImpl(pFilter,1,0,"botclip",EXCLUDE_BOTCLIP,true);
|
||||||
pFilter = FilterAdd(pFilter,1,0,"clipmonster",EXCLUDE_BOTCLIP);
|
pFilter = FilterAddImpl(pFilter,1,0,"clipmonster",EXCLUDE_BOTCLIP,true);
|
||||||
return pFilter;
|
return pFilter;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void FilterUpdateBase()
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
bfilter_t *filter;
|
||||||
|
int exclude;
|
||||||
|
for (i = 0; i < numBaseFilters; i++)
|
||||||
|
{
|
||||||
|
filter = baseFilters[i];
|
||||||
|
exclude = baseFilterExcludes[i];
|
||||||
|
if (g_qeglobals.d_savedinfo.exclude & exclude)
|
||||||
|
filter->active = true;
|
||||||
|
else
|
||||||
|
filter->active = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
==================
|
==================
|
||||||
FilterBrush
|
FilterBrush
|
||||||
|
|
|
@ -26,7 +26,8 @@ void FiltersActivate(void);
|
||||||
bfilter_t *FilterCreate(int type, int bmask, const char *str, int exclude);
|
bfilter_t *FilterCreate(int type, int bmask, const char *str, int exclude);
|
||||||
bfilter_t *FilterAdd(bfilter_t *pFilter, int type, int bmask, const char *str, int exclude);
|
bfilter_t *FilterAdd(bfilter_t *pFilter, int type, int bmask, const char *str, int exclude);
|
||||||
bfilter_t *FilterListDelete(bfilter_t *pFilter);
|
bfilter_t *FilterListDelete(bfilter_t *pFilter);
|
||||||
bfilter_t *FilterUpdate(bfilter_t *pFilter);
|
bfilter_t *FilterAddBase(bfilter_t *pFilter);
|
||||||
|
void FilterUpdateBase();
|
||||||
bool FilterBrush(brush_t *pb);
|
bool FilterBrush(brush_t *pb);
|
||||||
|
|
||||||
#endif // _FILTERS_H_
|
#endif // _FILTERS_H_
|
||||||
|
|
|
@ -932,7 +932,7 @@ int main( int argc, char* argv[] ) {
|
||||||
|
|
||||||
// spog - creates new filters list for the first time
|
// spog - creates new filters list for the first time
|
||||||
g_qeglobals.d_savedinfo.filters = NULL;
|
g_qeglobals.d_savedinfo.filters = NULL;
|
||||||
g_qeglobals.d_savedinfo.filters = FilterUpdate(g_qeglobals.d_savedinfo.filters);
|
g_qeglobals.d_savedinfo.filters = FilterAddBase(g_qeglobals.d_savedinfo.filters);
|
||||||
|
|
||||||
g_pParentWnd = new MainFrame();
|
g_pParentWnd = new MainFrame();
|
||||||
|
|
||||||
|
|
|
@ -7505,14 +7505,7 @@ void PerformFiltering ()
|
||||||
{
|
{
|
||||||
brush_t *brush;
|
brush_t *brush;
|
||||||
|
|
||||||
// mattn - this should be removed - otherwise the filters from the
|
FilterUpdateBase();
|
||||||
// plugins are wiped away with each update
|
|
||||||
#if 0
|
|
||||||
// spog - deletes old filters list and creates new one when
|
|
||||||
// g_qeglobals.d_savedinfo.exclude is updated
|
|
||||||
g_qeglobals.d_savedinfo.filters = FilterListDelete(g_qeglobals.d_savedinfo.filters);
|
|
||||||
g_qeglobals.d_savedinfo.filters = FilterUpdate(g_qeglobals.d_savedinfo.filters);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
for ( brush = active_brushes.next; brush != &active_brushes; brush = brush->next )
|
for ( brush = active_brushes.next; brush != &active_brushes; brush = brush->next )
|
||||||
brush->bFiltered = FilterBrush( brush );
|
brush->bFiltered = FilterBrush( brush );
|
||||||
|
|
Loading…
Reference in a new issue