Blame src/bs_size.h

Packit b040ce
#ifndef _BS_SIZE_H
Packit b040ce
#define _BS_SIZE_H
Packit b040ce
Packit b040ce
#include <stdint.h>
Packit b040ce
#include <stdbool.h>
Packit b040ce
Packit b040ce
/**
Packit b040ce
 * BSSize:
Packit b040ce
 * An opaque type representing a size in bytes.
Packit b040ce
 */
Packit b040ce
typedef struct _BSSize * BSSize;
Packit b040ce
Packit b040ce
/**
Packit b040ce
 * BSErrorCode:
Packit b040ce
 *
Packit b040ce
 * @BS_ERROR_INVALID_SPEC: invalid size or unit spec provided
Packit b040ce
 * @BS_ERROR_OVER: a value is over the limits imposed by a type
Packit b040ce
 * @BS_ERROR_ZERO_DIV: an attempt to do division by zero
Packit b040ce
 *
Packit b040ce
 * Error codes that identify various errors that can occur while working with
Packit b040ce
 * #BSSize instances.
Packit b040ce
 */
Packit b040ce
typedef enum {
Packit b040ce
    BS_ERROR_INVALID_SPEC,
Packit b040ce
    BS_ERROR_OVER,
Packit b040ce
    BS_ERROR_ZERO_DIV,
Packit b040ce
    BS_ERROR_FAIL
Packit b040ce
} BSErrorCode;
Packit b040ce
Packit b040ce
/**
Packit b040ce
 * BSError:
Packit b040ce
 *
Packit b040ce
 * @code: error code
Packit b040ce
 * @msg: optional error message
Packit b040ce
 */
Packit b040ce
typedef struct _BSError {
Packit b040ce
    BSErrorCode code;
Packit b040ce
    char *msg;
Packit b040ce
} BSError;
Packit b040ce
Packit b040ce
/**
Packit b040ce
 * BSBunit:
Packit b040ce
 *
Packit b040ce
 * Binary units (multiples of 1024) of size in bytes.
Packit b040ce
 */
Packit b040ce
typedef enum {
Packit b040ce
    BS_BUNIT_B = 0, BS_BUNIT_KiB, BS_BUNIT_MiB, BS_BUNIT_GiB, BS_BUNIT_TiB,
Packit b040ce
    BS_BUNIT_PiB, BS_BUNIT_EiB, BS_BUNIT_ZiB, BS_BUNIT_YiB, BS_BUNIT_UNDEF,
Packit b040ce
} BSBunit;
Packit b040ce
Packit b040ce
/**
Packit b040ce
 * BSDunit:
Packit b040ce
 *
Packit b040ce
 * Decimal units (multiples of 1000) of size in bytes.
Packit b040ce
 */
Packit b040ce
typedef enum {
Packit b040ce
    BS_DUNIT_B = 20, BS_DUNIT_KB, BS_DUNIT_MB, BS_DUNIT_GB, BS_DUNIT_TB,
Packit b040ce
    BS_DUNIT_PB, BS_DUNIT_EB, BS_DUNIT_ZB, BS_DUNIT_YB, BS_DUNIT_UNDEF,
Packit b040ce
} BSDunit;
Packit b040ce
Packit b040ce
/**
Packit b040ce
 * BSRoundDir:
Packit b040ce
 *
Packit b040ce
 * Rounding direction for rounding operations.
Packit b040ce
 */
Packit b040ce
typedef enum {
Packit b040ce
    BS_ROUND_DIR_UP = 0,
Packit b040ce
    BS_ROUND_DIR_DOWN = 1,
Packit b040ce
    BS_ROUND_DIR_HALF_UP = 2
Packit b040ce
} BSRoundDir;
Packit b040ce
Packit b040ce
/**
Packit b040ce
 * BSUnit:
Packit b040ce
 * @bunit: a binary unit
Packit b040ce
 * @dunit: a decimal unit
Packit b040ce
 *
Packit b040ce
 * Generic unit fo size in bytes.
Packit b040ce
 */
