/usr/include/oce/Message_ProgressIndicator.hxx is in liboce-foundation-dev 0.17.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 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 | // This file is generated by WOK (CPPExt).
// Please do not edit this file; modify original file instead.
// The copyright and license terms as defined for the original file apply to
// this header file considered to be the "object code" form of the original source.
#ifndef _Message_ProgressIndicator_HeaderFile
#define _Message_ProgressIndicator_HeaderFile
#include <Standard.hxx>
#include <Standard_DefineHandle.hxx>
#include <Handle_Message_ProgressIndicator.hxx>
#include <Standard_Real.hxx>
#include <Message_SequenceOfProgressScale.hxx>
#include <MMgt_TShared.hxx>
#include <Standard_CString.hxx>
#include <Handle_TCollection_HAsciiString.hxx>
#include <Standard_Boolean.hxx>
#include <Standard_Integer.hxx>
class TCollection_HAsciiString;
class Message_ProgressScale;
//! Defines abstract interface from program to the "user".
//! That includes progress indication and user break mechanisms
//!
//! The interface to progress indicator represents it as a scale
//! for each range and step can be defined by the program that uses it.
//! The scale can be made "infinite", which means it will grow
//! non-linearly, end of scale will be approached asymptotically at
//! infinite number of steps. In that case value of scale range
//! gives a number of steps corresponding to position at 1/2 of scale.
//! The current position can be either set directly (in a range from
//! current position to maximum scale value), or incremented step
//! by step.
//!
//! Progress indication mechanism is adapted for convenient
//! usage in hiererchical processes that require indication of
//! progress at several (sub)levels of the process.
//! For that purpose, it is possible to create restricted sub-scope of
//! indication by specifying part of a current scale that is to be
//! used by the subprocess.
//! When subprocess works with progress indicator in the restricted
//! scope, it has the same interface to a scale, while actually it
//! deals only with part of the whole scale.
//!
//! NOTE:
//! Currently there is no support for concurrent progress
//! indicator that could be useful in multithreaded applications.
//! The main reason for this is that such implementation would be
//! too complex regarding forecasted lack of real need for such
//! support.
//! To support this it would require that ProgressScale keep its
//! own position and take care of incrementing main ProgressIndicator
//! in destructor. This would also require having cross-references
//! between nested instances of ProgressScale, ie. potential
//! problems with memory management.
//! In case of need of concurrent progress indicator two things can
//! be suggested: either creation of single spane with summary number
//! of steps, or usage of infinite scale.
//!
//! The user break is implemented as virtual function that might
//! return True in case if break signal from the user is obtained.
//!
//! The derived classes should take care of visualisation of the
//! progress indicator (e.g. show total position at the graphical bar,
//! and/or print all scopes in text mode), and for implementation
//! of user break mechanism (if defined).
class Message_ProgressIndicator : public MMgt_TShared
{
public:
//! Drops all scopes and sets scale from 0 to 100, step 1
//! This scale has name "Step"
Standard_EXPORT virtual void Reset() ;
void SetName (const Standard_CString name) ;
//! Set (optional) name for scale
void SetName (const Handle(TCollection_HAsciiString)& name) ;
//! Set range for current scale
void SetRange (const Standard_Real min, const Standard_Real max) ;
//! Set step for current scale
void SetStep (const Standard_Real step) ;
//! Set or drop infinite mode for the current scale
void SetInfinite (const Standard_Boolean isInf = Standard_True) ;
void SetScale (const Standard_CString name, const Standard_Real min, const Standard_Real max, const Standard_Real step, const Standard_Boolean isInf = Standard_False) ;
//! Set all parameters for current scale
Standard_EXPORT void SetScale (const Standard_Real min, const Standard_Real max, const Standard_Real step, const Standard_Boolean isInf = Standard_False) ;
//! Returns all parameters for current scale
Standard_EXPORT void GetScale (Standard_Real& min, Standard_Real& max, Standard_Real& step, Standard_Boolean& isInf) const;
Standard_EXPORT void SetValue (const Standard_Real val) ;
//! Set and get progress value at current scale
//! If the value to be set is more than currently set one, or out
//! of range for the current scale, it is limited by that range
Standard_EXPORT Standard_Real GetValue() const;
void Increment() ;
//! Increment the progress value by the default of specified step
void Increment (const Standard_Real step) ;
Standard_Boolean NewScope (const Standard_CString name = 0) ;
Standard_Boolean NewScope (const Handle(TCollection_HAsciiString)& name) ;
Standard_Boolean NewScope (const Standard_Real span, const Standard_CString name = 0) ;
//! Creates new scope on a part of a current scale from current
//! position with span either equal to default step, or specified
//! The scale for the new scope will have specified name and
//! ranged from 0 to 100 with step 1
//! Returns False if something is wrong in arguments or in current
//! position of progress indicator; scope is opened anyway
Standard_EXPORT Standard_Boolean NewScope (const Standard_Real span, const Handle(TCollection_HAsciiString)& name) ;
//! Close the current scope and thus return to previous scale
//! Updates position to be at the end of the closing scope
//! Returns False if no scope is opened
Standard_EXPORT Standard_Boolean EndScope() ;
Standard_Boolean NextScope (const Standard_CString name = 0) ;
//! Optimized version of { return EndScope() && NewScope(); }
Standard_EXPORT Standard_Boolean NextScope (const Standard_Real span, const Standard_CString name = 0) ;
//! Should return True if user has send a break signal.
//! Default implementation returns False.
Standard_EXPORT virtual Standard_Boolean UserBreak() ;
//! Update presentation of the progress indicator
//! Called when progress position is changed
//! Flag force is intended for forcing update in case if it is
//! optimized; all internal calls from ProgressIndicator are
//! done with this flag equal to False
Standard_EXPORT virtual Standard_Boolean Show (const Standard_Boolean force = Standard_True) = 0;
//! Returns total progress position on the basic scale
//! ranged from 0. to 1.
Standard_Real GetPosition() const;
//! Returns current number of opened scopes
//! This number is always >=1 as top-level scale is always present
Standard_EXPORT Standard_Integer GetNbScopes() const;
//! Returns data for scale of index-th scope
//! The first scope is current one, the last is the top-level one
Standard_EXPORT const Message_ProgressScale& GetScope (const Standard_Integer index) const;
DEFINE_STANDARD_RTTI(Message_ProgressIndicator)
protected:
//! Constructor, just calls own Reset() (not yet redefined)
Standard_EXPORT Message_ProgressIndicator();
private:
Standard_Real myPosition;
Message_SequenceOfProgressScale myScopes;
};
#include <Message_ProgressIndicator.lxx>
#endif // _Message_ProgressIndicator_HeaderFile
|