2020-05-04 02:52:56 -04:00
|
|
|
#ifndef RBIMPL_RBIGNUM_H /*-*-C++-*-vi:se ft=cpp:*/
|
|
|
|
#define RBIMPL_RBIGNUM_H
|
2020-04-10 01:11:40 -04:00
|
|
|
/**
|
2020-04-08 00:28:13 -04:00
|
|
|
* @file
|
|
|
|
* @author Ruby developers <ruby-core@ruby-lang.org>
|
|
|
|
* @copyright This file is a part of the programming language Ruby.
|
|
|
|
* Permission is hereby granted, to either redistribute and/or
|
|
|
|
* modify this file, provided that the conditions mentioned in the
|
|
|
|
* file COPYING are met. Consult the file for details.
|
2020-05-04 03:27:48 -04:00
|
|
|
* @warning Symbols prefixed with either `RBIMPL` or `rbimpl` are
|
2020-04-08 00:28:13 -04:00
|
|
|
* implementation details. Don't take them as canon. They could
|
|
|
|
* rapidly appear then vanish. The name (path) of this header file
|
|
|
|
* is also an implementation detail. Do not expect it to persist
|
|
|
|
* at the place it is now. Developers are free to move it anywhere
|
|
|
|
* anytime at will.
|
|
|
|
* @note To ruby-core: remember that this header can be possibly
|
|
|
|
* recursively included from extension libraries written in C++.
|
|
|
|
* Do not expect for instance `__VA_ARGS__` is always available.
|
|
|
|
* We assume C99 for ruby itself but we don't assume languages of
|
2021-01-14 01:00:54 -05:00
|
|
|
* extension libraries. They could be written in C++98.
|
2021-02-02 03:29:23 -05:00
|
|
|
* @brief Routines to manipulate struct RBignum.
|
|
|
|
* @note The struct RBignum itself is opaque.
|
2020-04-08 00:28:13 -04:00
|
|
|
*/
|
2020-05-08 05:31:09 -04:00
|
|
|
#include "ruby/internal/dllexport.h"
|
|
|
|
#include "ruby/internal/value.h"
|
|
|
|
#include "ruby/internal/value_type.h"
|
|
|
|
#include "ruby/internal/stdbool.h"
|
2020-04-08 00:28:13 -04:00
|
|
|
|
2021-02-02 03:29:23 -05:00
|
|
|
#define RBIGNUM_SIGN rb_big_sign /**< @alias{rb_big_sign} */
|
2020-04-08 00:28:13 -04:00
|
|
|
|
|
|
|
/** @cond INTERNAL_MACRO */
|
|
|
|
#define RBIGNUM_POSITIVE_P RBIGNUM_POSITIVE_P
|
|
|
|
#define RBIGNUM_NEGATIVE_P RBIGNUM_NEGATIVE_P
|
|
|
|
/** @endcond */
|
|
|
|
|
2020-05-04 02:52:56 -04:00
|
|
|
RBIMPL_SYMBOL_EXPORT_BEGIN()
|
2021-02-02 03:29:23 -05:00
|
|
|
/**
|
|
|
|
* The "sign" of a bignum.
|
|
|
|
*
|
|
|
|
* @param[in] num An object of RBignum.
|
|
|
|
* @retval 1 It is greater than or equal to zero.
|
|
|
|
* @retval 0 It is less than zero.
|
|
|
|
*
|
|
|
|
* @internal
|
|
|
|
*
|
|
|
|
* Implementation wise, unlike fixnums (which are 2's complement), bignums are
|
|
|
|
* signed magnitude system. Theoretically it could be possible to have
|
|
|
|
* negative zero instances. But in reality there is no way to create such
|
|
|
|
* thing. Nobody ever needed that kind of insanity.
|
|
|
|
*/
|
2020-04-08 00:28:13 -04:00
|
|
|
int rb_big_sign(VALUE num);
|
2020-05-04 02:52:56 -04:00
|
|
|
RBIMPL_SYMBOL_EXPORT_END()
|
2020-04-08 00:28:13 -04:00
|
|
|
|
2021-02-02 03:29:23 -05:00
|
|
|
/**
|
|
|
|
* Checks if the bignum is positive.
|
|
|
|
* @param[in] b An object of RBignum.
|
|
|
|
* @retval false `b` is less than zero.
|
|
|
|
* @retval true Otherwise.
|
|
|
|
*/
|
2020-04-08 00:28:13 -04:00
|
|
|
static inline bool
|
2021-06-16 09:07:05 -04:00
|
|
|
RBIGNUM_POSITIVE_P(VALUE b)
|
|
|
|
{
|
2020-05-04 02:52:56 -04:00
|
|
|
RBIMPL_ASSERT_TYPE(b, RUBY_T_BIGNUM);
|
2020-04-08 00:28:13 -04:00
|
|
|
return RBIGNUM_SIGN(b);
|
|
|
|
}
|
|
|
|
|
2021-02-02 03:29:23 -05:00
|
|
|
/**
|
|
|
|
* Checks if the bignum is negative.
|
|
|
|
* @param[in] b An object of RBignum.
|
|
|
|
* @retval true `b` is less than zero.
|
|
|
|
* @retval false Otherwise.
|
|
|
|
*/
|
2020-04-08 00:28:13 -04:00
|
|
|
static inline bool
|
2021-06-16 09:07:05 -04:00
|
|
|
RBIGNUM_NEGATIVE_P(VALUE b)
|
|
|
|
{
|
2020-05-04 02:52:56 -04:00
|
|
|
RBIMPL_ASSERT_TYPE(b, RUBY_T_BIGNUM);
|
2020-04-08 00:28:13 -04:00
|
|
|
return ! RBIGNUM_POSITIVE_P(b);
|
|
|
|
}
|
|
|
|
|
2020-05-04 02:52:56 -04:00
|
|
|
#endif /* RBIMPL_RBIGNUM_H */
|