summaryrefslogtreecommitdiffstats
path: root/equipment.c
diff options
context:
space:
mode:
authorGravatar Linus Torvalds <torvalds@linux-foundation.org>2011-09-09 17:10:17 -0700
committerGravatar Linus Torvalds <torvalds@linux-foundation.org>2011-09-09 17:10:17 -0700
commit067506038a5fea72e60680513d768f89722671fd (patch)
tree9f926ebb0793cd7d4ee8445577a1d31dea901c33 /equipment.c
parent41bce9e5f4c80803132563681d492e74853aa609 (diff)
downloadsubsurface-067506038a5fea72e60680513d768f89722671fd.tar.gz
Rename 'cylinder.c' as 'equipment.c'
Make it about general equipment management, and start hooking up functions to show new equipment information when changing dives (and to flush changes to equipment information for the previously active dive). Nothing is hooked up yet, and it's now showing just one (really big) cylinder choice, so this is all broken. But it should make it possible to at least get somewhere some day. Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'equipment.c')
-rw-r--r--equipment.c108
1 files changed, 108 insertions, 0 deletions
diff --git a/equipment.c b/equipment.c
new file mode 100644
index 000000000..5b8bf3583
--- /dev/null
+++ b/equipment.c
@@ -0,0 +1,108 @@
+#include <stdio.h>
+#include <string.h>
+#include <stdlib.h>
+#include <stdarg.h>
+#include <time.h>
+
+#include "dive.h"
+#include "display.h"
+#include "divelist.h"
+
+void show_dive_equipment(struct dive *dive)
+{
+}
+
+void flush_dive_equipment_changes(struct dive *dive)
+{
+}
+
+static struct tank_info {
+ const char *name;
+ int size; /* cuft or mliter depending on psi */
+ int psi; /* If zero, size is in mliter */
+} tank_info[] = {
+ { "None", },
+ { "10.0 l", 10000 },
+ { "11.1 l", 11100 },
+ { "AL72", 72, 3000 },
+ { "AL80", 80, 3000 },
+ { "LP85", 85, 2640 },
+ { "LP95", 95, 2640 },
+ { "HP100", 100, 3442 },
+ { "HP119", 119, 3442 },
+ { NULL, }
+};
+
+static void fill_tank_list(GtkListStore *store)
+{
+ GtkTreeIter iter;
+
+ struct tank_info *info = tank_info;
+
+ while (info->name) {
+ int size = info->size;
+ int psi = info->psi;
+ int mbar = 0, ml = size;
+
+ /* Is it in cuft and psi? */
+ if (psi) {
+ double bar = 0.0689475729 * psi;
+ double airvolume = 28316.8466 * size;
+ double atm = bar / 1.01325;
+
+ ml = airvolume / atm + 0.5;
+ mbar = bar*1000 + 0.5;
+ }
+
+ gtk_list_store_append(store, &iter);
+ gtk_list_store_set(store, &iter,
+ 0, info->name,
+ 1, ml,
+ 2, mbar,
+ -1);
+ info++;
+ }
+}
+
+static void cylinder_widget(GtkWidget *box, int nr, GtkListStore *model)
+{
+ GtkWidget *frame, *hbox, *size;
+ char buffer[80];
+
+ snprintf(buffer, sizeof(buffer), "Cylinder %d", nr);
+ frame = gtk_frame_new(buffer);
+ gtk_box_pack_start(GTK_BOX(box), frame, TRUE, TRUE, 0);
+
+ hbox = gtk_hbox_new(TRUE, 3);
+ gtk_container_add(GTK_CONTAINER(frame), hbox);
+
+ size = gtk_combo_box_entry_new_with_model(GTK_TREE_MODEL(model), 0);
+ gtk_box_pack_start(GTK_BOX(hbox), size, FALSE, FALSE, 0);
+}
+
+static GtkListStore *create_tank_size_model(void)
+{
+ GtkListStore *model;
+
+ model = gtk_list_store_new(3,
+ G_TYPE_STRING, /* Tank name */
+ G_TYPE_INT, /* Tank size in mliter */
+ G_TYPE_INT, /* Tank working pressure in mbar */
+ -1);
+
+ fill_tank_list(model);
+ return model;
+}
+
+GtkWidget *equipment_widget(void)
+{
+ GtkWidget *vbox;
+ GtkListStore *model;
+
+ vbox = gtk_vbox_new(TRUE, 3);
+
+ model = create_tank_size_model();
+ cylinder_widget(vbox, 0, model);
+
+ return vbox;
+}