/usr/include/dar/deci.hpp is in libdar-dev 2.4.8-1ubuntu1.
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 | /*********************************************************************/
// dar - disk archive - a backup/restoration program
// Copyright (C) 2002-2052 Denis Corbin
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation; either version 2
// of the License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
//
// to contact the author : http://dar.linux.free.fr/email.html
/*********************************************************************/
/// \file deci.hpp
/// \brief manages the decimal representation of infinint
/// \ingroup Tools
#ifndef DECI_HPP
#define DECI_HPP
#include "/usr/include/dar/libdar_my_config.h"
#include <iostream>
#include "/usr/include/dar/storage.hpp"
#include "/usr/include/dar/infinint.hpp"
namespace libdar
{
/// \ingroup Tools
/// @}
/// decimal class, convert infinint from and to decimal represention
/// the class contains the decimal representation of an integer
/// and can produce a readable string to display the corresponding
/// integer it can also produce a computer value corresponding to
/// the decimal value. In the other side, objects of this class can
/// be built from a integer as well as from a string representing
/// the decimals of an integer.
class deci
{
public :
/// constructor to build a "deci" object from a string representing decimals
deci(std::string s);
/// constructor to build a "deci" from an infinint
deci(const infinint & x);
/// copy constructor
deci(const deci & ref)
{ copy_from(ref); };
/// destructor
~deci()
{ detruit(); };
/// copy operator
const deci & operator = (const deci & ref)
{ detruit(); copy_from(ref); return *this; };
/// this produce a infinint from the decimal stored in the current object
infinint computer() const;
/// this produce a string fromr the decimal stored in the current object
std::string human() const;
#ifdef LIBDAR_SPECIAL_ALLOC
USE_SPECIAL_ALLOC(deci);
#endif
private :
storage *decimales;
void detruit();
void copy_from(const deci & ref);
void reduce();
};
/// specific << operator to use infinint in std::ostream
/// including "deci.hpp" let this operator available so you can
/// display infinint with the << std::ostream operator as you can
/// do for standard types.
/// \ingroup Tools
extern std::ostream & operator << (std::ostream & ref, const infinint & arg);
/// @}
} // end of namespace
#endif
|