55fb1d40f1260cd68336f2abe8423931aaefcf93
[occt.git] / src / Standard / Handle_Standard_Transient.cxx
1 // Copyright (c) 1998-1999 Matra Datavision
2 // Copyright (c) 1999-2014 OPEN CASCADE SAS
3 //
4 // This file is part of Open CASCADE Technology software library.
5 //
6 // This library is free software; you can redistribute it and / or modify it
7 // under the terms of the GNU Lesser General Public version 2.1 as published
8 // by the Free Software Foundation, with special exception defined in the file
9 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
10 // distribution for complete text of the license and disclaimer of any warranty.
11 //
12 // Alternatively, this file may be used under the terms of Open CASCADE
13 // commercial license or contractual agreement.
14
15 #include <Handle_Standard_Transient.hxx>
16 #include <Standard_Atomic.hxx>
17
18 //============================================================================
19
20 void Handle(Standard_Transient)::Dump(Standard_OStream& out) const
21
22   out << Access();
23 }
24
25 //============================================================================
26
27 void Handle(Standard_Transient)::Assign (const Standard_Transient *anItem)
28 {
29   Standard_Transient *anIt = ( anItem ? (Standard_Transient*)anItem : UndefinedHandleAddress );
30   if ( anIt == entity ) return;
31   EndScope();
32   entity = anIt;
33   BeginScope();
34 }
35
36 //============================================================================
37
38 void Handle(Standard_Transient)::BeginScope()
39 {
40   if (entity != UndefinedHandleAddress)
41   {
42     Standard_Atomic_Increment (&entity->count);
43   }
44 }
45
46 //============================================================================
47
48 void Handle(Standard_Transient)::EndScope()
49 {
50   if (entity == UndefinedHandleAddress)
51     return;
52   if (Standard_Atomic_Decrement (&entity->count) == 0)
53     entity->Delete();
54   entity = UndefinedHandleAddress;
55 }