xref: /minix3/external/bsd/kyua-cli/dist/utils/units.hpp (revision 84d9c625bfea59e274550651111ae9edfdc40fbd)
111be35a1SLionel Sambuc // Copyright 2012 Google Inc.
211be35a1SLionel Sambuc // All rights reserved.
311be35a1SLionel Sambuc //
411be35a1SLionel Sambuc // Redistribution and use in source and binary forms, with or without
511be35a1SLionel Sambuc // modification, are permitted provided that the following conditions are
611be35a1SLionel Sambuc // met:
711be35a1SLionel Sambuc //
811be35a1SLionel Sambuc // * Redistributions of source code must retain the above copyright
911be35a1SLionel Sambuc //   notice, this list of conditions and the following disclaimer.
1011be35a1SLionel Sambuc // * Redistributions in binary form must reproduce the above copyright
1111be35a1SLionel Sambuc //   notice, this list of conditions and the following disclaimer in the
1211be35a1SLionel Sambuc //   documentation and/or other materials provided with the distribution.
1311be35a1SLionel Sambuc // * Neither the name of Google Inc. nor the names of its contributors
1411be35a1SLionel Sambuc //   may be used to endorse or promote products derived from this software
1511be35a1SLionel Sambuc //   without specific prior written permission.
1611be35a1SLionel Sambuc //
1711be35a1SLionel Sambuc // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
1811be35a1SLionel Sambuc // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
1911be35a1SLionel Sambuc // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
2011be35a1SLionel Sambuc // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
2111be35a1SLionel Sambuc // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
2211be35a1SLionel Sambuc // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
2311be35a1SLionel Sambuc // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
2411be35a1SLionel Sambuc // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
2511be35a1SLionel Sambuc // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
2611be35a1SLionel Sambuc // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
2711be35a1SLionel Sambuc // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
2811be35a1SLionel Sambuc 
2911be35a1SLionel Sambuc /// \file utils/units.hpp
3011be35a1SLionel Sambuc /// Formatters and parsers of user-friendly units.
3111be35a1SLionel Sambuc 
3211be35a1SLionel Sambuc #if !defined(UTILS_UNITS_HPP)
3311be35a1SLionel Sambuc #define UTILS_UNITS_HPP
3411be35a1SLionel Sambuc 
3511be35a1SLionel Sambuc extern "C" {
3611be35a1SLionel Sambuc #include <stdint.h>
3711be35a1SLionel Sambuc }
3811be35a1SLionel Sambuc 
3911be35a1SLionel Sambuc #include <istream>
4011be35a1SLionel Sambuc #include <ostream>
4111be35a1SLionel Sambuc #include <string>
4211be35a1SLionel Sambuc 
4311be35a1SLionel Sambuc namespace utils {
4411be35a1SLionel Sambuc namespace units {
4511be35a1SLionel Sambuc 
4611be35a1SLionel Sambuc 
4711be35a1SLionel Sambuc namespace {
4811be35a1SLionel Sambuc 
4911be35a1SLionel Sambuc /// Constant representing 1 kilobyte.
5011be35a1SLionel Sambuc const uint64_t KB = int64_t(1) << 10;
5111be35a1SLionel Sambuc 
5211be35a1SLionel Sambuc /// Constant representing 1 megabyte.
5311be35a1SLionel Sambuc const uint64_t MB = int64_t(1) << 20;
5411be35a1SLionel Sambuc 
5511be35a1SLionel Sambuc /// Constant representing 1 gigabyte.
5611be35a1SLionel Sambuc const uint64_t GB = int64_t(1) << 30;
5711be35a1SLionel Sambuc 
5811be35a1SLionel Sambuc /// Constant representing 1 terabyte.
5911be35a1SLionel Sambuc const uint64_t TB = int64_t(1) << 40;
6011be35a1SLionel Sambuc 
6111be35a1SLionel Sambuc }  // anonymous namespace
6211be35a1SLionel Sambuc 
6311be35a1SLionel Sambuc 
6411be35a1SLionel Sambuc /// Representation of a bytes quantity.
6511be35a1SLionel Sambuc ///
6611be35a1SLionel Sambuc /// The purpose of this class is to represent an amount of bytes in a semantic
6711be35a1SLionel Sambuc /// manner, and to provide functions to format such numbers for nice user
6811be35a1SLionel Sambuc /// presentation and to parse back such numbers.
6911be35a1SLionel Sambuc ///
7011be35a1SLionel Sambuc /// The input follows this regular expression: [0-9]+(|\.[0-9]+)[GgKkMmTt]?
7111be35a1SLionel Sambuc /// The output follows this regular expression: [0-9]+\.[0-9]{3}[GKMT]?
7211be35a1SLionel Sambuc class bytes {
7311be35a1SLionel Sambuc     /// Raw representation, in bytes, of the quantity.
7411be35a1SLionel Sambuc     uint64_t _count;
7511be35a1SLionel Sambuc 
7611be35a1SLionel Sambuc public:
7711be35a1SLionel Sambuc     bytes(void);
7811be35a1SLionel Sambuc     explicit bytes(const uint64_t);
7911be35a1SLionel Sambuc 
8011be35a1SLionel Sambuc     static bytes parse(const std::string&);
8111be35a1SLionel Sambuc     std::string format(void) const;
8211be35a1SLionel Sambuc 
8311be35a1SLionel Sambuc     operator uint64_t(void) const;
8411be35a1SLionel Sambuc };
8511be35a1SLionel Sambuc 
8611be35a1SLionel Sambuc 
87*84d9c625SLionel Sambuc std::istream& operator>>(std::istream&, bytes&);
88*84d9c625SLionel Sambuc std::ostream& operator<<(std::ostream&, const bytes&);
89*84d9c625SLionel Sambuc 
90*84d9c625SLionel Sambuc 
9111be35a1SLionel Sambuc }  // namespace units
9211be35a1SLionel Sambuc }  // namespace utils
9311be35a1SLionel Sambuc 
9411be35a1SLionel Sambuc #endif  // !defined(UTILS_UNITS_HPP)
95