From d5af4e2ff918d18e329b4753435728feae98b226 Mon Sep 17 00:00:00 2001 From: Dirk Hohndel Date: Sun, 21 Apr 2013 17:53:24 -0700 Subject: Simplistic filtering by tags This only allows for a logical "AND" - so only dives that all of the selected tags are displayed. Signed-off-by: Dirk Hohndel --- dive.h | 1 + divelist-gtk.c | 3 ++- gtk-gui.c | 7 ++++++- 3 files changed, 9 insertions(+), 2 deletions(-) diff --git a/dive.h b/dive.h index 957415396..5aa9fc011 100644 --- a/dive.h +++ b/dive.h @@ -53,6 +53,7 @@ /* defined in statistics.c */ extern char *dtag_names[DTAG_NR]; extern int dtag_shown[DTAG_NR]; +extern int dive_mask; /* * Some silly typedefs to make our units very explicit. diff --git a/divelist-gtk.c b/divelist-gtk.c index 2f6e12de7..f523805c1 100644 --- a/divelist-gtk.c +++ b/divelist-gtk.c @@ -695,7 +695,8 @@ static void fill_dive_list(void) while (--i >= 0) { struct dive *dive = get_dive(i); dive_trip_t *trip; - if ((dive->dive_tags & DTAG_INVALID) && !prefs.display_invalid_dives) + if (((dive->dive_tags & DTAG_INVALID) && !prefs.display_invalid_dives) || + (dive->dive_tags & dive_mask) != dive_mask) continue; trip = dive->divetrip; diff --git a/gtk-gui.c b/gtk-gui.c index 89f1eca1f..d9ac9530b 100644 --- a/gtk-gui.c +++ b/gtk-gui.c @@ -46,7 +46,7 @@ const char *existing_filename; typedef enum { PANE_INFO, PANE_PROFILE, PANE_LIST, PANE_THREE } pane_conf_t; static pane_conf_t pane_conf; -int dtag_shown[DTAG_NR]; +int dive_mask, dtag_shown[DTAG_NR]; static struct device_info *holdnicknames = NULL; static GtkWidget *dive_profile_widget(void); static void import_files(GtkWidget *, gpointer); @@ -1159,6 +1159,11 @@ static void selecttags_dialog(GtkWidget *w, gpointer data) repaint_dive(); } gtk_widget_destroy(dialog); + dive_mask = 0; + for (i = 0; i < DTAG_NR; i++) + if (dtag_shown[i]) + dive_mask |= (1 << i); + dive_list_update_dives(); } static void selectevents_dialog(GtkWidget *w, gpointer data) -- cgit v1.2.3-70-g09d2