- //gdk_gc_unref(draw_context_out->gc);
-
- draw_context_out->current->middle->y = y_out+height/2;
- draw_context_out->current->over->y = y_out;
- draw_context_out->current->under->y = y_out+height;
- draw_context_out->current->status = process_out->state->s;
-
- /* for pid_out : remove previous, Prev = current, new current (default) */
- g_free(draw_context_out->previous->modify_under);
- g_free(draw_context_out->previous->modify_middle);
- g_free(draw_context_out->previous->modify_over);
- g_free(draw_context_out->previous->under);
- g_free(draw_context_out->previous->middle);
- g_free(draw_context_out->previous->over);
- g_free(draw_context_out->previous);
-
- draw_context_out->previous = draw_context_out->current;
-
- draw_context_out->current = g_new(DrawInfo,1);
- draw_context_out->current->over = g_new(ItemInfo,1);
- draw_context_out->current->over->x = -1;
- draw_context_out->current->over->y = -1;
- draw_context_out->current->middle = g_new(ItemInfo,1);
- draw_context_out->current->middle->x = -1;
- draw_context_out->current->middle->y = -1;
- draw_context_out->current->under = g_new(ItemInfo,1);
- draw_context_out->current->under->x = -1;
- draw_context_out->current->under->y = -1;
- draw_context_out->current->modify_over = g_new(ItemInfo,1);
- draw_context_out->current->modify_over->x = -1;
- draw_context_out->current->modify_over->y = -1;
- draw_context_out->current->modify_middle = g_new(ItemInfo,1);
- draw_context_out->current->modify_middle->x = -1;
- draw_context_out->current->modify_middle->y = -1;
- draw_context_out->current->modify_under = g_new(ItemInfo,1);
- draw_context_out->current->modify_under->x = -1;
- draw_context_out->current->modify_under->y = -1;
- draw_context_out->current->status = LTTV_STATE_UNNAMED;
-
- /* Finally, update the drawing context of the pid_in. */
-
- DrawContext *draw_context_in = hashed_process_data_in->draw_context;
- //draw_context_in->current->modify_over->x = x;
- draw_context_in->current->modify_over->y = y_in;
- draw_context_in->current->modify_under->y = y_in+(height/2)+2;
- draw_context_in->drawable = control_flow_data->drawing->pixmap;
- draw_context_in->pango_layout = control_flow_data->drawing->pango_layout;
- widget = control_flow_data->drawing->drawing_area;
- //draw_context_in->gc = widget->style->fg_gc[GTK_WIDGET_STATE (widget)];
-
- //draw_arc((void*)&prop_arc, (void*)draw_context_in);
- //test_draw_item(control_flow_data->drawing, control_flow_data->drawing->pixmap);
-
- /*if(process_in->state->s == LTTV_STATE_RUN)
- {
- draw_context_in->gc = gdk_gc_new(control_flow_data->drawing->pixmap);
- gdk_gc_copy(draw_context_in->gc, widget->style->black_gc);
- PropertiesBG prop_bg;
- prop_bg.color = g_new(GdkColor,1);
-
- prop_bg.color->red = 0xffff;
- prop_bg.color->green = 0xffff;
- prop_bg.color->blue = 0xffff;
-
- draw_bg((void*)&prop_bg, (void*)draw_context_in);
- g_free(prop_bg.color);
- gdk_gc_unref(draw_context_in->gc);
- }*/
-
- draw_context_in->gc = widget->style->black_gc;
-
- GdkColor colorfg_in = { 0, 0x0000, 0xffff, 0x0000 };
- GdkColor colorbg_in = { 0, 0x0000, 0x0000, 0x0000 };
- PropertiesText prop_text_in;
- prop_text_in.foreground = &colorfg_in;
- prop_text_in.background = &colorbg_in;
- prop_text_in.size = 6;
- prop_text_in.position = OVER;
-
- /* foreground of text : status of the process */
- if(process_in->state->s == LTTV_STATE_UNNAMED)
- {
- prop_text_in.foreground->red = 0xffff;
- prop_text_in.foreground->green = 0xffff;
- prop_text_in.foreground->blue = 0xffff;
- }
- else if(process_in->state->s == LTTV_STATE_WAIT_FORK)
- {
- prop_text_in.foreground->red = 0x0fff;
- prop_text_in.foreground->green = 0xffff;
- prop_text_in.foreground->blue = 0xfff0;
- }
- else if(process_in->state->s == LTTV_STATE_WAIT_CPU)
- {
- prop_text_in.foreground->red = 0xffff;
- prop_text_in.foreground->green = 0xffff;
- prop_text_in.foreground->blue = 0x0000;
- }
- else if(process_in->state->s == LTTV_STATE_ZOMBIE)
- {
- prop_text_in.foreground->red = 0xffff;
- prop_text_in.foreground->green = 0x0000;
- prop_text_in.foreground->blue = 0xffff;
- }
- else if(process_in->state->s == LTTV_STATE_WAIT)
- {
- prop_text_in.foreground->red = 0xffff;
- prop_text_in.foreground->green = 0x0000;
- prop_text_in.foreground->blue = 0x0000;
- }
- else if(process_in->state->s == LTTV_STATE_RUN)
- {
- prop_text_in.foreground->red = 0x0000;
- prop_text_in.foreground->green = 0xffff;
- prop_text_in.foreground->blue = 0x0000;
- }
- else
- {
- prop_text_in.foreground->red = 0xffff;
- prop_text_in.foreground->green = 0xffff;
- prop_text_in.foreground->blue = 0xffff;
- }
-
+ /* Jump over draw if we are at the same x position */
+ if(unlikely(x == hashed_process_data->x.middle &&
+ hashed_process_data->x.middle_used))
+ {
+ if(unlikely(hashed_process_data->x.middle_marked == FALSE)) {
+ /* Draw collision indicator */
+ gdk_gc_set_foreground(drawing->gc, &drawing_colors[COL_WHITE]);
+ gdk_draw_point(hashed_process_data->pixmap,
+ drawing->gc,
+ x,
+ (hashed_process_data->height/2)-3);
+ hashed_process_data->x.middle_marked = TRUE;
+ }
+ /* jump */
+ } else {
+ DrawContext draw_context;
+
+ /* Now create the drawing context that will be used to draw
+ * items related to the last state. */
+ draw_context.drawable = hashed_process_data->pixmap;
+ draw_context.gc = drawing->gc;
+ draw_context.pango_layout = drawing->pango_layout;
+ draw_context.drawinfo.start.x = hashed_process_data->x.middle;
+ draw_context.drawinfo.end.x = x;
+
+ draw_context.drawinfo.y.over = 1;
+ draw_context.drawinfo.y.middle = (hashed_process_data->height/2);
+ draw_context.drawinfo.y.under = hashed_process_data->height;
+
+ draw_context.drawinfo.start.offset.over = 0;
+ draw_context.drawinfo.start.offset.middle = 0;
+ draw_context.drawinfo.start.offset.under = 0;
+ draw_context.drawinfo.end.offset.over = 0;
+ draw_context.drawinfo.end.offset.middle = 0;
+ draw_context.drawinfo.end.offset.under = 0;