------------------------------------------------------------------------------
------------------------------------------------------------------------------
-- This Ada package was automatically generated by the software engineering tool 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 free real time scheduling tool.
-- This program provides services to automatically check temporal constraints
-- of real time tasks.
--
-- Copyright (C) 2002-2009 Frank Singhoff
-- Cheddar is developed by the LAB-STICC Team, University of Brest
--
-- 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 Automaton;
use Automaton;
use automaton.Transition_Lists_Package;
use automaton.State_Lists_Package;
Package Body Sections is
function XML_String(obj : in Sections_Type; level : in natural := 0) return Unbounded_String is
begin
return to_unbounded_string(Sections_Type'image (obj) );
end XML_String;
function XML_Ref_String (obj : in Sections_Type; level : in natural := 0) return Unbounded_String is
begin
raise xml_ref_string_error;
return to_unbounded_string("");
end XML_Ref_String;
-- --------= Generic_Section =--------
procedure Initialize(obj : in out Generic_Section) is
begin
initialize(Named_Object(obj));
obj.section_type := Automaton_Type;
obj.file_name := empty_string;
obj.object_type := Section_Object_Type;
end Initialize;
function Copy ( obj : in Generic_Section ) return Generic_Section_Ptr is
New_Generic_Section : Generic_Section_Ptr;
begin
New_Generic_Section := new Generic_Section'(obj);
return (New_Generic_Section);
end Copy;
function Copy ( obj : in Generic_Section_Ptr ) return Generic_Section_Ptr is
begin
return copy(obj.all);
end Copy;
procedure Put(obj : in Generic_Section) is
begin
put(Named_Object(obj));
put("section_type: "); put(obj.section_type); put ( "; " );
put("file_name: "); put(obj.file_name); put ( "; " );
end Put;
procedure Put(obj : in Generic_Section_Ptr) is
begin
Put(Obj.All);
end Put;
procedure Put_Name ( obj : in Generic_Section_Ptr) is
begin
Put ( To_String ( Obj.Name ) );
end Put_Name;
function Get_Name (obj : in Generic_Section) return Unbounded_String is
begin
return obj.name;
end Get_Name;
function Get_Name (obj : in Generic_Section_ptr) return Unbounded_String is
begin
return obj.name;
end Get_Name;
function type_of ( obj : in Generic_Section ) 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("SECTIONS.GENERIC_SECTION");
Add (list, s);
return list;
end type_of;
function type_of ( obj : in Generic_Section_Ptr ) return unbounded_string_list is
begin
return type_of(obj.all);
end type_of;
procedure Build_Attributes_XML_String(obj : in Generic_Section; level : in natural := 0; result : in out Unbounded_String) is
begin
Build_Attributes_XML_String(Named_Object(obj), level, result);
if (XML_String(obj.section_type, level + 1) /= Empty_String) then
result := result & unbounded_ht(level + 1) & "" & XML_String(obj.section_type, level + 1) & "" & Unbounded_Lf;
end if;
if (XML_String(obj.file_name, level + 1) /= Empty_String) then
result := result & unbounded_ht(level + 1) & "" & XML_String(obj.file_name, level + 1) & "" & Unbounded_Lf;
end if;
end Build_Attributes_XML_String;
function XML_String(obj : in Generic_Section; level : in natural := 0) return Unbounded_String is
result : Unbounded_String;
begin
result := "" & Unbounded_Lf;
Build_Attributes_XML_String(obj, level, result);
result := result & "" & Unbounded_Lf;
return (result);
end XML_String;
function XML_String(obj : in Generic_Section_Ptr; level : in natural := 0) 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 Generic_Section; level : in natural := 0) return Unbounded_String is
result : Unbounded_String;
begin
result := "" & Unbounded_Lf;
return (result);
end XML_Ref_String;
function XML_Ref_String(obj : in Generic_Section_Ptr; level : in natural := 0) return Unbounded_String is
begin
return XML_Ref_String(obj.all);
end XML_Ref_String;
-- --------= Computation_Section =--------
procedure Initialize(obj : in out Computation_Section) is
begin
initialize(Generic_Section(obj));
end Initialize;
function Copy ( obj : in Computation_Section ) return Generic_Section_Ptr is
New_Computation_Section : Computation_Section_Ptr;
begin
New_Computation_Section := new Computation_Section'(obj);
return Generic_Section_Ptr(New_Computation_Section);
end Copy;
function Copy ( obj : in Computation_Section_Ptr ) return Generic_Section_Ptr is
begin
return copy(obj.all);
end Copy;
procedure Put(obj : in Computation_Section) is
begin
put(Generic_Section(obj));
put("first_statement: "); if obj.first_statement /= null then put(obj.first_statement.all); else put("null"); end if;put ( "; " );
end Put;
procedure Put(obj : in Computation_Section_Ptr) is
begin
Put(Obj.All);
end Put;
procedure Put_Name ( obj : in Computation_Section_Ptr) is
begin
Put ( To_String ( Obj.Name ) );
end Put_Name;
function Get_Name (obj : in Computation_Section) return Unbounded_String is
begin
return obj.name;
end Get_Name;
function Get_Name (obj : in Computation_Section_ptr) return Unbounded_String is
begin
return obj.name;
end Get_Name;
function type_of ( obj : in Computation_Section ) 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("SECTIONS.GENERIC_SECTION");
Add (list, s);
s := new unbounded_string;
s.all := to_unbounded_string("SECTIONS.COMPUTATION_SECTION");
Add (list, s);
return list;
end type_of;
function type_of ( obj : in Computation_Section_Ptr ) return unbounded_string_list is
begin
return type_of(obj.all);
end type_of;
procedure Build_Attributes_XML_String(obj : in Computation_Section; level : in natural := 0; result : in out Unbounded_String) is
begin
Build_Attributes_XML_String(Generic_Section(obj), level, result);
result := result & unbounded_ht ( level + 1 ) & "" & Unbounded_Lf;
end Build_Attributes_XML_String;
function XML_String(obj : in Computation_Section; level : in natural := 0) return Unbounded_String is
result : Unbounded_String;
begin
result := "" & Unbounded_Lf;
Build_Attributes_XML_String(obj, level, result);
result := result & "" & Unbounded_Lf;
return (result);
end XML_String;
function XML_String(obj : in Computation_Section_Ptr; level : in natural := 0) 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 Computation_Section; level : in natural := 0) return Unbounded_String is
result : Unbounded_String;
begin
result := "" & Unbounded_Lf;
return (result);
end XML_Ref_String;
function XML_Ref_String(obj : in Computation_Section_Ptr; level : in natural := 0) return Unbounded_String is
begin
return XML_Ref_String(obj.all);
end XML_Ref_String;
-- --------= Synchronization_Section =--------
procedure Initialize(obj : in out Synchronization_Section) is
begin
initialize(Generic_Section(obj));
end Initialize;
function Copy ( obj : in Synchronization_Section ) return Generic_Section_Ptr is
New_Synchronization_Section : Synchronization_Section_Ptr;
begin
New_Synchronization_Section := new Synchronization_Section'(obj);
return Generic_Section_Ptr(New_Synchronization_Section);
end Copy;
function Copy ( obj : in Synchronization_Section_Ptr ) return Generic_Section_Ptr is
begin
return copy(obj.all);
end Copy;
procedure Put(obj : in Synchronization_Section) is
begin
put(Generic_Section(obj));
put("state_list: "); put(obj.state_list); put ( "; " );
put("transition_list: "); put(obj.transition_list); put ( "; " );
end Put;
procedure Put(obj : in Synchronization_Section_Ptr) is
begin
Put(Obj.All);
end Put;
procedure Put_Name ( obj : in Synchronization_Section_Ptr) is
begin
Put ( To_String ( Obj.Name ) );
end Put_Name;
function Get_Name (obj : in Synchronization_Section) return Unbounded_String is
begin
return obj.name;
end Get_Name;
function Get_Name (obj : in Synchronization_Section_ptr) return Unbounded_String is
begin
return obj.name;
end Get_Name;
function type_of ( obj : in Synchronization_Section ) 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("SECTIONS.GENERIC_SECTION");
Add (list, s);
s := new unbounded_string;
s.all := to_unbounded_string("SECTIONS.SYNCHRONIZATION_SECTION");
Add (list, s);
return list;
end type_of;
function type_of ( obj : in Synchronization_Section_Ptr ) return unbounded_string_list is
begin
return type_of(obj.all);
end type_of;
procedure Build_Attributes_XML_String(obj : in Synchronization_Section; level : in natural := 0; result : in out Unbounded_String) is
begin
Build_Attributes_XML_String(Generic_Section(obj), level, result);
if (XML_String(obj.state_list, level + 1) /= Empty_String) then
result := result & unbounded_ht(level + 1) & "" & XML_String(obj.state_list, level + 1) & "" & Unbounded_Lf;
end if;
if (XML_String(obj.transition_list, level + 1) /= Empty_String) then
result := result & unbounded_ht(level + 1) & "" & XML_String(obj.transition_list, level + 1) & "" & Unbounded_Lf;
end if;
end Build_Attributes_XML_String;
function XML_String(obj : in Synchronization_Section; level : in natural := 0) return Unbounded_String is
result : Unbounded_String;
begin
result := "" & Unbounded_Lf;
Build_Attributes_XML_String(obj, level, result);
result := result & "" & Unbounded_Lf;
return (result);
end XML_String;
function XML_String(obj : in Synchronization_Section_Ptr; level : in natural := 0) 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 Synchronization_Section; level : in natural := 0) return Unbounded_String is
result : Unbounded_String;
begin
result := "" & Unbounded_Lf;
return (result);
end XML_Ref_String;
function XML_Ref_String(obj : in Synchronization_Section_Ptr; level : in natural := 0) return Unbounded_String is
begin
return XML_Ref_String(obj.all);
end XML_Ref_String;
End Sections;