/usr/share/ada/adainclude/xmlada/sax-pointers.adb is in libxmlada4.1-dev 4.1-1.
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 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 | -----------------------------------------------------------------------
-- XML/Ada - An XML suite for Ada95 --
-- --
-- Copyright (C) 2007-2010, AdaCore --
-- --
-- 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.Unchecked_Deallocation;
package body Sax.Pointers is
procedure Unchecked_Free is new Ada.Unchecked_Deallocation
(Root_Encapsulated'Class, Root_Encapsulated_Access);
----------
-- Free --
----------
procedure Free (Data : in out Root_Encapsulated) is
pragma Unreferenced (Data);
begin
null;
end Free;
--------------------
-- Smart_Pointers --
--------------------
package body Smart_Pointers is
--------------
-- Allocate --
--------------
function Allocate (Data : Encapsulated'Class) return Pointer is
Tmp : constant Encapsulated_Access :=
new Encapsulated'Class'(Data);
begin
return Allocate (Tmp);
end Allocate;
function Allocate (Data : access Encapsulated'Class) return Pointer is
begin
return (Ada.Finalization.Controlled with
Root_Encapsulated_Access (Data));
end Allocate;
---------
-- Get --
---------
function Get (P : Pointer) return Encapsulated_Access is
begin
return Encapsulated_Access (P.Data);
end Get;
---------
-- "=" --
---------
function "=" (P1, P2 : Pointer) return Boolean is
begin
return P1.Data = P2.Data;
end "=";
--------------
-- Finalize --
--------------
procedure Finalize (P : in out Pointer) is
Data : Root_Encapsulated_Access := P.Data;
begin
-- Make Finalize idempotent, since it could be called several
-- times for the same instance (RM 7.6.1(24)
P.Data := null;
-- Test if refcount is > 0, in case we are already freeing this
-- element. That shouldn't happen, though, since we are not in a
-- multi-tasking environment.
if Data /= null and then Data.Refcount > 0 then
Data.Refcount := Data.Refcount - 1;
if Data.Refcount = 0 then
Free (Data.all);
Unchecked_Free (Data);
end if;
end if;
end Finalize;
------------
-- Adjust --
------------
procedure Adjust (P : in out Pointer) is
begin
if P.Data /= null then
P.Data.Refcount := P.Data.Refcount + 1;
end if;
end Adjust;
end Smart_Pointers;
end Sax.Pointers;
|