diff options
| author | Seba Gamboa <[email protected]> | 2015-09-21 11:59:39 -0300 |
|---|---|---|
| committer | Seba Gamboa <[email protected]> | 2015-09-21 11:59:39 -0300 |
| commit | dd925578c604a608f83172f85d8e5bfc3bb99c6a (patch) | |
| tree | 1796d2f9f9bf1e8f209fb194ece362afaf1fbea2 /include | |
| parent | 40bf7bde785f45b46ec0dd72239822b8e9cb2a1a (diff) | |
| download | mruby-dd925578c604a608f83172f85d8e5bfc3bb99c6a.tar.gz mruby-dd925578c604a608f83172f85d8e5bfc3bb99c6a.zip | |
Sort compiler macros around
Diffstat (limited to 'include')
| -rw-r--r-- | include/mruby.h | 70 | ||||
| -rw-r--r-- | include/mruby/common.h | 53 |
2 files changed, 92 insertions, 31 deletions
diff --git a/include/mruby.h b/include/mruby.h index 6d8b5555d..4af607b26 100644 --- a/include/mruby.h +++ b/include/mruby.h @@ -39,7 +39,6 @@ /** * @file mruby.h - * @brief Main header of mruby C API. Include this first. * @defgroup mruby MRuby C API * @{ */ @@ -57,11 +56,13 @@ struct mrb_irep; struct mrb_state; /** - * Function pointer type of custom allocator used in mrb_open_allocf. + * Function pointer type of custom allocator used in @ref mrb_open_allocf. * * The function pointing it must behave similarly as realloc except: * - If ptr is NULL it must allocate new space. * - If s is NULL, ptr must be freed. + * + * See @ref mrb_default_allocf for the default implementation. */ typedef void* (*mrb_allocf) (struct mrb_state *mrb, void*, size_t, void *ud); @@ -205,18 +206,6 @@ typedef struct mrb_state { mrb_int atexit_stack_len; } mrb_state; -#if __STDC_VERSION__ >= 201112L -# define mrb_noreturn _Noreturn -#elif defined __GNUC__ && !defined __STRICT_ANSI__ -# define mrb_noreturn __attribute__((noreturn)) -# define mrb_deprecated __attribute__((deprecated)) -#elif defined _MSC_VER -# define mrb_noreturn __declspec(noreturn) -# define mrb_deprecated __declspec(deprecated) -#else -# define mrb_noreturn -# define mrb_deprecated -#endif typedef mrb_value (*mrb_func_t)(mrb_state *mrb, mrb_value); @@ -278,8 +267,29 @@ MRB_API void mrb_define_module_function(mrb_state*, struct RClass*, const char*, MRB_API void mrb_define_const(mrb_state*, struct RClass*, const char *name, mrb_value); MRB_API void mrb_undef_method(mrb_state*, struct RClass*, const char*); MRB_API void mrb_undef_class_method(mrb_state*, struct RClass*, const char*); + +/** + * Initialize a new object instace of c class. + * + * @param mrb + * The current mruby state. + * @param c + * Reference to the class of the new object. + * @param argc + * Number of arguments in argv + * @param argv + * Array of @ref mrb_value "mrb_values" to initialize the object + * @returns + * The newly initialized object + */ MRB_API mrb_value mrb_obj_new(mrb_state *mrb, struct RClass *c, mrb_int argc, const mrb_value *argv); -#define mrb_class_new_instance(mrb,argc,argv,c) mrb_obj_new(mrb,c,argc,argv) + +/** See @ref mrb_obj_new */ +MRB_INLINE mrb_value mrb_class_new_instance(mrb_state *mrb, struct RClass *c, mrb_int argc, const mrb_value *argv) +{ + return mrb_obj_new(mrb,c,argc,argv); +} + MRB_API mrb_value mrb_instance_new(mrb_state *mrb, mrb_value cv); MRB_API struct RClass * mrb_class_new(mrb_state *mrb, struct RClass *super); MRB_API struct RClass * mrb_module_new(mrb_state *mrb); @@ -464,19 +474,32 @@ char* mrb_locale_from_utf8(const char *p, size_t len); */ MRB_API mrb_state* mrb_open(void); - /** - * Create new mrb_state with custom allocator. + * Create new mrb_state with custom allocators. * + * @param f + * Reference to the allocation function. * @param ud - * will be passed to custom allocator f. If user data isn't required just - * pass NULL. Function pointer f must satisfy requirements of its type. + * User data will be passed to custom allocator f. + * If user data isn't required just pass NULL. + * @returns + * Pointer to the newly created mrb_state. + */ +MRB_API mrb_state* mrb_open_allocf(mrb_allocf f, void *ud); + +/** + * Create new mrb_state with just the MRuby core * + * @param f + * Reference to the allocation function. + * Use mrb_default_allocf for the default + * @param ud + * User data will be passed to custom allocator f. + * If user data isn't required just pass NULL. * @returns * Pointer to the newly created mrb_state. */ -MRB_API mrb_state* mrb_open_allocf(mrb_allocf, void *ud); -MRB_API mrb_state* mrb_open_core(mrb_allocf, void *ud); +MRB_API mrb_state* mrb_open_core(mrb_allocf f, void *ud); /** * Closes and frees a mrb_state. @@ -486,6 +509,11 @@ MRB_API mrb_state* mrb_open_core(mrb_allocf, void *ud); */ MRB_API void mrb_close(mrb_state *mrb); +/** + * The default allocation function. + * + * @ref mrb_allocf + */ MRB_API void* mrb_default_allocf(mrb_state*, void*, size_t, void*); MRB_API mrb_value mrb_top_self(mrb_state *); diff --git a/include/mruby/common.h b/include/mruby/common.h index 0a7cd2f1e..01e558291 100644 --- a/include/mruby/common.h +++ b/include/mruby/common.h @@ -7,29 +7,62 @@ #ifndef MRUBY_COMMON_H #define MRUBY_COMMON_H +/** + * @file mruby/common.h + * @defgroup mruby_common Shared compiler macros + * @ingroup mruby + * @{ + */ + #ifdef __cplusplus -/** Start declarations in C++ mode */ -#define MRB_BEGIN_DECL extern "C" { -/** End declarations in C++ mode */ -#define MRB_END_DECL } +# define MRB_BEGIN_DECL extern "C" { +# define MRB_END_DECL } #else /** Start declarations in C mode */ -#define MRB_BEGIN_DECL /* empty */ +# define MRB_BEGIN_DECL /** End declarations in C mode */ -#define MRB_END_DECL /* empty */ +# define MRB_END_DECL +#endif + +/** Declare a function that never returns. */ +#if __STDC_VERSION__ >= 201112L +# define mrb_noreturn _Noreturn +#elif defined __GNUC__ && !defined __STRICT_ANSI__ +# define mrb_noreturn __attribute__((noreturn)) +#elif defined _MSC_VER +# define mrb_noreturn __declspec(noreturn) +#else +# define mrb_noreturn +#endif + +/** Mark a function as deprecated. */ +#if defined __GNUC__ && !defined __STRICT_ANSI__ +# define mrb_deprecated __attribute__((deprecated)) +#elif defined _MSC_VER +# define mrb_deprecated __declspec(deprecated) +#else +# define mrb_deprecated +#endif + +/** Declare a function as always inlined. */ +#if defined(_MSC_VER) +# define MRB_INLINE static __inline +#else +# define MRB_INLINE static inline #endif +/** Declare a public MRuby API function. */ #if defined(MRB_BUILD_AS_DLL) #if defined(MRB_CORE) || defined(MRB_LIB) -#define MRB_API __declspec(dllexport) +# define MRB_API __declspec(dllexport) #else -#define MRB_API __declspec(dllimport) +# define MRB_API __declspec(dllimport) #endif #else -#define MRB_API extern +# define MRB_API extern #endif -MRB_END_DECL +/** @} */ #endif /* MRUBY_COMMON_H */ |
