On Sun, Jul 12, 2009 at 11:08:59AM +0200, Anders Broman wrote:
> I haven't figured out where packet_list_get_value():s column
> value comes from yet. 

It's set by gtk_tree_view_column_add_attribute(..., "text", X) call

Doc: 
http://library.gnome.org/devel/gtk/stable/GtkTreeViewColumn.html#gtk-tree-view-column-add-attribute
"So for example if column 2 of the model contains strings, you could
have the "text" attribute of a GtkCellRendererText get its values from
column 2."

In attachment patch.
diff --git gtk/new_packet_list.c gtk/new_packet_list.c
index 73f7209..e43d789 100644
--- gtk/new_packet_list.c
+++ gtk/new_packet_list.c
@@ -132,8 +132,7 @@ create_view_and_model(void)
        for(i = 0; i < cfile.cinfo.num_cols; i++) {
                col = gtk_tree_view_column_new();
                gtk_tree_view_column_pack_start(col, renderer, TRUE);
-               gtk_tree_view_column_add_attribute(col, renderer, "text",
-                                                  cfile.cinfo.col_fmt[i]);
+               gtk_tree_view_column_add_attribute(col, renderer, "text", i);
                gtk_tree_view_column_set_title(col, cfile.cinfo.col_title[i]);
                gtk_tree_view_column_set_sort_column_id(col, i);
                gtk_tree_view_column_set_resizable(col, TRUE);
diff --git gtk/packet_list_store.c gtk/packet_list_store.c
index 1b1cc14..c772d21 100644
--- gtk/packet_list_store.c
+++ gtk/packet_list_store.c
@@ -205,11 +205,11 @@ packet_list_tree_model_init(GtkTreeModelIface *iface)
 static void
 packet_list_init(PacketList *packet_list)
 {
-       guint i;
+       gint i;
 #if 0
        gint fmt;
 
-       for(i = 0; i < (guint)cfile.cinfo.num_cols; i++) {
+       for(i = 0; i < NUM_COL_FMTS && i < cfile.cinfo.num_cols; i++) {
                /* Get the format of the column, see column_info.h */
                fmt = get_column_format(i);
                switch(fmt){
@@ -224,12 +224,12 @@ packet_list_init(PacketList *packet_list)
        }
 #endif
 
-       for(i = 0; i < NUM_COL_FMTS; i++) { /* XXX - Temporary? */
+       for(i = 0; i < NUM_COL_FMTS && i < cfile.cinfo.num_cols; i++) { /* XXX 
- Temporary? */
                packet_list->column_types[i] = G_TYPE_STRING;
        }
        
 
-       packet_list->n_columns = NUM_COL_FMTS;
+       packet_list->n_columns = i;     /* max(NUM_COL_FMTS, 
cfile.cinfo.num_cols) */
        packet_list->num_rows = 0;
        packet_list->rows = NULL;
 
@@ -517,12 +517,10 @@ packet_list_append_record(PacketList *packet_list, 
row_data_t *row_data)
                                    packet_list->num_rows);
 
        newrecord = se_alloc0(sizeof(PacketListRecord));
-       newrecord->col_text = se_alloc0(sizeof(row_data->col_text)* 
NUM_COL_FMTS);
-
+       newrecord->col_text = se_alloc(sizeof(row_data->col_text) * 
packet_list->n_columns);
 
-       /* XXX newrecord->col_text still uses the fmt index */
-       for(i = 0; i < cfile.cinfo.num_cols; i++)
-               newrecord->col_text[row_data->col_fmt[i]] = 
row_data->col_text[i];
+       for(i = 0; i < packet_list->n_columns; i++)
+               newrecord->col_text[i] = (i < cfile.cinfo.num_cols) ? 
row_data->col_text[i] : NULL;
 
        newrecord->fdata = row_data->fdata;
 
@@ -632,8 +630,8 @@ packet_list_compare_records(gint sort_id, PacketListRecord 
*a,
         * seen by the user, whereas the col_text array from a and b is a
         * column format number. This matches them to each other to get
         * the right column text. */
-       gchar *a_col_text = a->col_text[cfile.cinfo.col_fmt[sort_id]];
-       gchar *b_col_text = b->col_text[cfile.cinfo.col_fmt[sort_id]];
+       gchar *a_col_text = a->col_text[sort_id];
+       gchar *b_col_text = b->col_text[sort_id];
 
        if((a_col_text) && (b_col_text))
                return strcmp(a_col_text, b_col_text);
___________________________________________________________________________
Sent via:    Wireshark-dev mailing list <[email protected]>
Archives:    http://www.wireshark.org/lists/wireshark-dev
Unsubscribe: https://wireshark.org/mailman/options/wireshark-dev
             mailto:[email protected]?subject=unsubscribe

Reply via email to