mirror of
https://github.com/PurpleI2P/Boost-for-Android-Prebuilt
synced 2025-01-24 05:25:26 +00:00
91 lines
3.3 KiB
C++
91 lines
3.3 KiB
C++
|
|
||
|
// Copyright Beman Dawes 1994-99.
|
||
|
// Copyright Peter Dimov 2019.
|
||
|
// Distributed under the Boost Software License, Version 1.0.
|
||
|
// (http://www.boost.org/LICENSE_1_0.txt)
|
||
|
//
|
||
|
// See http://www.boost.org/libs/timer for documentation.
|
||
|
|
||
|
#ifndef BOOST_TIMER_PROGRESS_DISPLAY_HPP_INCLUDED
|
||
|
#define BOOST_TIMER_PROGRESS_DISPLAY_HPP_INCLUDED
|
||
|
|
||
|
#include <boost/noncopyable.hpp>
|
||
|
#include <iostream> // for ostream, cout, etc
|
||
|
#include <string> // for string
|
||
|
|
||
|
namespace boost {
|
||
|
namespace timer {
|
||
|
|
||
|
// progress_display --------------------------------------------------------//
|
||
|
|
||
|
// progress_display displays an appropriate indication of
|
||
|
// progress at an appropriate place in an appropriate form.
|
||
|
|
||
|
class progress_display : private noncopyable
|
||
|
{
|
||
|
public:
|
||
|
explicit progress_display( unsigned long expected_count_,
|
||
|
std::ostream & os = std::cout,
|
||
|
const std::string & s1 = "\n", //leading strings
|
||
|
const std::string & s2 = "",
|
||
|
const std::string & s3 = "" )
|
||
|
// os is hint; implementation may ignore, particularly in embedded systems
|
||
|
: noncopyable(), m_os(os), m_s1(s1), m_s2(s2), m_s3(s3) { restart(expected_count_); }
|
||
|
|
||
|
void restart( unsigned long expected_count_ )
|
||
|
// Effects: display appropriate scale
|
||
|
// Postconditions: count()==0, expected_count()==expected_count_
|
||
|
{
|
||
|
_count = _next_tic_count = _tic = 0;
|
||
|
_expected_count = expected_count_;
|
||
|
|
||
|
m_os << m_s1 << "0% 10 20 30 40 50 60 70 80 90 100%\n"
|
||
|
<< m_s2 << "|----|----|----|----|----|----|----|----|----|----|"
|
||
|
<< std::endl // endl implies flush, which ensures display
|
||
|
<< m_s3;
|
||
|
if ( !_expected_count ) _expected_count = 1; // prevent divide by zero
|
||
|
} // restart
|
||
|
|
||
|
unsigned long operator+=( unsigned long increment )
|
||
|
// Effects: Display appropriate progress tic if needed.
|
||
|
// Postconditions: count()== original count() + increment
|
||
|
// Returns: count().
|
||
|
{
|
||
|
if ( (_count += increment) >= _next_tic_count ) { display_tic(); }
|
||
|
return _count;
|
||
|
}
|
||
|
|
||
|
unsigned long operator++() { return operator+=( 1 ); }
|
||
|
unsigned long count() const { return _count; }
|
||
|
unsigned long expected_count() const { return _expected_count; }
|
||
|
|
||
|
private:
|
||
|
std::ostream & m_os; // may not be present in all imps
|
||
|
const std::string m_s1; // string is more general, safer than
|
||
|
const std::string m_s2; // const char *, and efficiency or size are
|
||
|
const std::string m_s3; // not issues
|
||
|
|
||
|
unsigned long _count, _expected_count, _next_tic_count;
|
||
|
unsigned int _tic;
|
||
|
void display_tic()
|
||
|
{
|
||
|
// use of floating point ensures that both large and small counts
|
||
|
// work correctly. static_cast<>() is also used several places
|
||
|
// to suppress spurious compiler warnings.
|
||
|
unsigned int tics_needed = static_cast<unsigned int>((static_cast<double>(_count)
|
||
|
/ static_cast<double>(_expected_count)) * 50.0);
|
||
|
do { m_os << '*' << std::flush; } while ( ++_tic < tics_needed );
|
||
|
_next_tic_count =
|
||
|
static_cast<unsigned long>((_tic/50.0) * static_cast<double>(_expected_count));
|
||
|
if ( _count == _expected_count ) {
|
||
|
if ( _tic < 51 ) m_os << '*';
|
||
|
m_os << std::endl;
|
||
|
}
|
||
|
} // display_tic
|
||
|
};
|
||
|
|
||
|
} // namespace timer
|
||
|
} // namespace boost
|
||
|
|
||
|
#endif // BOOST_TIMER_PROGRESS_DISPLAY_HPP_INCLUDED
|