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
/////////////////////////////////////////////////////////////////////////////// 
// 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 _ODDB_HOSTAPPPROGRESSMETER_INCLUDED_
#define _ODDB_HOSTAPPPROGRESSMETER_INCLUDED_
 
 
#include "TD_PackPush.h"
 
 
#include "DbRootExport.h"
#include "OdString.h"
 
 
/** \details
    This class is the base class for platform specific progress metering
    within Teigha.
 
    Library: TD_Db
 
    \remarks
    This class receives progress notifications during various database operations such
    as loading or saving a file.
 
    Calls to an instance of this class will always come in the following order:
 
    1.  setLimit (called once).
    2.  start (called once).
    3.  meterProgress (called repeatedly).
    4.  stop (called once).
 
    <group OdDb_Classes>
*/
class DBROOT_EXPORT OdDbHostAppProgressMeter
{
public:
  virtual ~OdDbHostAppProgressMeter();
 
    /** \details
    Notification function called to initialize this ProgressMeter object.
    \param displayString [in]  String to be displayed.
    */
  virtual void start(
    const OdString& displayString = OdString::kEmpty) = 0;
 
  /** \details
    Notification function called to terminate this ProgressMeter object.
  */
  virtual void stop() = 0;
 
  /** \details
    Notification function called to increment this ProgressMeter object.
 
    \remarks
    The completion percentage may be calculated by dividing the number of times
    this function is called by the value set by setLimit.
 
    \note
    Throwing an exception indicates that the operation associated with this ProgressMeter object
    should be halted.
  */
  virtual void meterProgress() = 0;
 
  /** \details
    Notification function called to specify the maximum number of times this
    ProgressMeter object will be incremented.
 
    \param max [in]  Maximum meterProgress calls.
  */
  virtual void setLimit(
    int max) = 0;
};
 
 
#include "TD_PackPop.h"
 
#endif // _ODDB_HOSTAPPPROGRESSMETER_INCLUDED_