mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
include/ruby/internal/core/rbignum.h: add doxgen
Must not be a bad idea to improve documents. [ci skip]
This commit is contained in:
parent
7c28330ca0
commit
9c4aa94a19
Notes:
git
2021-09-10 20:01:40 +09:00
1 changed files with 29 additions and 2 deletions
|
@ -18,14 +18,15 @@
|
|||
* Do not expect for instance `__VA_ARGS__` is always available.
|
||||
* We assume C99 for ruby itself but we don't assume languages of
|
||||
* extension libraries. They could be written in C++98.
|
||||
* @brief Routines to manipulate struct ::RBignum.
|
||||
* @brief Routines to manipulate struct RBignum.
|
||||
* @note The struct RBignum itself is opaque.
|
||||
*/
|
||||
#include "ruby/internal/dllexport.h"
|
||||
#include "ruby/internal/value.h"
|
||||
#include "ruby/internal/value_type.h"
|
||||
#include "ruby/internal/stdbool.h"
|
||||
|
||||
#define RBIGNUM_SIGN rb_big_sign
|
||||
#define RBIGNUM_SIGN rb_big_sign /**< @alias{rb_big_sign} */
|
||||
|
||||
/** @cond INTERNAL_MACRO */
|
||||
#define RBIGNUM_POSITIVE_P RBIGNUM_POSITIVE_P
|
||||
|
@ -33,9 +34,29 @@
|
|||
/** @endcond */
|
||||
|
||||
RBIMPL_SYMBOL_EXPORT_BEGIN()
|
||||
/**
|
||||
* 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.
|
||||
*/
|
||||
int rb_big_sign(VALUE num);
|
||||
RBIMPL_SYMBOL_EXPORT_END()
|
||||
|
||||
/**
|
||||
* Checks if the bignum is positive.
|
||||
* @param[in] b An object of RBignum.
|
||||
* @retval false `b` is less than zero.
|
||||
* @retval true Otherwise.
|
||||
*/
|
||||
static inline bool
|
||||
RBIGNUM_POSITIVE_P(VALUE b)
|
||||
{
|
||||
|
@ -43,6 +64,12 @@ RBIGNUM_POSITIVE_P(VALUE b)
|
|||
return RBIGNUM_SIGN(b);
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks if the bignum is negative.
|
||||
* @param[in] b An object of RBignum.
|
||||
* @retval true `b` is less than zero.
|
||||
* @retval false Otherwise.
|
||||
*/
|
||||
static inline bool
|
||||
RBIGNUM_NEGATIVE_P(VALUE b)
|
||||
{
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue