diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2011-09-09 19:46:53 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-09-09 19:46:53 -0700 |
commit | 8f12eed9e0acb474cdab019ce912db3afd3c3584 (patch) | |
tree | d577e192d1652a0148534e42e78402d38194703d | |
parent | 067506038a5fea72e60680513d768f89722671fd (diff) | |
download | subsurface-8f12eed9e0acb474cdab019ce912db3afd3c3584.tar.gz |
First (broken) try at actually tracking cylinder types
This doesn't actually change the cylinder type info in the dive, because
it's too broken for that. Instead it prints out what it would change
things to.
The gtk2 notion of text input focus is *really* odd. Why is the
cylinder type sometimes selected, and sometimes not?
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r-- | display.h | 2 | ||||
-rw-r--r-- | equipment.c | 124 |
2 files changed, 121 insertions, 5 deletions
@@ -5,6 +5,8 @@ #include <gdk/gdk.h> #include <cairo.h> +extern GtkWidget *main_window; + extern GtkWidget *dive_profile_widget(void); extern GtkWidget *dive_info_frame(void); extern GtkWidget *extended_dive_info_widget(void); diff --git a/equipment.c b/equipment.c index 5b8bf3583..f250c46f2 100644 --- a/equipment.c +++ b/equipment.c @@ -8,26 +8,138 @@ #include "display.h" #include "divelist.h" +static GtkWidget *cylinder_description; + +static gboolean match_cylinder(GtkTreeModel *model, + GtkTreePath *path, + GtkTreeIter *iter, + gpointer data) +{ + const char *name; + const char *desc = data; + GValue value = {0, }; + + gtk_tree_model_get_value(model, iter, 0, &value); + name = g_value_get_string(&value); + if (strcmp(desc, name)) + return FALSE; + gtk_combo_box_set_active_iter(GTK_COMBO_BOX(cylinder_description), iter); + return TRUE; +} + void show_dive_equipment(struct dive *dive) { + const char *desc = dive->cylinder[0].type.description; + GtkTreeModel *model = gtk_combo_box_get_model(GTK_COMBO_BOX(cylinder_description)); + + if (!desc) + return; + gtk_tree_model_foreach(model, match_cylinder, (gpointer)desc); +} + +static GtkWidget *create_spinbutton(GtkWidget *vbox, const char *name) +{ + GtkWidget *frame, *button; + + frame = gtk_frame_new(name); + gtk_container_add(GTK_CONTAINER(vbox), frame); + + button = gtk_spin_button_new_with_range( 1.0, 3000, 0.1); + gtk_container_add(GTK_CONTAINER(frame), button); + + return button; +} + +static int get_cylinder_details(const char *name, int *volume, int *pressure) +{ + int result; + GtkWidget *dialog, *frame, *vbox; + + dialog = gtk_dialog_new_with_buttons("New Cylinder Type", + GTK_WINDOW(main_window), + GTK_DIALOG_DESTROY_WITH_PARENT, + GTK_STOCK_OK, GTK_RESPONSE_ACCEPT, + GTK_STOCK_CANCEL, GTK_RESPONSE_REJECT, + NULL); + + frame = gtk_frame_new(name); + gtk_container_add(GTK_CONTAINER(GTK_DIALOG(dialog)->vbox), frame); + vbox = gtk_vbox_new(TRUE, 6); + gtk_container_add(GTK_CONTAINER(frame), vbox); + + create_spinbutton(vbox, "Size:"); + create_spinbutton(vbox, "Working pressure:"); + + gtk_widget_show_all(dialog); + result = gtk_dialog_run(GTK_DIALOG(dialog)); + gtk_widget_destroy(dialog); + + *volume = 0; + *pressure = 0; + return result == GTK_RESPONSE_ACCEPT; +} + +static void fill_cylinder_info(cylinder_t *cyl, const char *desc, int mliter, int mbar) +{ + /* + * The code is currently too broken to actually set anything, + * so just print what we would set + */ + printf("Set cylinder to '%s': %.1f liter at %.1f bar working pressure\n", + desc, mliter / 1000.0, mbar / 1000.); +#if 0 + cyl->type.description = desc; + cyl->type.size.mliter = mliter; + cyl->type.workingpressure.mbar = mbar; +#endif } void flush_dive_equipment_changes(struct dive *dive) { + GtkTreeIter iter; + const gchar *desc; + GtkComboBox *box = GTK_COMBO_BOX(cylinder_description); + GtkTreeModel *model = gtk_combo_box_get_model(box); + GtkListStore *store = GTK_LIST_STORE(model); + GValue value1 = {0, }, value2 = {0,}, value3 = {0, }; + int volume, pressure; + + if (!gtk_combo_box_get_active_iter(box, &iter)) { + desc = gtk_combo_box_get_active_text(box); + if (!get_cylinder_details(desc, &volume, &pressure)) + return; + gtk_list_store_append(store, &iter); + gtk_list_store_set(store, &iter, + 0, desc, + 1, volume, + 2, pressure, + -1); + } + + gtk_tree_model_get_value(model, &iter, 0, &value1); + desc = g_value_get_string(&value1); + gtk_tree_model_get_value(model, &iter, 1, &value2); + volume = g_value_get_int(&value2); + gtk_tree_model_get_value(model, &iter, 2, &value3); + pressure = g_value_get_int(&value3); + fill_cylinder_info(dive->cylinder+0, desc, volume, pressure); } +/* We should take these from the dive list instead */ 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", }, + { "None", 0, 0 }, { "10.0 l", 10000 }, { "11.1 l", 11100 }, { "AL72", 72, 3000 }, { "AL80", 80, 3000 }, - { "LP85", 85, 2640 }, - { "LP95", 95, 2640 }, + { "LP85", 85, 2400 }, + { "LP95", 95, 2400 }, + { "LP85+", 85, 2640 }, + { "LP95+", 95, 2640 }, { "HP100", 100, 3442 }, { "HP119", 119, 3442 }, { NULL, } @@ -71,13 +183,15 @@ static void cylinder_widget(GtkWidget *box, int nr, GtkListStore *model) snprintf(buffer, sizeof(buffer), "Cylinder %d", nr); frame = gtk_frame_new(buffer); - gtk_box_pack_start(GTK_BOX(box), frame, TRUE, TRUE, 0); + gtk_box_pack_start(GTK_BOX(box), frame, FALSE, FALSE, 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); + + cylinder_description = size; } static GtkListStore *create_tank_size_model(void) @@ -99,7 +213,7 @@ GtkWidget *equipment_widget(void) GtkWidget *vbox; GtkListStore *model; - vbox = gtk_vbox_new(TRUE, 3); + vbox = gtk_vbox_new(FALSE, 3); model = create_tank_size_model(); cylinder_widget(vbox, 0, model); |