summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--dive.h1
-rw-r--r--divelist-gtk.c3
-rw-r--r--gtk-gui.c7
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)