This file is indexed.

/usr/share/ada/adainclude/log4ada/log4ada-appenders-xml.adb is in liblog4ada4-dev 1.3-3.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
------------------------------------------------------------------------------
--                                  Log4Ada                                 --
--                                                                          --
--                            Copyright (C) 2007                            --
--                              X. Grave CNRS                               --
--                                                                          --
--  This library 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 library 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 library; if not, write to the Free Software Foundation, --
--  Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.          --
--                                                                          --
with Ada.Command_Line;
with GNAT.Sockets;

with McKae.XML.EZ_Out.Generic_Medium;

package body Log4ada.Appenders.Xml is

   package Output is new McKae.XML.EZ_Out.Generic_Medium (Output_Medium_Type,
                                                          Put,
                                                          New_Line);
   use Output;

   ------------
   -- Append --
   ------------

   procedure Append
     (Xml_Appender : not null access Xml_Appender_Type;
      Event : Events.Event_Type)
   is
      Level : constant Level_Type := Events.Get_Level (Event);
      Time_Stamp_Milliseconds : constant String :=
        Events.Get_Timestamp (Event)'Img & "000";
   begin
      if not Xml_Appender.Enabled then
         return;
      end if;
      if not Continue (Xml_Appender, Event) then
         return;
      end if;
      Current_Format := McKae.XML.EZ_Out.Continuous_Stream;
      Start_Element (Output_Medium,
                     "log4j:event",
                     ("logger" = Events.Get_Logger_Name (Event),
                      "timestamp" = Time_Stamp_Milliseconds
                      (2 .. Time_Stamp_Milliseconds'Last),
                      "level" = Level'Img,
                      "thread" = Events.Get_Location_Information (Event)));
      if Events.Exception_Present (Event) then
         Output_Element (Output_Medium, "log4j:message",
                         Events.Get_Message (Event) & "," &
                         Events.Get_Exception_Name (Event) & "," &
                         Events.Get_Exception_Message (Event));
      else
         Output_Element (Output_Medium, "log4j:message",
                         Events.Get_Message (Event));
      end if;
      Start_Element (Output_Medium, "log4j:NDC");
      Output_Element (Output_Medium, "host", GNAT.Sockets.Host_Name);
      Output_Element (Output_Medium,
                      "prog_name",
                      Ada.Command_Line.Command_Name);
      End_Element (Output_Medium, "log4j:NDC");
      Start_Element (Output_Medium, "log4j:throwable");
      End_Element (Output_Medium, "log4j:throwable");
      End_Element (Output_Medium, "log4j:event");
   end Append;

   procedure Set_Logger (Xml_Appender : not null access Xml_Appender_Type;
                         Logger : Loggers.Logger_Class_Access) is
   begin
      Xml_Appender.Logger := Logger;
   end Set_Logger;

end Log4ada.Appenders.Xml;