Packit b040ce
typedef union {
Packit b040ce
    BSBunit bunit;
Packit b040ce
    BSDunit dunit;
Packit b040ce
} BSUnit;
Packit b040ce
Packit b040ce
/* use 256 bits of precision for floating point numbets, that should be more
Packit b040ce
   than enough */
Packit b040ce
/**
Packit b040ce
 * BS_FLOAT_PREC_BITS:
Packit b040ce
 *
Packit b040ce
 * Precision (in bits) of floating-point numbers used internally.
Packit b040ce
 */
Packit b040ce
#define BS_FLOAT_PREC_BITS 256
Packit b040ce
Packit b040ce
/* Constructors */
Packit b040ce
BSSize bs_size_new (void);
Packit b040ce
BSSize bs_size_new_from_bytes (uint64_t bytes, int sgn);
Packit b040ce
BSSize bs_size_new_from_str (const char *size_str, BSError **error);
Packit b040ce
BSSize bs_size_new_from_size (const BSSize size);
Packit b040ce
Packit b040ce
/* Destructors */
Packit b040ce
void bs_size_free (BSSize size);
Packit b040ce
void bs_clear_error (BSError **error);
Packit b040ce
Packit b040ce
/* Query functions */
Packit b040ce
uint64_t bs_size_get_bytes (const BSSize size, int *sgn, BSError **error);
Packit b040ce
int bs_size_sgn (const BSSize size);
Packit b040ce
char* bs_size_get_bytes_str (const BSSize size);
Packit b040ce
char* bs_size_convert_to (const BSSize size, BSUnit unit, BSError **error);
Packit b040ce
char* bs_size_human_readable (const BSSize size, BSBunit min_unit, int max_places, bool xlate);
Packit b040ce
Packit b040ce
/* Arithmetic */
Packit b040ce
BSSize bs_size_add (const BSSize size1, const BSSize size2);
Packit b040ce
BSSize bs_size_grow (BSSize size1, const BSSize size2);
Packit b040ce
BSSize bs_size_add_bytes (const BSSize size, uint64_t bytes);
Packit b040ce
BSSize bs_size_grow_bytes (BSSize size, uint64_t bytes);
Packit b040ce
BSSize bs_size_sub (const BSSize size1, const BSSize size2);
Packit b040ce
BSSize bs_size_shrink (BSSize size1, const BSSize size2);
Packit b040ce
BSSize bs_size_sub_bytes (const BSSize size, uint64_t bytes);
Packit b040ce
BSSize bs_size_shrink_bytes (BSSize size, uint64_t bytes);
Packit b040ce
BSSize bs_size_mul_int (const BSSize size, uint64_t times);
Packit b040ce
BSSize bs_size_grow_mul_int (BSSize size, uint64_t times);
Packit b040ce
BSSize bs_size_mul_float_str (const BSSize size, const char *float_str, BSError **error);
Packit b040ce
BSSize bs_size_grow_mul_float_str (BSSize size, const char *float_str, BSError **error);
Packit b040ce
uint64_t bs_size_div (const BSSize size1, const BSSize size2, int *sgn, BSError **error);
Packit b040ce
BSSize bs_size_div_int (const BSSize size, uint64_t divisor, BSError **error);
Packit b040ce
BSSize bs_size_shrink_div_int (BSSize size, uint64_t shrink_divisor, BSError **error);
Packit b040ce
char* bs_size_true_div (const BSSize size1, const BSSize size2, BSError **error);
Packit b040ce
char* bs_size_true_div_int (const BSSize size, uint64_t divisor, BSError **error);
Packit b040ce
BSSize bs_size_mod (const BSSize size1, const BSSize size2, BSError **error);
Packit b040ce
BSSize bs_size_round_to_nearest (const BSSize size, const BSSize round_to, BSRoundDir dir, BSError **error);
Packit b040ce
Packit b040ce
/* Comparisons */
Packit b040ce
int bs_size_cmp (const BSSize size1, const BSSize size2, bool abs);
Packit b040ce
int bs_size_cmp_bytes (const BSSize size1, uint64_t bytes, bool abs);
Packit b040ce
Packit b040ce
#endif  /* _BS_SIZE_H */