------------------------------------------------------------------------------ ------------------------------------------------------------------------------ -- Cheddar is a GNU GPL real-time scheduling analysis tool. -- This program provides services to automatically check schedulability and -- other performance criteria of real-time architecture models. -- -- Copyright (C) 2002-2023, Frank Singhoff, Alain Plantec, Jerome Legrand, -- Hai Nam Tran, Stephane Rubini -- -- The Cheddar project was started in 2002 by -- Frank Singhoff, Lab-STICC UMR 6285, Université de Bretagne Occidentale -- -- Cheddar has been published in the "Agence de Protection des Programmes/France" in 2008. -- Since 2008, Ellidiss technologies also contributes to the development of -- Cheddar and provides industrial support. -- -- The full list of contributors and sponsors can be found in README.md -- -- This program is free software; you can redistribute it and/or modify -- it under the terms of the GNU General Public License as published by -- the Free Software Foundation; either version 2 of the License, or -- (at your option) any later version. -- -- This program is distributed in the hope that it will be useful, -- but WITHOUT ANY WARRANTY; without even the implied warranty of -- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -- GNU General Public License for more details. -- -- You should have received a copy of the GNU General Public License -- along with this program; if not, write to the Free Software -- Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA -- -- -- Contact : cheddar@listes.univ-brest.fr -- ------------------------------------------------------------------------------ -- Last update : -- $Rev: 3657 $ -- $Date: 2020-12-13 13:25:49 +0100 (dim., 13 déc. 2020) $ -- $Author: singhoff $ ------------------------------------------------------------------------------ ------------------------------------------------------------------------------ with Ada.Text_IO; use Ada.Text_IO; with Ada.Strings.Unbounded; use Ada.Strings.Unbounded; with Ada.Strings.Unbounded; use Ada.Strings.Unbounded; with Gtk; use Gtk; with Gtk.Menu_Item; use Gtk.Menu_Item; with Gtk.Main; use Gtk.Main; with Glib.Error; use Glib.Error; with Gtk.Widget; use Gtk.Widget; with Gtk.Dialog; use Gtk.Dialog; with Gtk.About_Dialog; use Gtk.About_Dialog; with Gtk.Label; use Gtk.Label; with Glib.Object; use Glib.Object; with Gtk.Text_Buffer; use Gtk.Text_Buffer; with Gtk.Combo_Box; use Gtk.Combo_Box; with Gtk.Combo_Box_text; use Gtk.Combo_Box_text; with Gtk.Text_Iter; use Gtk.Text_Iter; with Gtk.List_Store; use Gtk.List_Store; with Gtk.Tree_Model; use Gtk.Tree_Model; with Gtk.Tree_View; use Gtk.Tree_View; with Gtk.Tree_View_Column; use Gtk.Tree_View_Column; with Glib.Values; use Glib.Values; with Glib; use Glib; with Gtkada.Builder; use Gtkada.Builder; with unbounded_strings; use unbounded_strings; with task_dependencies; use task_dependencies; use task_dependencies.half_dep_set; with dependencies; use dependencies; with task_set; use task_set; with tasks; use tasks; with graphical_editor.manual_callbacks; use graphical_editor.manual_callbacks; with graphical_editor.convert_text; use graphical_editor.convert_text; with convert_unbounded_strings; package body graphical_editor.time_triggered_communication_dependency is time_triggered_table_length : constant Natural := 6; procedure initialize_time_triggered (my_tab : in out table_widget_id; object : access gtkada_builder_record'class) is ob1 : gobject := Get_Object (object, "combobox1"); ob2 : gobject := Get_Object (object, "combobox2"); ob3 : gobject := Get_Object (object, "combobox3"); ob4 : gobject := Get_Object (object, "liststore1"); ob5 : gobject := Get_Object (object, "treeview1"); wid1 : t_widget := (ptype => combo, combo_value => gtk_combo_box_text (ob1)); wid2 : t_widget := (ptype => combo, combo_value => gtk_combo_box_text (ob2)); wid3 : t_widget := (ptype => combo, combo_value => gtk_combo_box_text (ob3)); wid4 : t_widget := (ptype => lists, list_value => gtk_list_store (ob4)); wid5 : t_widget := (ptype => view, view_value => gtk_tree_view (ob5)); wid6 : t_widget := (ptype => my_window, window_value => time_triggered_dependency_window); begin my_tab (1 .. time_triggered_table_length) := (new t_widget'(wid1), new t_widget'(wid2), new t_widget'(wid3), new t_widget'(wid4), new t_widget'(wid5), new t_widget'(wid6)); end initialize_time_triggered; -- Data retrieved from widget -- time_triggered_sink : Unbounded_String; time_triggered_source : Unbounded_String; time_triggered_protocol : time_triggered_communication_timing_property_type; procedure check_time_triggered (my_tab : in out table_widget_id; object : access gtkada_builder_record'class) is begin time_triggered_sink := To_Unbounded_String (Get_Active_Text (gtk_combo_box_text (my_tab (1).combo_value))); time_triggered_source := To_Unbounded_String (Get_Active_Text (gtk_combo_box_text (my_tab (2).combo_value))); time_triggered_protocol := to_type (To_Unbounded_String (Get_Active_Text (gtk_combo_box_text (my_tab (3).combo_value)))) .trigerres_value; end check_time_triggered; procedure add_in_sys_time_triggered (my_tab : in out table_widget_id; object : access gtkada_builder_record'class) is begin add_one_task_dependency_time_triggered (sys.dependencies, search_task (sys.tasks, time_triggered_source), search_task (sys.tasks, time_triggered_sink), time_triggered_protocol); end add_in_sys_time_triggered; procedure deleted_in_sys_time_triggered (my_tab : in out table_widget_id; object : access gtkada_builder_record'class) is begin time_triggered_sink := To_Unbounded_String (Get_Active_Text (gtk_combo_box_text (Get_Object (object, "combobox1")))); time_triggered_source := To_Unbounded_String (Get_Active_Text (gtk_combo_box_text (Get_Object (object, "combobox2")))); time_triggered_protocol := to_type (To_Unbounded_String (Get_Active_Text (gtk_combo_box_text (my_tab (3).combo_value)))) .trigerres_value; delete_one_task_dependency_time_triggered (sys.dependencies, search_task (sys.tasks, time_triggered_source), search_task (sys.tasks, time_triggered_sink), time_triggered_protocol); end deleted_in_sys_time_triggered; procedure show_in_sys_time_triggered (my_tab : in out table_widget_id; object : access gtkada_builder_record'class) is begin null; end show_in_sys_time_triggered; procedure modify_in_sys_time_triggered (my_tab : in out table_widget_id; object : access gtkada_builder_record'class) is begin null; end modify_in_sys_time_triggered; package time_triggered_callbacks is new generic_callbacks (number_of_widget => time_triggered_table_length, initialize => initialize_time_triggered, check => check_time_triggered, add_in_sys => add_in_sys_time_triggered, deleted_in_sys => deleted_in_sys_time_triggered, modify_in_sys => modify_in_sys_time_triggered, show_in_sys => show_in_sys_time_triggered); use time_triggered_callbacks; procedure show_time_triggered_widget is builder : gtkada_builder; error : aliased Glib.Error.gerror; diag : guint; liststore : gobject; tree_iter : gtk_tree_iter; my_iterator : tasks_dependencies_iterator; a_half_dep : dependency_ptr; combo_task_sink, combo_task_source : gobject; my_task_iterator : tasks_iterator; a_task : generic_task_ptr; begin Gtk.Main.Init; Gtk_New (builder); diag := Add_From_File (builder, To_String (glade_path) & "time_triggered_communication_dependency.glade", error'access); if diag = 0 then Ada.Text_IO.Put_Line ("Error : " & Get_Message (error)); Error_Free (error); return; end if; initialize (sys_buffer); duplicate (sys, sys_buffer); combo_task_sink := Get_Object (builder, "combobox1"); combo_task_source := Get_Object (builder, "combobox2"); reset_iterator (sys.tasks, my_task_iterator); if not is_empty (sys.tasks) then loop current_element (sys.tasks, a_task, my_task_iterator); Append_Text (gtk_combo_box_text (combo_task_sink), To_String (a_task.name)); Append_Text (gtk_combo_box_text (combo_task_source), To_String (a_task.name)); exit when is_last_element (sys.tasks, my_task_iterator); next_element (sys.tasks, my_task_iterator); end loop; end if; Set_Active (gtk_combo_box (combo_task_source), 0); Set_Active (gtk_combo_box (combo_task_sink), 0); Set_Active (gtk_combo_box (Get_Object (builder, "combobox3")), 0); if not is_empty (sys.dependencies.depends) then liststore := Get_Object (builder, "liststore1"); reset_iterator (sys.dependencies.depends, my_iterator); loop current_element (sys.dependencies.depends, a_half_dep, my_iterator); if a_half_dep.type_of_dependency = dependencies.time_triggered_communication_dependency then Append (gtk_list_store (liststore), tree_iter); Gtk.List_Store.Set (gtk_list_store (liststore), tree_iter, 0, To_String (a_half_dep.time_triggered_communication_sink.name)); Gtk.List_Store.Set (gtk_list_store (liststore), tree_iter, 1, To_String (a_half_dep.time_triggered_communication_source.name)); Gtk.List_Store.Set (gtk_list_store (liststore), tree_iter, 2, To_String (to_label (new t_all_enumeration_type' (trigerres, a_half_dep.time_triggered_timing_property)))); end if; exit when is_last_element (sys.dependencies.depends, my_iterator); next_element (sys.dependencies.depends, my_iterator); end loop; end if; Gtkada.Builder.Register_Handler (Builder => builder, Handler_Name => "on_button2_clicked", Handler => time_triggered_callbacks.add_view'access); Gtkada.Builder.Register_Handler (Builder => builder, Handler_Name => "on_button4_clicked", Handler => time_triggered_callbacks.delected_lign_selected'access); Gtkada.Builder.Register_Handler (Builder => builder, Handler_Name => "on_button3_clicked", Handler => time_triggered_callbacks.cancel_view'access); Gtkada.Builder.Register_Handler (Builder => builder, Handler_Name => "on_treeview1_cursor_changed", Handler => time_triggered_callbacks.show_lign_selected'access); Gtkada.Builder.Register_Handler (Builder => builder, Handler_Name => "on_button1_clicked", Handler => time_triggered_callbacks.close_view'access); Do_Connect (builder); declare Custom_Widget : constant Gtk.Widget.Gtk_Widget := Gtk.Widget.Gtk_Widget (Get_Object (Builder, "window1")); begin Gtk.Widget.Show_All (Custom_Widget); end; Gtk.Main.Main; Unref (builder); end show_time_triggered_widget; end graphical_editor.time_triggered_communication_dependency;