- Move JumpTo to the main window
- Simplify progress dialog for JumpTo - TODO: this code is buggy. SGPEMv2 won't exit after using JumpTo, unless you kill it explicitly. git-svn-id: svn://svn.gna.org/svn/sgpemv2/trunk@1113 3ecf2c5c-341e-0410-92b4-d18e462d057c
This commit is contained in:
parent
538470f96c
commit
0fe1e13ef9
|
@ -1,344 +1,74 @@
|
||||||
<?xml version="1.0" standalone="no"?> <!--*- mode: xml -*-->
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
<!DOCTYPE glade-interface SYSTEM "http://glade.gnome.org/glade-2.0.dtd">
|
<!DOCTYPE glade-interface SYSTEM "glade-2.0.dtd">
|
||||||
|
<!-- Generated with glade3
|
||||||
|
Version: 3.0.1
|
||||||
|
Date: Tue Sep 12 21:18:38 2006
|
||||||
|
User: matteo
|
||||||
|
Host: tulip
|
||||||
|
-->
|
||||||
<glade-interface>
|
<glade-interface>
|
||||||
|
<widget class="GtkDialog" id="JumpToDialog">
|
||||||
<widget class="GtkDialog" id="JumpToDialog">
|
<property name="title">Jump To...</property>
|
||||||
<property name="title">Jump To...</property>
|
<property name="modal">True</property>
|
||||||
<property name="type">GTK_WINDOW_TOPLEVEL</property>
|
<property name="window_position">GTK_WIN_POS_MOUSE</property>
|
||||||
<property name="window_position">GTK_WIN_POS_MOUSE</property>
|
<property name="type_hint">GDK_WINDOW_TYPE_HINT_DIALOG</property>
|
||||||
<property name="modal">True</property>
|
<child internal-child="vbox">
|
||||||
<property name="resizable">True</property>
|
<widget class="GtkVBox" id="MainVBox">
|
||||||
<property name="destroy_with_parent">False</property>
|
<property name="visible">True</property>
|
||||||
<property name="decorated">True</property>
|
<child>
|
||||||
<property name="skip_taskbar_hint">False</property>
|
<widget class="GtkVBox" id="ProgressBox">
|
||||||
<property name="skip_pager_hint">False</property>
|
<property name="visible">True</property>
|
||||||
<property name="type_hint">GDK_WINDOW_TYPE_HINT_DIALOG</property>
|
<property name="border_width">4</property>
|
||||||
<property name="gravity">GDK_GRAVITY_NORTH_WEST</property>
|
<property name="spacing">6</property>
|
||||||
<property name="focus_on_map">True</property>
|
<child>
|
||||||
<property name="urgency_hint">False</property>
|
<widget class="GtkLabel" id="Label.Description">
|
||||||
<property name="has_separator">True</property>
|
<property name="visible">True</property>
|
||||||
|
<property name="label" translatable="yes"><b>Please wait...</b>
|
||||||
<child internal-child="vbox">
|
while we advance the simulation to fulfill your request:</property>
|
||||||
<widget class="GtkVBox" id="MainVBox">
|
<property name="use_markup">True</property>
|
||||||
<property name="visible">True</property>
|
<property name="justify">GTK_JUSTIFY_CENTER</property>
|
||||||
<property name="homogeneous">False</property>
|
<property name="wrap">True</property>
|
||||||
<property name="spacing">0</property>
|
</widget>
|
||||||
|
</child>
|
||||||
<child internal-child="action_area">
|
<child>
|
||||||
<widget class="GtkHButtonBox" id="MainButtonBox">
|
<widget class="GtkProgressBar" id="ProgressBar">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="layout_style">GTK_BUTTONBOX_SPREAD</property>
|
<property name="pulse_step">0</property>
|
||||||
|
</widget>
|
||||||
<child>
|
<packing>
|
||||||
<widget class="GtkButton" id="OK.Button">
|
<property name="position">1</property>
|
||||||
<property name="visible">True</property>
|
</packing>
|
||||||
<property name="can_default">True</property>
|
</child>
|
||||||
<property name="has_default">True</property>
|
</widget>
|
||||||
<property name="can_focus">True</property>
|
<packing>
|
||||||
<property name="label">gtk-ok</property>
|
<property name="fill">False</property>
|
||||||
<property name="use_stock">True</property>
|
<property name="position">2</property>
|
||||||
<property name="relief">GTK_RELIEF_NORMAL</property>
|
</packing>
|
||||||
<property name="focus_on_click">True</property>
|
</child>
|
||||||
<property name="response_id">-5</property>
|
<child internal-child="action_area">
|
||||||
</widget>
|
<widget class="GtkHButtonBox" id="MainButtonBox">
|
||||||
</child>
|
<property name="visible">True</property>
|
||||||
</widget>
|
<property name="layout_style">GTK_BUTTONBOX_END</property>
|
||||||
<packing>
|
<child>
|
||||||
<property name="padding">0</property>
|
<widget class="GtkButton" id="Button.Stop">
|
||||||
<property name="expand">False</property>
|
<property name="visible">True</property>
|
||||||
<property name="fill">True</property>
|
<property name="can_focus">True</property>
|
||||||
<property name="pack_type">GTK_PACK_END</property>
|
<property name="has_focus">True</property>
|
||||||
</packing>
|
<property name="is_focus">True</property>
|
||||||
</child>
|
<property name="can_default">True</property>
|
||||||
|
<property name="has_default">True</property>
|
||||||
<child>
|
<property name="receives_default">True</property>
|
||||||
<widget class="GtkVBox" id="ProgressBox">
|
<property name="label" translatable="yes">gtk-media-stop</property>
|
||||||
<property name="border_width">4</property>
|
<property name="use_stock">True</property>
|
||||||
<property name="visible">True</property>
|
</widget>
|
||||||
<property name="homogeneous">False</property>
|
</child>
|
||||||
<property name="spacing">6</property>
|
</widget>
|
||||||
|
<packing>
|
||||||
<child>
|
<property name="expand">False</property>
|
||||||
<widget class="GtkTable" id="Instant.Table">
|
<property name="pack_type">GTK_PACK_END</property>
|
||||||
<property name="visible">True</property>
|
</packing>
|
||||||
<property name="n_rows">1</property>
|
</child>
|
||||||
<property name="n_columns">3</property>
|
</widget>
|
||||||
<property name="homogeneous">False</property>
|
</child>
|
||||||
<property name="row_spacing">0</property>
|
</widget>
|
||||||
<property name="column_spacing">6</property>
|
|
||||||
|
|
||||||
<child>
|
|
||||||
<widget class="GtkSpinButton" id="Instant.Spin">
|
|
||||||
<property name="width_request">146</property>
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="can_focus">True</property>
|
|
||||||
<property name="climb_rate">1</property>
|
|
||||||
<property name="digits">0</property>
|
|
||||||
<property name="numeric">True</property>
|
|
||||||
<property name="update_policy">GTK_UPDATE_ALWAYS</property>
|
|
||||||
<property name="snap_to_ticks">False</property>
|
|
||||||
<property name="wrap">False</property>
|
|
||||||
<property name="adjustment">1 1 inf 1 10 10</property>
|
|
||||||
</widget>
|
|
||||||
<packing>
|
|
||||||
<property name="left_attach">1</property>
|
|
||||||
<property name="right_attach">2</property>
|
|
||||||
<property name="top_attach">0</property>
|
|
||||||
<property name="bottom_attach">1</property>
|
|
||||||
<property name="x_options">expand</property>
|
|
||||||
<property name="y_options"></property>
|
|
||||||
</packing>
|
|
||||||
</child>
|
|
||||||
|
|
||||||
<child>
|
|
||||||
<widget class="GtkLabel" id="Instant.Label">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="label" translatable="yes">Instant</property>
|
|
||||||
<property name="use_underline">False</property>
|
|
||||||
<property name="use_markup">False</property>
|
|
||||||
<property name="justify">GTK_JUSTIFY_LEFT</property>
|
|
||||||
<property name="wrap">False</property>
|
|
||||||
<property name="selectable">False</property>
|
|
||||||
<property name="xalign">0.5</property>
|
|
||||||
<property name="yalign">0.5</property>
|
|
||||||
<property name="xpad">0</property>
|
|
||||||
<property name="ypad">0</property>
|
|
||||||
<property name="ellipsize">PANGO_ELLIPSIZE_NONE</property>
|
|
||||||
<property name="width_chars">-1</property>
|
|
||||||
<property name="single_line_mode">False</property>
|
|
||||||
<property name="angle">0</property>
|
|
||||||
</widget>
|
|
||||||
<packing>
|
|
||||||
<property name="left_attach">0</property>
|
|
||||||
<property name="right_attach">1</property>
|
|
||||||
<property name="top_attach">0</property>
|
|
||||||
<property name="bottom_attach">1</property>
|
|
||||||
<property name="y_options"></property>
|
|
||||||
</packing>
|
|
||||||
</child>
|
|
||||||
|
|
||||||
<child>
|
|
||||||
<widget class="GtkButton" id="Jump.Button">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="can_focus">True</property>
|
|
||||||
<property name="relief">GTK_RELIEF_NORMAL</property>
|
|
||||||
<property name="focus_on_click">True</property>
|
|
||||||
|
|
||||||
<child>
|
|
||||||
<widget class="GtkAlignment" id="alignment1">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="xalign">0.5</property>
|
|
||||||
<property name="yalign">0.5</property>
|
|
||||||
<property name="xscale">0</property>
|
|
||||||
<property name="yscale">0</property>
|
|
||||||
<property name="top_padding">0</property>
|
|
||||||
<property name="bottom_padding">0</property>
|
|
||||||
<property name="left_padding">0</property>
|
|
||||||
<property name="right_padding">0</property>
|
|
||||||
|
|
||||||
<child>
|
|
||||||
<widget class="GtkHBox" id="hbox1">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="homogeneous">False</property>
|
|
||||||
<property name="spacing">2</property>
|
|
||||||
|
|
||||||
<child>
|
|
||||||
<widget class="GtkImage" id="image1">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="stock">gtk-jump-to</property>
|
|
||||||
<property name="icon_size">4</property>
|
|
||||||
<property name="xalign">0.5</property>
|
|
||||||
<property name="yalign">0.5</property>
|
|
||||||
<property name="xpad">0</property>
|
|
||||||
<property name="ypad">0</property>
|
|
||||||
</widget>
|
|
||||||
<packing>
|
|
||||||
<property name="padding">0</property>
|
|
||||||
<property name="expand">False</property>
|
|
||||||
<property name="fill">False</property>
|
|
||||||
</packing>
|
|
||||||
</child>
|
|
||||||
|
|
||||||
<child>
|
|
||||||
<widget class="GtkLabel" id="label1">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="label" translatable="yes">Jump!</property>
|
|
||||||
<property name="use_underline">True</property>
|
|
||||||
<property name="use_markup">False</property>
|
|
||||||
<property name="justify">GTK_JUSTIFY_LEFT</property>
|
|
||||||
<property name="wrap">False</property>
|
|
||||||
<property name="selectable">False</property>
|
|
||||||
<property name="xalign">0.5</property>
|
|
||||||
<property name="yalign">0.5</property>
|
|
||||||
<property name="xpad">0</property>
|
|
||||||
<property name="ypad">0</property>
|
|
||||||
<property name="ellipsize">PANGO_ELLIPSIZE_NONE</property>
|
|
||||||
<property name="width_chars">-1</property>
|
|
||||||
<property name="single_line_mode">False</property>
|
|
||||||
<property name="angle">0</property>
|
|
||||||
</widget>
|
|
||||||
<packing>
|
|
||||||
<property name="padding">0</property>
|
|
||||||
<property name="expand">False</property>
|
|
||||||
<property name="fill">False</property>
|
|
||||||
</packing>
|
|
||||||
</child>
|
|
||||||
</widget>
|
|
||||||
</child>
|
|
||||||
</widget>
|
|
||||||
</child>
|
|
||||||
</widget>
|
|
||||||
<packing>
|
|
||||||
<property name="left_attach">2</property>
|
|
||||||
<property name="right_attach">3</property>
|
|
||||||
<property name="top_attach">0</property>
|
|
||||||
<property name="bottom_attach">1</property>
|
|
||||||
<property name="x_options">fill</property>
|
|
||||||
<property name="y_options"></property>
|
|
||||||
</packing>
|
|
||||||
</child>
|
|
||||||
</widget>
|
|
||||||
<packing>
|
|
||||||
<property name="padding">0</property>
|
|
||||||
<property name="expand">False</property>
|
|
||||||
<property name="fill">True</property>
|
|
||||||
</packing>
|
|
||||||
</child>
|
|
||||||
|
|
||||||
<child>
|
|
||||||
<widget class="GtkHSeparator" id="Separator">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
</widget>
|
|
||||||
<packing>
|
|
||||||
<property name="padding">0</property>
|
|
||||||
<property name="expand">False</property>
|
|
||||||
<property name="fill">False</property>
|
|
||||||
</packing>
|
|
||||||
</child>
|
|
||||||
|
|
||||||
<child>
|
|
||||||
<widget class="GtkTable" id="Progress.Table">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="n_rows">1</property>
|
|
||||||
<property name="n_columns">2</property>
|
|
||||||
<property name="homogeneous">False</property>
|
|
||||||
<property name="row_spacing">0</property>
|
|
||||||
<property name="column_spacing">6</property>
|
|
||||||
|
|
||||||
<child>
|
|
||||||
<widget class="GtkButton" id="Stop.Button">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="can_focus">True</property>
|
|
||||||
<property name="relief">GTK_RELIEF_NORMAL</property>
|
|
||||||
<property name="focus_on_click">True</property>
|
|
||||||
|
|
||||||
<child>
|
|
||||||
<widget class="GtkAlignment" id="alignment2">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="xalign">0.5</property>
|
|
||||||
<property name="yalign">0.5</property>
|
|
||||||
<property name="xscale">0</property>
|
|
||||||
<property name="yscale">0</property>
|
|
||||||
<property name="top_padding">0</property>
|
|
||||||
<property name="bottom_padding">0</property>
|
|
||||||
<property name="left_padding">0</property>
|
|
||||||
<property name="right_padding">0</property>
|
|
||||||
|
|
||||||
<child>
|
|
||||||
<widget class="GtkHBox" id="hbox2">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="homogeneous">False</property>
|
|
||||||
<property name="spacing">2</property>
|
|
||||||
|
|
||||||
<child>
|
|
||||||
<widget class="GtkImage" id="image2">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="stock">gtk-media-stop</property>
|
|
||||||
<property name="icon_size">4</property>
|
|
||||||
<property name="xalign">0.5</property>
|
|
||||||
<property name="yalign">0.5</property>
|
|
||||||
<property name="xpad">0</property>
|
|
||||||
<property name="ypad">0</property>
|
|
||||||
</widget>
|
|
||||||
<packing>
|
|
||||||
<property name="padding">0</property>
|
|
||||||
<property name="expand">False</property>
|
|
||||||
<property name="fill">False</property>
|
|
||||||
</packing>
|
|
||||||
</child>
|
|
||||||
|
|
||||||
<child>
|
|
||||||
<widget class="GtkLabel" id="Stop.Label">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="label" translatable="yes">Stop</property>
|
|
||||||
<property name="use_underline">True</property>
|
|
||||||
<property name="use_markup">False</property>
|
|
||||||
<property name="justify">GTK_JUSTIFY_LEFT</property>
|
|
||||||
<property name="wrap">False</property>
|
|
||||||
<property name="selectable">False</property>
|
|
||||||
<property name="xalign">0.5</property>
|
|
||||||
<property name="yalign">0.5</property>
|
|
||||||
<property name="xpad">0</property>
|
|
||||||
<property name="ypad">0</property>
|
|
||||||
<property name="ellipsize">PANGO_ELLIPSIZE_NONE</property>
|
|
||||||
<property name="width_chars">-1</property>
|
|
||||||
<property name="single_line_mode">False</property>
|
|
||||||
<property name="angle">0</property>
|
|
||||||
</widget>
|
|
||||||
<packing>
|
|
||||||
<property name="padding">0</property>
|
|
||||||
<property name="expand">False</property>
|
|
||||||
<property name="fill">False</property>
|
|
||||||
</packing>
|
|
||||||
</child>
|
|
||||||
</widget>
|
|
||||||
</child>
|
|
||||||
</widget>
|
|
||||||
</child>
|
|
||||||
</widget>
|
|
||||||
<packing>
|
|
||||||
<property name="left_attach">1</property>
|
|
||||||
<property name="right_attach">2</property>
|
|
||||||
<property name="top_attach">0</property>
|
|
||||||
<property name="bottom_attach">1</property>
|
|
||||||
<property name="x_options">fill</property>
|
|
||||||
<property name="y_options"></property>
|
|
||||||
</packing>
|
|
||||||
</child>
|
|
||||||
|
|
||||||
<child>
|
|
||||||
<widget class="GtkProgressBar" id="ProgressBar">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="orientation">GTK_PROGRESS_LEFT_TO_RIGHT</property>
|
|
||||||
<property name="fraction">0</property>
|
|
||||||
<property name="pulse_step">0.10000000149</property>
|
|
||||||
<property name="ellipsize">PANGO_ELLIPSIZE_NONE</property>
|
|
||||||
</widget>
|
|
||||||
<packing>
|
|
||||||
<property name="left_attach">0</property>
|
|
||||||
<property name="right_attach">1</property>
|
|
||||||
<property name="top_attach">0</property>
|
|
||||||
<property name="bottom_attach">1</property>
|
|
||||||
<property name="y_options"></property>
|
|
||||||
</packing>
|
|
||||||
</child>
|
|
||||||
</widget>
|
|
||||||
<packing>
|
|
||||||
<property name="padding">4</property>
|
|
||||||
<property name="expand">True</property>
|
|
||||||
<property name="fill">False</property>
|
|
||||||
</packing>
|
|
||||||
</child>
|
|
||||||
</widget>
|
|
||||||
<packing>
|
|
||||||
<property name="padding">0</property>
|
|
||||||
<property name="expand">True</property>
|
|
||||||
<property name="fill">True</property>
|
|
||||||
</packing>
|
|
||||||
</child>
|
|
||||||
</widget>
|
|
||||||
</child>
|
|
||||||
</widget>
|
|
||||||
|
|
||||||
</glade-interface>
|
</glade-interface>
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -51,6 +51,7 @@
|
||||||
#include <glibmm/markup.h>
|
#include <glibmm/markup.h>
|
||||||
#include <glibmm/ustring.h>
|
#include <glibmm/ustring.h>
|
||||||
#include <gtkmm/aboutdialog.h>
|
#include <gtkmm/aboutdialog.h>
|
||||||
|
#include <gtkmm/button.h>
|
||||||
#include <gtkmm/messagedialog.h>
|
#include <gtkmm/messagedialog.h>
|
||||||
#include <gtkmm/menutoolbutton.h>
|
#include <gtkmm/menutoolbutton.h>
|
||||||
#include <gtkmm/filechooserdialog.h>
|
#include <gtkmm/filechooserdialog.h>
|
||||||
|
@ -60,6 +61,7 @@
|
||||||
#include <gtkmm/radiomenuitem.h>
|
#include <gtkmm/radiomenuitem.h>
|
||||||
#include <gtkmm/radiobuttongroup.h>
|
#include <gtkmm/radiobuttongroup.h>
|
||||||
#include <gtkmm/scrolledwindow.h>
|
#include <gtkmm/scrolledwindow.h>
|
||||||
|
#include <gtkmm/spinbutton.h>
|
||||||
#include <gtkmm/statusbar.h>
|
#include <gtkmm/statusbar.h>
|
||||||
#include <gtkmm/stock.h>
|
#include <gtkmm/stock.h>
|
||||||
|
|
||||||
|
@ -77,16 +79,26 @@ GuiBuilder::on_edit_preferences_activate()
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
GuiBuilder::on_simulation_jump_to_activate()
|
GuiBuilder::on_simulation_jump_to_clicked()
|
||||||
{
|
{
|
||||||
using Gnome::Glade::Xml;
|
using Gnome::Glade::Xml;
|
||||||
|
|
||||||
Glib::RefPtr<Xml> jump_to_dialog_glade = Xml::create(GLADEDIR "/jump-to-dialog.glade");
|
// JumpTo spinbox
|
||||||
|
Gtk::SpinButton* jump_to_spin;
|
||||||
|
_refXml->get_widget("BottomHBox.JumpToSpin", jump_to_spin);
|
||||||
|
int target_instant = jump_to_spin->get_value_as_int();
|
||||||
|
assert(target_instant > 0);
|
||||||
|
|
||||||
|
Glib::RefPtr<Xml> jump_to_dialog_glade = Xml::create(GLADEDIR "/jump-to-dialog.glade");
|
||||||
JumpToDialog* jump_to_dialog = NULL;
|
JumpToDialog* jump_to_dialog = NULL;
|
||||||
jump_to_dialog_glade->get_widget_derived("JumpToDialog", jump_to_dialog);
|
jump_to_dialog_glade->get_widget_derived("JumpToDialog", jump_to_dialog);
|
||||||
|
|
||||||
|
jump_to_dialog->set_transient_for(get_initial_window());
|
||||||
|
jump_to_dialog->set_target_instant(target_instant);
|
||||||
jump_to_dialog->run();
|
jump_to_dialog->run();
|
||||||
|
|
||||||
|
jump_to_dialog->hide();
|
||||||
|
delete jump_to_dialog;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -545,11 +557,6 @@ GuiBuilder::GuiBuilder(const std::string& gladefile)
|
||||||
_refXml->get_widget("MenuItem.Edit.Preferences", edit_preferences);
|
_refXml->get_widget("MenuItem.Edit.Preferences", edit_preferences);
|
||||||
edit_preferences->signal_activate().connect(sigc::mem_fun(*this, &GuiBuilder::on_edit_preferences_activate));
|
edit_preferences->signal_activate().connect(sigc::mem_fun(*this, &GuiBuilder::on_edit_preferences_activate));
|
||||||
|
|
||||||
// JumpTo
|
|
||||||
MenuItem* simulation_jump_to = NULL;
|
|
||||||
_refXml->get_widget("MenuItem.Simulation.JumpTo", simulation_jump_to);
|
|
||||||
simulation_jump_to->signal_activate().connect(sigc::mem_fun(*this, &GuiBuilder::on_simulation_jump_to_activate));
|
|
||||||
|
|
||||||
// enable/disable show threads on widgets
|
// enable/disable show threads on widgets
|
||||||
MenuItem* show_threads;
|
MenuItem* show_threads;
|
||||||
_refXml->get_widget("MenuItem.View.ShowThreads", show_threads);
|
_refXml->get_widget("MenuItem.View.ShowThreads", show_threads);
|
||||||
|
@ -633,12 +640,18 @@ GuiBuilder::GuiBuilder(const std::string& gladefile)
|
||||||
|
|
||||||
// ReadyQueue custom label widget
|
// ReadyQueue custom label widget
|
||||||
ReadyQueueWidget& rq_widget = *manage(new ReadyQueueWidget(Simulation::get_instance().get_history()));
|
ReadyQueueWidget& rq_widget = *manage(new ReadyQueueWidget(Simulation::get_instance().get_history()));
|
||||||
HBox* rqb;
|
HBox* bottomhbox;
|
||||||
_refXml->get_widget("ReadyQueueBox", rqb);
|
_refXml->get_widget("BottomHBox", bottomhbox);
|
||||||
rqb->pack_start(rq_widget);
|
bottomhbox->pack_start(rq_widget);
|
||||||
rq_widget.show();
|
rq_widget.show();
|
||||||
|
|
||||||
|
|
||||||
|
// JumpTo button
|
||||||
|
Button* simulation_jump_to = NULL;
|
||||||
|
_refXml->get_widget("BottomHBox.JumpToButton", simulation_jump_to);
|
||||||
|
simulation_jump_to->signal_clicked().connect(sigc::mem_fun(*this, &GuiBuilder::on_simulation_jump_to_clicked));
|
||||||
|
|
||||||
|
|
||||||
// HoltGraph container window
|
// HoltGraph container window
|
||||||
_holt_container.set_keep_above();
|
_holt_container.set_keep_above();
|
||||||
_holt_container.get_holt_widget().set_show_threads(_show_threads);
|
_holt_container.get_holt_widget().set_show_threads(_show_threads);
|
||||||
|
|
|
@ -58,7 +58,7 @@ namespace sgpem
|
||||||
|
|
||||||
void on_edit_preferences_activate();
|
void on_edit_preferences_activate();
|
||||||
|
|
||||||
void on_simulation_jump_to_activate();
|
void on_simulation_jump_to_clicked();
|
||||||
|
|
||||||
void on_view_show_threads_activate();
|
void on_view_show_threads_activate();
|
||||||
void on_view_show_holt_graph_activate();
|
void on_view_show_holt_graph_activate();
|
||||||
|
@ -82,10 +82,9 @@ namespace sgpem
|
||||||
std::string _filename;
|
std::string _filename;
|
||||||
|
|
||||||
HoltContainerWindow _holt_container;
|
HoltContainerWindow _holt_container;
|
||||||
StatisticsContainerWindow _statistics_container;
|
StatisticsContainerWindow _statistics_container;
|
||||||
SimulationWidget* _simulation_widget;
|
SimulationWidget* _simulation_widget;
|
||||||
bool _show_threads;
|
bool _show_threads;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
} //~ namespace sgpem
|
} //~ namespace sgpem
|
||||||
|
|
|
@ -31,53 +31,49 @@
|
||||||
#include <gtkmm/main.h>
|
#include <gtkmm/main.h>
|
||||||
#include <gtkmm/messagedialog.h>
|
#include <gtkmm/messagedialog.h>
|
||||||
|
|
||||||
#include <iostream>
|
|
||||||
|
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
using namespace sgpem;
|
using namespace sgpem;
|
||||||
using namespace Gtk;
|
using namespace Gtk;
|
||||||
using namespace Glib;
|
using namespace Glib;
|
||||||
using Gnome::Glade::Xml;
|
using Gnome::Glade::Xml;
|
||||||
using std::vector;
|
|
||||||
|
|
||||||
JumpToDialog::JumpToDialog(BaseObjectType* cobject, const RefPtr<Xml>& glade) :
|
JumpToDialog::JumpToDialog(BaseObjectType* cobject, const RefPtr<Xml>& glade) :
|
||||||
Dialog(cobject), _glade(glade), _target_instant(0)
|
Dialog(cobject), _glade(glade), _target_instant(0)
|
||||||
{
|
{
|
||||||
_glade->get_widget("OK.Button", _ok_button);
|
_glade->get_widget("Button.Stop", _stop_button);
|
||||||
_glade->get_widget("Jump.Button", _jump_button);
|
|
||||||
_glade->get_widget("Stop.Button", _stop_button);
|
|
||||||
_glade->get_widget("Instant.Spin", _instant_spin);
|
|
||||||
_glade->get_widget("ProgressBar", _progress);
|
_glade->get_widget("ProgressBar", _progress);
|
||||||
|
|
||||||
|
// Attach signal handlers for the Stop button
|
||||||
/** ATTACH SIGNAL HANDLERS FOR BUTTONS **/
|
_stop_button->signal_clicked().connect(sigc::mem_fun(*this, &JumpToDialog::_on_stop));
|
||||||
|
signal_show().connect(sigc::mem_fun(*this, &JumpToDialog::_on_jump));
|
||||||
_jump_button->signal_clicked().connect(
|
|
||||||
sigc::mem_fun(*this, &JumpToDialog::_on_jump));
|
|
||||||
|
|
||||||
_stop_button->signal_clicked().connect(
|
|
||||||
sigc::mem_fun(*this, &JumpToDialog::_on_stop));
|
|
||||||
|
|
||||||
_ok_button->signal_clicked().connect(sigc::bind(
|
|
||||||
sigc::mem_fun(*this, &JumpToDialog::response), RESPONSE_OK));
|
|
||||||
_ok_button->signal_clicked().connect(
|
|
||||||
sigc::mem_fun(*this, &JumpToDialog::hide));
|
|
||||||
|
|
||||||
// FIXME: not implemented
|
|
||||||
_stop_button->set_sensitive(false);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
unsigned int
|
||||||
|
JumpToDialog::set_target_instant(unsigned int new_target)
|
||||||
|
{
|
||||||
|
unsigned int temp = _target_instant;
|
||||||
|
_target_instant = new_target;
|
||||||
|
return temp;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
unsigned int
|
||||||
|
JumpToDialog::get_target_instant() const
|
||||||
|
{
|
||||||
|
return _target_instant;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
JumpToDialog::_on_jump()
|
JumpToDialog::_on_jump()
|
||||||
{
|
{
|
||||||
_ok_button->set_sensitive(false);
|
|
||||||
_stop_button->set_sensitive(true);
|
|
||||||
_jump_button->set_sensitive(false);
|
|
||||||
_progress->set_fraction(0.0);
|
_progress->set_fraction(0.0);
|
||||||
|
|
||||||
assert(_instant_spin->get_value_as_int() > 0);
|
assert(_target_instant > 0);
|
||||||
_target_instant = _instant_spin->get_value_as_int();
|
|
||||||
|
|
||||||
Simulation& sim = Simulation::get_instance();
|
Simulation& sim = Simulation::get_instance();
|
||||||
History& h = sim.get_history();
|
History& h = sim.get_history();
|
||||||
|
@ -99,19 +95,19 @@ JumpToDialog::_on_jump()
|
||||||
break; // Simulation ended before reaching _target_instant
|
break; // Simulation ended before reaching _target_instant
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// TODO: exception handling copied from SimulationController, it should be factored out
|
// TODO: exception handling copied from SimulationController, it should be factored out (?)
|
||||||
catch(const UserInterruptException& uie)
|
catch(const UserInterruptException& uie)
|
||||||
{
|
{
|
||||||
// Show the user a dialog
|
// Show the user a dialog
|
||||||
MessageDialog diag(_("<b>The selected user CPU policy stopped before returning:</b>\n") + Markup::escape_text(uie.what()),
|
MessageDialog diag(_("<b>The selected user CPU policy stopped before returning:</b>\n") + Markup::escape_text(uie.what()),
|
||||||
true, Gtk::MESSAGE_ERROR, Gtk::BUTTONS_OK, true);
|
true, Gtk::MESSAGE_ERROR, Gtk::BUTTONS_OK, true);
|
||||||
diag.run();
|
diag.run();
|
||||||
}
|
}
|
||||||
catch(const MalformedPolicyException& mpe)
|
catch(const MalformedPolicyException& mpe)
|
||||||
{
|
{
|
||||||
// Show user a dialog
|
// Show user a dialog
|
||||||
MessageDialog diag(_("<b>The selected user CPU policy was malformed and failed to sort the queue:</b>\n") +
|
MessageDialog diag(_("<b>The selected user CPU policy was malformed and failed to sort the queue:</b>\n") +
|
||||||
Markup::escape_text(mpe.what()), true, Gtk::MESSAGE_ERROR, Gtk::BUTTONS_OK, true);
|
Markup::escape_text(mpe.what()), true, Gtk::MESSAGE_ERROR, Gtk::BUTTONS_OK, true);
|
||||||
diag.run();
|
diag.run();
|
||||||
|
|
||||||
try
|
try
|
||||||
|
@ -130,31 +126,41 @@ JumpToDialog::_on_jump()
|
||||||
catch(const NullPolicyException& npe)
|
catch(const NullPolicyException& npe)
|
||||||
{
|
{
|
||||||
MessageDialog diag(_("<b>No active policy selected:</b>\n") + Markup::escape_text(npe.what()),
|
MessageDialog diag(_("<b>No active policy selected:</b>\n") + Markup::escape_text(npe.what()),
|
||||||
true, Gtk::MESSAGE_ERROR, Gtk::BUTTONS_OK, true);
|
true, Gtk::MESSAGE_ERROR, Gtk::BUTTONS_OK, true);
|
||||||
diag.run();
|
diag.run();
|
||||||
|
|
||||||
}
|
}
|
||||||
catch(const CPUPolicyException& cpe)
|
catch(const CPUPolicyException& cpe)
|
||||||
{
|
{
|
||||||
MessageDialog diag(_("<b>Unexpected error</b>:\n") + Markup::escape_text(cpe.what()),
|
MessageDialog diag(_("<b>Unexpected error</b>:\n") + Markup::escape_text(cpe.what()),
|
||||||
true, Gtk::MESSAGE_ERROR, Gtk::BUTTONS_OK, true);
|
true, Gtk::MESSAGE_ERROR, Gtk::BUTTONS_OK, true);
|
||||||
diag.run();
|
diag.run();
|
||||||
}
|
}
|
||||||
|
|
||||||
h.set_notify_enabled(reenable);
|
// Ending successfully: detach me, reenable notifications,
|
||||||
|
// and emit response ``okay''
|
||||||
sim.detach(*this);
|
sim.detach(*this);
|
||||||
|
h.set_notify_enabled(reenable);
|
||||||
_ok_button->set_sensitive(true);
|
response(Gtk::RESPONSE_OK);
|
||||||
_stop_button->set_sensitive(false);
|
|
||||||
_jump_button->set_sensitive(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
JumpToDialog::_on_stop()
|
JumpToDialog::_on_stop()
|
||||||
{
|
{
|
||||||
Simulation::get_instance().stop();
|
Simulation::get_instance().stop();
|
||||||
|
response(Gtk::RESPONSE_CANCEL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool
|
||||||
|
JumpToDialog::on_delete_event(GdkEventAny* event)
|
||||||
|
{
|
||||||
|
_on_stop();
|
||||||
|
return Dialog::on_delete_event(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
JumpToDialog::update(const Simulation& changed_simulation)
|
JumpToDialog::update(const Simulation& changed_simulation)
|
||||||
{
|
{
|
||||||
|
@ -168,5 +174,5 @@ JumpToDialog::update(const Simulation& changed_simulation)
|
||||||
// intensive computation it doesn't have
|
// intensive computation it doesn't have
|
||||||
// the time to flush all UI events):
|
// the time to flush all UI events):
|
||||||
while(Gtk::Main::events_pending())
|
while(Gtk::Main::events_pending())
|
||||||
Gtk::Main::iteration();
|
Gtk::Main::iteration();
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,8 +25,8 @@
|
||||||
|
|
||||||
#include <sgpemv2/simulation_observer.hh>
|
#include <sgpemv2/simulation_observer.hh>
|
||||||
|
|
||||||
|
#include <gtkmm/button.h>
|
||||||
#include <gtkmm/dialog.h>
|
#include <gtkmm/dialog.h>
|
||||||
#include <gtkmm/spinbutton.h>
|
|
||||||
#include <gtkmm/progressbar.h>
|
#include <gtkmm/progressbar.h>
|
||||||
#include <libglademm/xml.h>
|
#include <libglademm/xml.h>
|
||||||
|
|
||||||
|
@ -37,6 +37,12 @@ namespace sgpem
|
||||||
public:
|
public:
|
||||||
JumpToDialog(BaseObjectType* cobject, const Glib::RefPtr<Gnome::Glade::Xml>& glade);
|
JumpToDialog(BaseObjectType* cobject, const Glib::RefPtr<Gnome::Glade::Xml>& glade);
|
||||||
|
|
||||||
|
unsigned int set_target_instant(unsigned int new_target = 0);
|
||||||
|
unsigned int get_target_instant() const;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
bool on_delete_event(GdkEventAny* event);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void _on_jump();
|
void _on_jump();
|
||||||
void _on_stop();
|
void _on_stop();
|
||||||
|
@ -45,11 +51,7 @@ namespace sgpem
|
||||||
|
|
||||||
Glib::RefPtr<Gnome::Glade::Xml> _glade;
|
Glib::RefPtr<Gnome::Glade::Xml> _glade;
|
||||||
|
|
||||||
Gtk::Button* _jump_button;
|
|
||||||
Gtk::Button* _stop_button;
|
Gtk::Button* _stop_button;
|
||||||
Gtk::Button* _ok_button;
|
|
||||||
Gtk::SpinButton* _instant_spin;
|
|
||||||
|
|
||||||
Gtk::ProgressBar* _progress;
|
Gtk::ProgressBar* _progress;
|
||||||
|
|
||||||
unsigned int _target_instant;
|
unsigned int _target_instant;
|
||||||
|
|
Loading…
Reference in New Issue