------------------------------------------------------------------------------
------------------------------------------------------------------------------
-- This source file was automatically generated by Platypus
-- see http://dossen.univ-brest.fr/apl
--
-- Any modification of this file will be lost.
-- Please see the "platypus" directory instead : it contains the Cheddar's
-- model and its meta-model.
------------------------------------------------------------------------------
------------------------------------------------------------------------------
-- 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-2016 Frank Singhoff, Alain Plantec, Jerome Legrand
--
-- The Cheddar project was started in 2002 by
-- Frank Singhoff, Lab-STICC UMR 6285 laboratory, 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 AUTHORS.txt and SPONSORS.txt
--
-- 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
-- To post to this mailing list, you must be subscribed
-- (see http//beru.univ-brest.fr/~singhoff/cheddar for details)
--
------------------------------------------------------------------------------
------------------------------------------------------------------------------
with Text_io;
use Text_io;
with unbounded_strings;
use unbounded_strings;
with primitive_xml_strings;
use primitive_xml_strings;
with Scheduling_Analysis;
use Scheduling_Analysis;
with Time_Unit_Events;
use Time_Unit_Events;
use Time_Unit_Events.Time_Unit_Package;
Package Body Multiprocessor_Services_Interface is
-- --------= Scheduling_Result =--------
procedure Initialize(obj : out Scheduling_Result) is
begin
obj.scheduling_msg := empty_string;
obj.has_error := false;
obj.error_msg := empty_string;
if obj.result /= null then
Free (obj.result );
end if;
obj.result := new Scheduling_Sequence;
Initialize(obj.result.all);
end Initialize;
procedure Put(obj : in Scheduling_Result) is
begin
put("scheduling_msg: "); put(obj.scheduling_msg); put ( "; " );
put("has_error: "); standards_io.boolean_io.put(obj.has_error); put ( "; " );
put("error_msg: "); put(obj.error_msg); put ( "; " );
put("result: "); if obj.result /= null then put(obj.result.all); else put("null"); end if;put ( "; " );
end Put;
procedure Put(obj : in Scheduling_Result_Ptr) is
begin
Put(Obj.All);
end Put;
procedure Build_Attributes_XML_String(obj : in Scheduling_Result; result : in out Unbounded_String) is
begin
if (XML_String(obj.scheduling_msg) /= Empty_String) then
result := result & to_unbounded_string("") & XML_String(obj.scheduling_msg) & to_unbounded_string("");
end if;
if (XML_String(obj.has_error) /= Empty_String) then
result := result & to_unbounded_string("") & XML_String(obj.has_error) & to_unbounded_string("");
end if;
if (XML_String(obj.error_msg) /= Empty_String) then
result := result & to_unbounded_string("") & XML_String(obj.error_msg) & to_unbounded_string("");
end if;
if (XML_String(obj.result) /= Empty_String) then
result := result & to_unbounded_string("") & XML_String(obj.result) & to_unbounded_string("");
end if;
end Build_Attributes_XML_String;
function XML_String(obj : in Scheduling_Result) return Unbounded_String is
result : Unbounded_String;
begin
result := to_unbounded_string("");
Build_Attributes_XML_String(obj, result);
result := result & to_unbounded_string("");
return (result);
end XML_String;
function XML_String(obj : in Scheduling_Result_Ptr) return Unbounded_String is
begin
if obj /= null then
return XML_String(obj.all);
else
return Empty_String;
end if;
end XML_String;
function XML_Ref_String(obj : in Scheduling_Result) return Unbounded_String is
result : Unbounded_String;
begin
raise xml_ref_string_error;
return to_unbounded_string("");
end XML_Ref_String;
function Copy ( obj : in Scheduling_Result ) return Scheduling_Result_Ptr is
New_Scheduling_Result : Scheduling_Result_Ptr;
begin
New_Scheduling_Result := new Scheduling_Result'(obj);
return (New_Scheduling_Result);
end Copy;
function Copy ( obj : in Scheduling_Result_Ptr ) return Scheduling_Result_Ptr is
begin
return copy(obj.all);
end Copy;
-- --------= Run_Server =--------
procedure Initialize(obj : in out Run_Server) is
begin
initialize(Periodic_Task(obj));
obj.rate := 0.0;
obj.core := empty_string;
obj.executing := false;
obj.job_capacity := 0;
obj.job_duration := 0;
obj.job_release := 0;
obj.job_deadline := 0;
end Initialize;
function Copy ( obj : in Run_Server ) return Run_Server_Ptr is
New_Run_Server : Run_Server_Ptr;
begin
New_Run_Server := new Run_Server'(obj);
return (New_Run_Server);
end Copy;
function Copy ( obj : in Run_Server_Ptr ) return Run_Server_Ptr is
begin
return copy(obj.all);
end Copy;
procedure Put(obj : in Run_Server) is
begin
put(Periodic_Task(obj));
put("rate: "); standards_io.double_io.put(obj.rate); put ( "; " );
put("core: "); put(obj.core); put ( "; " );
put("executing: "); standards_io.boolean_io.put(obj.executing); put ( "; " );
put("deadlines: "); put(obj.deadlines); put ( "; " );
put("periods: "); put(obj.periods); put ( "; " );
put("job: "); put(obj.job); put ( "; " );
put("job_capacity: "); standards_io.natural_io.put(obj.job_capacity); put ( "; " );
put("job_duration: "); standards_io.natural_io.put(obj.job_duration); put ( "; " );
put("job_release: "); standards_io.natural_io.put(obj.job_release); put ( "; " );
put("job_deadline: "); standards_io.natural_io.put(obj.job_deadline); put ( "; " );
end Put;
procedure Put(obj : in Run_Server_Ptr) is
begin
Put(Obj.All);
end Put;
procedure Put_Name ( obj : in Run_Server_Ptr) is
begin
Put ( To_String ( Obj.Name ) );
end Put_Name;
function Get_Name (obj : in Run_Server) return Unbounded_String is
begin
return obj.name;
end Get_Name;
function Get_Name (obj : in Run_Server_ptr) return Unbounded_String is
begin
return obj.name;
end Get_Name;
function type_of ( obj : in Run_Server ) return unbounded_string_list is
list : unbounded_string_list;
s : unbounded_string_ptr;
begin
Initialize(list);
s := new unbounded_string;
s.all := to_unbounded_string("OBJECTS.GENERIC_OBJECT");
Add (list, s);
s := new unbounded_string;
s.all := to_unbounded_string("OBJECTS.NAMED_OBJECT");
Add (list, s);
s := new unbounded_string;
s.all := to_unbounded_string("TASKS.GENERIC_TASK");
Add (list, s);
s := new unbounded_string;
s.all := to_unbounded_string("TASKS.PERIODIC_TASK");
Add (list, s);
s := new unbounded_string;
s.all := to_unbounded_string("MULTIPROCESSOR_SERVICES_INTERFACE.RUN_SERVER");
Add (list, s);
return list;
end type_of;
function type_of ( obj : in Run_Server_Ptr ) return unbounded_string_list is
begin
return type_of(obj.all);
end type_of;
procedure Build_Attributes_XML_String(obj : in Run_Server; result : in out Unbounded_String) is
begin
Build_Attributes_XML_String(Periodic_Task(obj), result);
if (XML_String(obj.rate) /= Empty_String) then
result := result & to_unbounded_string("") & XML_String(obj.rate) & to_unbounded_string("");
end if;
if (XML_String(obj.core) /= Empty_String) then
result := result & to_unbounded_string("") & XML_String(obj.core) & to_unbounded_string("");
end if;
if (XML_String(obj.executing) /= Empty_String) then
result := result & to_unbounded_string("") & XML_String(obj.executing) & to_unbounded_string("");
end if;
if (XML_String(obj.deadlines) /= Empty_String) then
result := result & to_unbounded_string("") & XML_String(obj.deadlines) & to_unbounded_string("");
end if;
if (XML_String(obj.periods) /= Empty_String) then
result := result & to_unbounded_string("") & XML_String(obj.periods) & to_unbounded_string("");
end if;
if (XML_String(obj.job) /= Empty_String) then
result := result & to_unbounded_string("") & XML_String(obj.job) & to_unbounded_string("");
end if;
if (XML_String(obj.job_capacity) /= Empty_String) then
result := result & to_unbounded_string("") & XML_String(obj.job_capacity) & to_unbounded_string("");
end if;
if (XML_String(obj.job_duration) /= Empty_String) then
result := result & to_unbounded_string("") & XML_String(obj.job_duration) & to_unbounded_string("");
end if;
if (XML_String(obj.job_release) /= Empty_String) then
result := result & to_unbounded_string("") & XML_String(obj.job_release) & to_unbounded_string("");
end if;
if (XML_String(obj.job_deadline) /= Empty_String) then
result := result & to_unbounded_string("") & XML_String(obj.job_deadline) & to_unbounded_string("");
end if;
end Build_Attributes_XML_String;
function XML_String(obj : in Run_Server) return Unbounded_String is
result : Unbounded_String;
begin
result := to_unbounded_string("");
Build_Attributes_XML_String(obj, result);
result := result & to_unbounded_string("");
return (result);
end XML_String;
function XML_String(obj : in Run_Server_Ptr) return Unbounded_String is
begin
if obj /= null then
return XML_String(obj.all);
else
return Empty_String;
end if;
end XML_String;
function XML_Ref_String(obj : in Run_Server) return Unbounded_String is
result : Unbounded_String;
begin
result := to_unbounded_string("");
return (result);
end XML_Ref_String;
function XML_Ref_String(obj : in Run_Server_Ptr) return Unbounded_String is
begin
return XML_Ref_String(obj.all);
end XML_Ref_String;
-- --------= Run_Server_Primal =--------
procedure Initialize(obj : in out Run_Server_Primal) is
begin
initialize(Run_Server(obj));
end Initialize;
function Copy ( obj : in Run_Server_Primal ) return Run_Server_Ptr is
New_Run_Server_Primal : Run_Server_Primal_Ptr;
begin
New_Run_Server_Primal := new Run_Server_Primal'(obj);
return Run_Server_Ptr(New_Run_Server_Primal);
end Copy;
function Copy ( obj : in Run_Server_Primal_Ptr ) return Run_Server_Ptr is
begin
return copy(obj.all);
end Copy;
procedure Put(obj : in Run_Server_Primal) is
begin
put(Run_Server(obj));
put("packed_servers: "); put(obj.packed_servers); put ( "; " );
end Put;
procedure Put(obj : in Run_Server_Primal_Ptr) is
begin
Put(Obj.All);
end Put;
procedure Put_Name ( obj : in Run_Server_Primal_Ptr) is
begin
Put ( To_String ( Obj.Name ) );
end Put_Name;
function Get_Name (obj : in Run_Server_Primal) return Unbounded_String is
begin
return obj.name;
end Get_Name;
function Get_Name (obj : in Run_Server_Primal_ptr) return Unbounded_String is
begin
return obj.name;
end Get_Name;
function type_of ( obj : in Run_Server_Primal ) return unbounded_string_list is
list : unbounded_string_list;
s : unbounded_string_ptr;
begin
Initialize(list);
s := new unbounded_string;
s.all := to_unbounded_string("OBJECTS.GENERIC_OBJECT");
Add (list, s);
s := new unbounded_string;
s.all := to_unbounded_string("OBJECTS.NAMED_OBJECT");
Add (list, s);
s := new unbounded_string;
s.all := to_unbounded_string("TASKS.GENERIC_TASK");
Add (list, s);
s := new unbounded_string;
s.all := to_unbounded_string("TASKS.PERIODIC_TASK");
Add (list, s);
s := new unbounded_string;
s.all := to_unbounded_string("MULTIPROCESSOR_SERVICES_INTERFACE.RUN_SERVER");
Add (list, s);
s := new unbounded_string;
s.all := to_unbounded_string("MULTIPROCESSOR_SERVICES_INTERFACE.RUN_SERVER_PRIMAL");
Add (list, s);
return list;
end type_of;
function type_of ( obj : in Run_Server_Primal_Ptr ) return unbounded_string_list is
begin
return type_of(obj.all);
end type_of;
procedure Build_Attributes_XML_String(obj : in Run_Server_Primal; result : in out Unbounded_String) is
begin
Build_Attributes_XML_String(Run_Server(obj), result);
if (XML_String(obj.packed_servers) /= Empty_String) then
result := result & to_unbounded_string("") & XML_String(obj.packed_servers) & to_unbounded_string("");
end if;
end Build_Attributes_XML_String;
function XML_String(obj : in Run_Server_Primal) return Unbounded_String is
result : Unbounded_String;
begin
result := to_unbounded_string("");
Build_Attributes_XML_String(obj, result);
result := result & to_unbounded_string("");
return (result);
end XML_String;
function XML_String(obj : in Run_Server_Primal_Ptr) return Unbounded_String is
begin
if obj /= null then
return XML_String(obj.all);
else
return Empty_String;
end if;
end XML_String;
function XML_Ref_String(obj : in Run_Server_Primal) return Unbounded_String is
result : Unbounded_String;
begin
result := to_unbounded_string("");
return (result);
end XML_Ref_String;
function XML_Ref_String(obj : in Run_Server_Primal_Ptr) return Unbounded_String is
begin
return XML_Ref_String(obj.all);
end XML_Ref_String;
-- --------= Run_Server_Dual =--------
procedure Initialize(obj : in out Run_Server_Dual) is
begin
initialize(Run_Server(obj));
end Initialize;
function Copy ( obj : in Run_Server_Dual ) return Run_Server_Ptr is
New_Run_Server_Dual : Run_Server_Dual_Ptr;
begin
New_Run_Server_Dual := new Run_Server_Dual'(obj);
return Run_Server_Ptr(New_Run_Server_Dual);
end Copy;
function Copy ( obj : in Run_Server_Dual_Ptr ) return Run_Server_Ptr is
begin
return copy(obj.all);
end Copy;
procedure Put(obj : in Run_Server_Dual) is
begin
put(Run_Server(obj));
put("primal_server: "); if obj.primal_server /= null then put(obj.primal_server.all); else put("null"); end if;put ( "; " );
end Put;
procedure Put(obj : in Run_Server_Dual_Ptr) is
begin
Put(Obj.All);
end Put;
procedure Put_Name ( obj : in Run_Server_Dual_Ptr) is
begin
Put ( To_String ( Obj.Name ) );
end Put_Name;
function Get_Name (obj : in Run_Server_Dual) return Unbounded_String is
begin
return obj.name;
end Get_Name;
function Get_Name (obj : in Run_Server_Dual_ptr) return Unbounded_String is
begin
return obj.name;
end Get_Name;
function type_of ( obj : in Run_Server_Dual ) return unbounded_string_list is
list : unbounded_string_list;
s : unbounded_string_ptr;
begin
Initialize(list);
s := new unbounded_string;
s.all := to_unbounded_string("OBJECTS.GENERIC_OBJECT");
Add (list, s);
s := new unbounded_string;
s.all := to_unbounded_string("OBJECTS.NAMED_OBJECT");
Add (list, s);
s := new unbounded_string;
s.all := to_unbounded_string("TASKS.GENERIC_TASK");
Add (list, s);
s := new unbounded_string;
s.all := to_unbounded_string("TASKS.PERIODIC_TASK");
Add (list, s);
s := new unbounded_string;
s.all := to_unbounded_string("MULTIPROCESSOR_SERVICES_INTERFACE.RUN_SERVER");
Add (list, s);
s := new unbounded_string;
s.all := to_unbounded_string("MULTIPROCESSOR_SERVICES_INTERFACE.RUN_SERVER_DUAL");
Add (list, s);
return list;
end type_of;
function type_of ( obj : in Run_Server_Dual_Ptr ) return unbounded_string_list is
begin
return type_of(obj.all);
end type_of;
procedure Build_Attributes_XML_String(obj : in Run_Server_Dual; result : in out Unbounded_String) is
begin
Build_Attributes_XML_String(Run_Server(obj), result);
result := result & to_unbounded_string("");
end Build_Attributes_XML_String;
function XML_String(obj : in Run_Server_Dual) return Unbounded_String is
result : Unbounded_String;
begin
result := to_unbounded_string("");
Build_Attributes_XML_String(obj, result);
result := result & to_unbounded_string("");
return (result);
end XML_String;
function XML_String(obj : in Run_Server_Dual_Ptr) return Unbounded_String is
begin
if obj /= null then
return XML_String(obj.all);
else
return Empty_String;
end if;
end XML_String;
function XML_Ref_String(obj : in Run_Server_Dual) return Unbounded_String is
result : Unbounded_String;
begin
result := to_unbounded_string("");
return (result);
end XML_Ref_String;
function XML_Ref_String(obj : in Run_Server_Dual_Ptr) return Unbounded_String is
begin
return XML_Ref_String(obj.all);
end XML_Ref_String;
End Multiprocessor_Services_Interface;