zjf
2023-03-06 392b76515f40376b6d36f40a114850ef63650384
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
/////////////////////////////////////////////////////////////////////////////// 
// Copyright (C) 2002-2016, Open Design Alliance (the "Alliance"). 
// All rights reserved. 
// 
// This software and its documentation and related materials are owned by 
// the Alliance. The software may only be incorporated into application 
// programs owned by members of the Alliance, subject to a signed 
// Membership Agreement and Supplemental Software License Agreement with the
// Alliance. The structure and organization of this software are the valuable  
// trade secrets of the Alliance and its suppliers. The software is also 
// protected by copyright law and international treaty provisions. Application  
// programs incorporating this software must include the following statement 
// with their copyright notices:
//   
//   This application incorporates Teigha(R) software pursuant to a license 
//   agreement with Open Design Alliance.
//   Teigha(R) Copyright (C) 2002-2016 by Open Design Alliance. 
//   All rights reserved.
//
// By use of this software, its documentation or related materials, you 
// acknowledge and accept the above terms.
///////////////////////////////////////////////////////////////////////////////
 
 
 
 
#ifndef _ODDBSAFETRANSACTION_INCLUDED_
#define _ODDBSAFETRANSACTION_INCLUDED_
 
#include "TD_PackPush.h"
 
#include "RxObject.h"
#include "StaticRxObject.h"
#include "DbTransactionReactor.h"
 
 
/** \details
    This class implements Safe OdDbTransactionReactor objects.
    
    \remarks
    These Reactor objects assure that all active database transactions for the 
    tracked database will be aborted when an instance of this class is destroyed.
 
    <group OdDb_Classes>
*/
class OdDbSafeTransaction : private OdStaticRxObject<OdDbTransactionReactor>
{
  int m_nCounter;
  OdDbDatabase* m_pTrackedDB;
 
  OdDbSafeTransaction& operator = (const OdDbSafeTransaction& other);
 
  /** \details
    Notification function called whenever a transaction has started.
    \remarks
    Increments the reference count of this Reactor object.
  */
void transactionStarted(OdDbDatabase* )  { ++m_nCounter; }
  /** \details
    Notification function called whenever a transaction has ended.
    \param pTrackedDb [in]  Pointer to the tracked database.
    \remarks
    Decrements the reference count of this Reactor object.
 
    This Reactor object is removed from the tracked database when the reference count reaches zero.
  */
  void transactionEnded(OdDbDatabase* pTrackedDb)
  {
    if(!--m_nCounter)
      pTrackedDb->removeTransactionReactor(this);
  }
  /** \details
    Notification function called whenever a transaction has been aborted.
    \param pTrackedDb [in]  Pointer to the tracked database.
    \remarks
    Decrements the reference count of this Reactor object.
 
    This Reactor object is removed from the tracked database when the reference count reaches zero.
  */
  void transactionAborted(OdDbDatabase* pTrackedDb)
  {
    if(!--m_nCounter)
      pTrackedDb->removeTransactionReactor(this);
  }
public:
  /** \param pTrackedDB [in]  Pointer to the tracked database.
    
    \remarks
    Adds this Reactor object to the tracked database. 
  */
  OdDbSafeTransaction(OdDbDatabase* pTrackedDb)
  : m_nCounter(0), m_pTrackedDB(pTrackedDb)
  {
    if (m_pTrackedDB)
    {
      m_pTrackedDB->addTransactionReactor(this);
    }
  }
 
  /** \remarks
    Removes this Reactor object from the tracked database,
    and aborts all active transactions started since this Reactor object
    was constructed. 
  */
    ~OdDbSafeTransaction()
  { 
    m_pTrackedDB->removeTransactionReactor(this);
    while(m_nCounter--)
      m_pTrackedDB->abortTransaction();
  }
};
 
#include "TD_PackPop.h"
 
#endif // _ODDBSAFETRANSACTION_INCLUDED_