~ubuntu-branches/ubuntu/intrepid/ruby1.9/intrepid-updates

« back to all changes in this revision

Viewing changes to include/ruby/intern.h

  • Committer: Bazaar Package Importer
  • Author(s): Matthias Klose
  • Date: 2007-09-04 16:01:17 UTC
  • mfrom: (1.1.8 upstream)
  • Revision ID: james.westby@ubuntu.com-20070904160117-i15zckg2nhxe9fyw
Tags: 1.9.0+20070830-2ubuntu1
* Sync from Debian; remaining changes:
  - Add -g to CFLAGS.
* Fixes build failure on ia64.
* Fixes build failure with gcc-4.2 on lpia.
* Robustify check for target_os, fixing build failure on lpia.
* Set Ubuntu maintainer address.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/**********************************************************************
 
2
 
 
3
  intern.h -
 
4
 
 
5
  $Author: akr $
 
6
  $Date: 2007-08-30 08:12:21 +0900 (木, 30  8月 2007) $
 
7
  created at: Thu Jun 10 14:22:17 JST 1993
 
8
 
 
9
  Copyright (C) 1993-2007 Yukihiro Matsumoto
 
10
  Copyright (C) 2000  Network Applied Communication Laboratory, Inc.
 
11
  Copyright (C) 2000  Information-technology Promotion Agency, Japan
 
12
 
 
13
**********************************************************************/
 
14
 
 
15
#ifndef RUBY_INTERN_H
 
16
#define RUBY_INTERN_H 1
 
17
 
 
18
#if defined(__cplusplus)
 
19
extern "C" {
 
20
#if 0
 
21
} /* satisfy cc-mode */
 
22
#endif
 
23
#endif
 
24
 
 
25
#ifdef HAVE_STDARG_PROTOTYPES
 
26
# include <stdarg.h>
 
27
#else
 
28
# include <varargs.h>
 
29
#endif
 
30
#include <ruby/st.h>
 
31
 
 
32
/* 
 
33
 * Functions and variables that are used by more than one source file of
 
34
 * the kernel.
 
35
 */
 
36
 
 
37
#define ID_ALLOCATOR 1
 
38
 
 
39
/* array.c */
 
40
void rb_mem_clear(register VALUE*, register long);
 
41
VALUE rb_assoc_new(VALUE, VALUE);
 
42
VALUE rb_check_array_type(VALUE);
 
43
VALUE rb_ary_new(void);
 
44
VALUE rb_ary_new2(long);
 
45
VALUE rb_ary_new3(long,...);
 
46
VALUE rb_ary_new4(long, const VALUE *);
 
47
void rb_ary_free(VALUE);
 
48
VALUE rb_ary_freeze(VALUE);
 
49
VALUE rb_ary_aref(int, VALUE*, VALUE);
 
50
void rb_ary_store(VALUE, long, VALUE);
 
51
VALUE rb_ary_dup(VALUE);
 
52
VALUE rb_ary_to_ary(VALUE);
 
53
VALUE rb_ary_to_s(VALUE);
 
54
VALUE rb_ary_push(VALUE, VALUE);
 
55
VALUE rb_ary_pop(VALUE);
 
56
VALUE rb_ary_shift(VALUE);
 
57
VALUE rb_ary_unshift(VALUE, VALUE);
 
58
VALUE rb_ary_entry(VALUE, long);
 
59
VALUE rb_ary_each(VALUE);
 
60
VALUE rb_ary_join(VALUE, VALUE);
 
61
VALUE rb_ary_print_on(VALUE, VALUE);
 
62
VALUE rb_ary_reverse(VALUE);
 
63
VALUE rb_ary_sort(VALUE);
 
64
VALUE rb_ary_sort_bang(VALUE);
 
65
VALUE rb_ary_delete(VALUE, VALUE);
 
66
VALUE rb_ary_delete_at(VALUE, long);
 
67
VALUE rb_ary_clear(VALUE);
 
68
VALUE rb_ary_plus(VALUE, VALUE);
 
69
VALUE rb_ary_concat(VALUE, VALUE);
 
70
VALUE rb_ary_assoc(VALUE, VALUE);
 
71
VALUE rb_ary_rassoc(VALUE, VALUE);
 
72
VALUE rb_ary_includes(VALUE, VALUE);
 
73
VALUE rb_ary_cmp(VALUE, VALUE);
 
74
VALUE rb_ary_replace(VALUE copy, VALUE orig);
 
75
VALUE rb_get_values_at(VALUE, long, int, VALUE*, VALUE(*)(VALUE,long));
 
76
/* bignum.c */
 
77
VALUE rb_big_clone(VALUE);
 
78
void rb_big_2comp(VALUE);
 
79
VALUE rb_big_norm(VALUE);
 
80
VALUE rb_uint2big(VALUE);
 
81
VALUE rb_int2big(SIGNED_VALUE);
 
82
VALUE rb_uint2inum(VALUE);
 
83
VALUE rb_int2inum(SIGNED_VALUE);
 
84
VALUE rb_cstr_to_inum(const char*, int, int);
 
85
VALUE rb_str_to_inum(VALUE, int, int);
 
86
VALUE rb_cstr2inum(const char*, int);
 
87
VALUE rb_str2inum(VALUE, int);
 
88
VALUE rb_big2str(VALUE, int);
 
89
VALUE rb_big2str0(VALUE, int, int);
 
90
SIGNED_VALUE rb_big2long(VALUE);
 
91
#define rb_big2int(x) rb_big2long(x)
 
92
VALUE rb_big2ulong(VALUE);
 
93
#define rb_big2uint(x) rb_big2ulong(x)
 
94
#if HAVE_LONG_LONG
 
95
VALUE rb_ll2inum(LONG_LONG);
 
96
VALUE rb_ull2inum(unsigned LONG_LONG);
 
97
LONG_LONG rb_big2ll(VALUE);
 
98
unsigned LONG_LONG rb_big2ull(VALUE);
 
99
#endif  /* HAVE_LONG_LONG */
 
100
void rb_quad_pack(char*,VALUE);
 
101
VALUE rb_quad_unpack(const char*,int);
 
102
VALUE rb_dbl2big(double);
 
103
double rb_big2dbl(VALUE);
 
104
VALUE rb_big_cmp(VALUE, VALUE);
 
105
VALUE rb_big_eq(VALUE, VALUE);
 
106
VALUE rb_big_plus(VALUE, VALUE);
 
107
VALUE rb_big_minus(VALUE, VALUE);
 
108
VALUE rb_big_mul(VALUE, VALUE);
 
109
VALUE rb_big_div(VALUE, VALUE);
 
110
VALUE rb_big_modulo(VALUE, VALUE);
 
111
VALUE rb_big_divmod(VALUE, VALUE);
 
112
VALUE rb_big_pow(VALUE, VALUE);
 
113
VALUE rb_big_and(VALUE, VALUE);
 
114
VALUE rb_big_or(VALUE, VALUE);
 
115
VALUE rb_big_xor(VALUE, VALUE);
 
116
VALUE rb_big_lshift(VALUE, VALUE);
 
117
VALUE rb_big_rshift(VALUE, VALUE);
 
118
/* class.c */
 
119
VALUE rb_class_boot(VALUE);
 
120
VALUE rb_class_new(VALUE);
 
121
VALUE rb_mod_init_copy(VALUE, VALUE);
 
122
VALUE rb_class_init_copy(VALUE, VALUE);
 
123
VALUE rb_singleton_class_clone(VALUE);
 
124
void rb_singleton_class_attached(VALUE,VALUE);
 
125
VALUE rb_make_metaclass(VALUE, VALUE);
 
126
void rb_check_inheritable(VALUE);
 
127
VALUE rb_class_inherited(VALUE, VALUE);
 
128
VALUE rb_define_class_id(ID, VALUE);
 
129
VALUE rb_module_new(void);
 
130
VALUE rb_define_module_id(ID);
 
131
VALUE rb_mod_included_modules(VALUE);
 
132
VALUE rb_mod_include_p(VALUE, VALUE);
 
133
VALUE rb_mod_ancestors(VALUE);
 
134
VALUE rb_class_instance_methods(int, VALUE*, VALUE);
 
135
VALUE rb_class_public_instance_methods(int, VALUE*, VALUE);
 
136
VALUE rb_class_protected_instance_methods(int, VALUE*, VALUE);
 
137
VALUE rb_class_private_instance_methods(int, VALUE*, VALUE);
 
138
VALUE rb_class_local_methods(VALUE);
 
139
VALUE rb_obj_singleton_methods(int, VALUE*, VALUE);
 
140
void rb_define_method_id(VALUE, ID, VALUE (*)(ANYARGS), int);
 
141
void rb_frozen_class_p(VALUE);
 
142
void rb_undef(VALUE, ID);
 
143
void rb_define_protected_method(VALUE, const char*, VALUE (*)(ANYARGS), int);
 
144
void rb_define_private_method(VALUE, const char*, VALUE (*)(ANYARGS), int);
 
145
void rb_define_singleton_method(VALUE, const char*, VALUE(*)(ANYARGS), int);
 
146
VALUE rb_singleton_class(VALUE);
 
147
/* compar.c */
 
148
int rb_cmpint(VALUE, VALUE, VALUE);
 
149
NORETURN(void rb_cmperr(VALUE, VALUE));
 
150
/* cont.c */
 
151
VALUE rb_fiber_new(VALUE (*)(ANYARGS), VALUE);
 
152
VALUE rb_fiber_resume(VALUE fib, int argc, VALUE *args);
 
153
VALUE rb_fiber_yield(int argc, VALUE *args);
 
154
VALUE rb_fiber_current(void);
 
155
/* enum.c */
 
156
/* enumerator.c */
 
157
VALUE rb_enumeratorize(VALUE, VALUE, int, VALUE *);
 
158
#define RETURN_ENUMERATOR(obj, argc, argv) do {                         \
 
159
        if (!rb_block_given_p())                                        \
 
160
            return rb_enumeratorize(obj, ID2SYM(rb_frame_this_func()),  \
 
161
                                    argc, argv);                        \
 
162
    } while (0)
 
163
/* error.c */
 
164
VALUE rb_exc_new(VALUE, const char*, long);
 
165
VALUE rb_exc_new2(VALUE, const char*);
 
166
VALUE rb_exc_new3(VALUE, VALUE);
 
167
PRINTF_ARGS(NORETURN(void rb_loaderror(const char*, ...)), 1, 2);
 
168
PRINTF_ARGS(NORETURN(void rb_name_error(ID, const char*, ...)), 2, 3);
 
169
NORETURN(void rb_invalid_str(const char*, const char*));
 
170
PRINTF_ARGS(void rb_compile_error(const char*, int, const char*, ...), 3, 4);
 
171
PRINTF_ARGS(void rb_compile_error_append(const char*, ...), 1, 2);
 
172
NORETURN(void rb_load_fail(const char*));
 
173
NORETURN(void rb_error_frozen(const char*));
 
174
void rb_check_frozen(VALUE);
 
175
/* eval.c */
 
176
int rb_sourceline(void);
 
177
const char *rb_sourcefile(void);
 
178
 
 
179
#if defined(NFDBITS) && defined(HAVE_RB_FD_INIT)
 
180
typedef struct {
 
181
    int maxfd;
 
182
    fd_set *fdset;
 
183
} rb_fdset_t;
 
184
 
 
185
void rb_fd_init(volatile rb_fdset_t *);
 
186
void rb_fd_term(rb_fdset_t *);
 
187
void rb_fd_zero(rb_fdset_t *);
 
188
void rb_fd_set(int, rb_fdset_t *);
 
189
void rb_fd_clr(int, rb_fdset_t *);
 
190
int rb_fd_isset(int, const rb_fdset_t *);
 
191
void rb_fd_copy(rb_fdset_t *, const fd_set *, int);
 
192
int rb_fd_select(int, rb_fdset_t *, rb_fdset_t *, rb_fdset_t *, struct timeval *);
 
193
 
 
194
#define rb_fd_ptr(f)    ((f)->fdset)
 
195
#define rb_fd_max(f)    ((f)->maxfd)
 
196
 
 
197
#else
 
198
 
 
199
typedef fd_set rb_fdset_t;
 
200
#define rb_fd_zero(f)   FD_ZERO(f)
 
201
#define rb_fd_set(n, f) FD_SET(n, f)
 
202
#define rb_fd_clr(n, f) FD_CLR(n, f)
 
203
#define rb_fd_isset(n, f) FD_ISSET(n, f)
 
204
#define rb_fd_copy(d, s, n) (*(d) = *(s))
 
205
#define rb_fd_ptr(f)    (f)
 
206
#define rb_fd_init(f)   FD_ZERO(f)
 
207
#define rb_fd_term(f)   (f)
 
208
#define rb_fd_max(f)    FD_SETSIZE
 
209
#define rb_fd_select(n, rfds, wfds, efds, timeout)      select(n, rfds, wfds, efds, timeout)
 
210
 
 
211
#endif
 
212
 
 
213
NORETURN(void rb_exc_raise(VALUE));
 
214
NORETURN(void rb_exc_fatal(VALUE));
 
215
VALUE rb_f_exit(int,VALUE*);
 
216
VALUE rb_f_abort(int,VALUE*);
 
217
void rb_remove_method(VALUE, const char*);
 
218
#define rb_disable_super(klass, name) ((void)0)
 
219
#define rb_enable_super(klass, name) ((void)0)
 
220
#define HAVE_RB_DEFINE_ALLOC_FUNC 1
 
221
void rb_define_alloc_func(VALUE, VALUE (*)(VALUE));
 
222
void rb_undef_alloc_func(VALUE);
 
223
void rb_clear_cache(void);
 
224
void rb_clear_cache_by_class(VALUE);
 
225
void rb_alias(VALUE, ID, ID);
 
226
void rb_attr(VALUE,ID,int,int,int);
 
227
int rb_method_boundp(VALUE, ID, int);
 
228
VALUE rb_eval_cmd(VALUE, VALUE, int);
 
229
int rb_obj_respond_to(VALUE, ID, int);
 
230
int rb_respond_to(VALUE, ID);
 
231
void rb_interrupt(void);
 
232
VALUE rb_apply(VALUE, ID, VALUE);
 
233
void rb_backtrace(void);
 
234
ID rb_frame_this_func(void);
 
235
VALUE rb_obj_instance_eval(int, VALUE*, VALUE);
 
236
VALUE rb_mod_module_eval(int, VALUE*, VALUE);
 
237
void rb_load(VALUE, int);
 
238
void rb_load_protect(VALUE, int, int*);
 
239
NORETURN(void rb_jump_tag(int));
 
240
int rb_provided(const char*);
 
241
void rb_provide(const char*);
 
242
VALUE rb_f_require(VALUE, VALUE);
 
243
VALUE rb_require_safe(VALUE, int);
 
244
void rb_obj_call_init(VALUE, int, VALUE*);
 
245
VALUE rb_class_new_instance(int, VALUE*, VALUE);
 
246
VALUE rb_block_proc(void);
 
247
VALUE rb_f_lambda(void);
 
248
VALUE rb_proc_new(VALUE (*)(ANYARGS/* VALUE yieldarg[, VALUE procarg] */), VALUE);
 
249
VALUE rb_proc_call(VALUE, VALUE);
 
250
int rb_proc_arity(VALUE);
 
251
VALUE rb_binding_new(void);
 
252
VALUE rb_obj_method(VALUE, VALUE);
 
253
VALUE rb_method_call(int, VALUE*, VALUE);
 
254
int rb_mod_method_arity(VALUE, ID);
 
255
int rb_obj_method_arity(VALUE, ID);
 
256
VALUE rb_protect(VALUE (*)(VALUE), VALUE, int*);
 
257
void rb_set_end_proc(void (*)(VALUE), VALUE);
 
258
void rb_mark_end_proc(void);
 
259
void rb_exec_end_proc(void);
 
260
void Init_jump(void);
 
261
void ruby_finalize(void);
 
262
NORETURN(void ruby_stop(int));
 
263
int ruby_cleanup(int);
 
264
void rb_gc_mark_threads(void);
 
265
void rb_thread_schedule(void);
 
266
void rb_thread_wait_fd(int);
 
267
int rb_thread_fd_writable(int);
 
268
void rb_thread_fd_close(int);
 
269
int rb_thread_alone(void);
 
270
void rb_thread_polling(void);
 
271
void rb_thread_sleep(int);
 
272
void rb_thread_sleep_forever(void);
 
273
VALUE rb_thread_stop(void);
 
274
VALUE rb_thread_wakeup(VALUE);
 
275
VALUE rb_thread_run(VALUE);
 
276
VALUE rb_thread_kill(VALUE);
 
277
VALUE rb_thread_create(VALUE (*)(ANYARGS), void*);
 
278
void rb_thread_signal_raise(void *, int);
 
279
void rb_thread_signal_exit(void *);
 
280
int rb_thread_select(int, fd_set *, fd_set *, fd_set *, struct timeval *);
 
281
void rb_thread_wait_for(struct timeval);
 
282
VALUE rb_thread_current(void);
 
283
VALUE rb_thread_main(void);
 
284
VALUE rb_thread_local_aref(VALUE, ID);
 
285
VALUE rb_thread_local_aset(VALUE, ID, VALUE);
 
286
void rb_thread_atfork(void);
 
287
VALUE rb_exec_recursive(VALUE(*)(VALUE, VALUE, int),VALUE,VALUE);
 
288
/* file.c */
 
289
VALUE rb_file_s_expand_path(int, VALUE *);
 
290
VALUE rb_file_expand_path(VALUE, VALUE);
 
291
void rb_file_const(const char*, VALUE);
 
292
int rb_find_file_ext(VALUE*, const char* const*);
 
293
VALUE rb_find_file(VALUE);
 
294
char *rb_path_next(const char *);
 
295
char *rb_path_skip_prefix(const char *);
 
296
char *rb_path_last_separator(const char *);
 
297
char *rb_path_end(const char *);
 
298
VALUE rb_file_directory_p(VALUE,VALUE);
 
299
/* gc.c */
 
300
void ruby_set_stack_size(size_t);
 
301
NORETURN(void rb_memerror(void));
 
302
int ruby_stack_check(void);
 
303
int ruby_stack_length(VALUE**);
 
304
char *rb_source_filename(const char*);
 
305
void rb_gc_mark_locations(VALUE*, VALUE*);
 
306
void rb_mark_tbl(struct st_table*);
 
307
void rb_mark_hash(struct st_table*);
 
308
void rb_gc_mark_maybe(VALUE);
 
309
void rb_gc_mark(VALUE);
 
310
void rb_gc_force_recycle(VALUE);
 
311
void rb_gc(void);
 
312
void rb_gc_copy_finalizer(VALUE,VALUE);
 
313
void rb_gc_finalize_deferred(void);
 
314
void rb_gc_call_finalizer_at_exit(void);
 
315
VALUE rb_gc_enable(void);
 
316
VALUE rb_gc_disable(void);
 
317
VALUE rb_gc_start(void);
 
318
/* hash.c */
 
319
void st_foreach_safe(struct st_table *, int (*)(ANYARGS), st_data_t);
 
320
void rb_hash_foreach(VALUE, int (*)(ANYARGS), VALUE);
 
321
VALUE rb_hash(VALUE);
 
322
VALUE rb_hash_new(void);
 
323
VALUE rb_hash_freeze(VALUE);
 
324
VALUE rb_hash_aref(VALUE, VALUE);
 
325
VALUE rb_hash_lookup(VALUE, VALUE);
 
326
VALUE rb_hash_aset(VALUE, VALUE, VALUE);
 
327
VALUE rb_hash_delete_if(VALUE);
 
328
VALUE rb_hash_delete(VALUE,VALUE);
 
329
struct st_table *rb_hash_tbl(VALUE);
 
330
int rb_path_check(const char*);
 
331
int rb_env_path_tainted(void);
 
332
/* io.c */
 
333
#define rb_defout rb_stdout
 
334
RUBY_EXTERN VALUE rb_fs;
 
335
RUBY_EXTERN VALUE rb_output_fs;
 
336
RUBY_EXTERN VALUE rb_rs;
 
337
RUBY_EXTERN VALUE rb_default_rs;
 
338
RUBY_EXTERN VALUE rb_output_rs;
 
339
VALUE rb_io_write(VALUE, VALUE);
 
340
VALUE rb_io_gets(VALUE);
 
341
VALUE rb_io_getbyte(VALUE);
 
342
VALUE rb_io_ungetc(VALUE, VALUE);
 
343
VALUE rb_io_close(VALUE);
 
344
VALUE rb_io_flush(VALUE);
 
345
VALUE rb_io_eof(VALUE);
 
346
VALUE rb_io_binmode(VALUE);
 
347
VALUE rb_io_addstr(VALUE, VALUE);
 
348
VALUE rb_io_printf(int, VALUE*, VALUE);
 
349
VALUE rb_io_print(int, VALUE*, VALUE);
 
350
VALUE rb_io_puts(int, VALUE*, VALUE);
 
351
VALUE rb_file_open(const char*, const char*);
 
352
VALUE rb_gets(void);
 
353
void rb_write_error(const char*);
 
354
void rb_write_error2(const char*, long);
 
355
/* marshal.c */
 
356
VALUE rb_marshal_dump(VALUE, VALUE);
 
357
VALUE rb_marshal_load(VALUE);
 
358
/* numeric.c */
 
359
void rb_num_zerodiv(void);
 
360
VALUE rb_num_coerce_bin(VALUE, VALUE);
 
361
VALUE rb_num_coerce_cmp(VALUE, VALUE);
 
362
VALUE rb_num_coerce_relop(VALUE, VALUE);
 
363
VALUE rb_float_new(double);
 
364
VALUE rb_num2fix(VALUE);
 
365
VALUE rb_fix2str(VALUE, int);
 
366
VALUE rb_dbl_cmp(double, double);
 
367
/* object.c */
 
368
int rb_eql(VALUE, VALUE);
 
369
VALUE rb_any_to_s(VALUE);
 
370
VALUE rb_inspect(VALUE);
 
371
VALUE rb_obj_is_instance_of(VALUE, VALUE);
 
372
VALUE rb_obj_is_kind_of(VALUE, VALUE);
 
373
VALUE rb_obj_alloc(VALUE);
 
374
VALUE rb_obj_clone(VALUE);
 
375
VALUE rb_obj_dup(VALUE);
 
376
VALUE rb_obj_init_copy(VALUE,VALUE);
 
377
VALUE rb_obj_taint(VALUE);
 
378
VALUE rb_obj_tainted(VALUE);
 
379
VALUE rb_obj_untaint(VALUE);
 
380
VALUE rb_obj_freeze(VALUE);
 
381
VALUE rb_obj_id(VALUE);
 
382
VALUE rb_obj_class(VALUE);
 
383
VALUE rb_class_real(VALUE);
 
384
VALUE rb_class_inherited_p(VALUE, VALUE);
 
385
VALUE rb_convert_type(VALUE,int,const char*,const char*);
 
386
VALUE rb_check_convert_type(VALUE,int,const char*,const char*);
 
387
VALUE rb_check_to_integer(VALUE, const char *);
 
388
VALUE rb_to_int(VALUE);
 
389
VALUE rb_Integer(VALUE);
 
390
VALUE rb_Float(VALUE);
 
391
VALUE rb_String(VALUE);
 
392
VALUE rb_Array(VALUE);
 
393
double rb_cstr_to_dbl(const char*, int);
 
394
double rb_str_to_dbl(VALUE, int);
 
395
/* parse.y */
 
396
RUBY_EXTERN int   ruby_sourceline;
 
397
RUBY_EXTERN char *ruby_sourcefile;
 
398
ID rb_id_attrset(ID);
 
399
void rb_gc_mark_parser(void);
 
400
int rb_is_const_id(ID);
 
401
int rb_is_instance_id(ID);
 
402
int rb_is_class_id(ID);
 
403
int rb_is_local_id(ID);
 
404
int rb_is_junk_id(ID);
 
405
int rb_symname_p(const char*);
 
406
int rb_sym_interned_p(VALUE);
 
407
void rb_gc_mark_symbols(void);
 
408
VALUE rb_backref_get(void);
 
409
void rb_backref_set(VALUE);
 
410
VALUE rb_lastline_get(void);
 
411
void rb_lastline_set(VALUE);
 
412
VALUE rb_sym_all_symbols(void);
 
413
/* process.c */
 
414
void rb_last_status_set(int status, rb_pid_t pid);
 
415
VALUE rb_last_status_get(void);
 
416
struct rb_exec_arg {
 
417
    int argc;
 
418
    VALUE *argv;
 
419
    const char *prog;
 
420
};
 
421
int rb_proc_exec_n(int, VALUE*, const char*);
 
422
int rb_proc_exec(const char*);
 
423
VALUE rb_check_argv(int, VALUE*);
 
424
int rb_exec(const struct rb_exec_arg*);
 
425
rb_pid_t rb_fork(int*, int (*)(void*), void*);
 
426
VALUE rb_f_exec(int,VALUE*);
 
427
rb_pid_t rb_waitpid(rb_pid_t pid, int *status, int flags);
 
428
void rb_syswait(rb_pid_t pid);
 
429
rb_pid_t rb_spawn(int, VALUE*);
 
430
VALUE rb_proc_times(VALUE);
 
431
VALUE rb_detach_process(rb_pid_t pid);
 
432
/* range.c */
 
433
VALUE rb_range_new(VALUE, VALUE, int);
 
434
VALUE rb_range_beg_len(VALUE, long*, long*, long, int);
 
435
/* random.c */
 
436
unsigned long genrand_int32(void);
 
437
double genrand_real(void);
 
438
/* re.c */
 
439
int rb_memcmp(const void*,const void*,long);
 
440
int rb_memcicmp(const void*,const void*,long);
 
441
long rb_memsearch(const void*,long,const void*,long);
 
442
VALUE rb_reg_nth_defined(int, VALUE);
 
443
VALUE rb_reg_nth_match(int, VALUE);
 
444
VALUE rb_reg_last_match(VALUE);
 
445
VALUE rb_reg_match_pre(VALUE);
 
446
VALUE rb_reg_match_post(VALUE);
 
447
VALUE rb_reg_match_last(VALUE);
 
448
VALUE rb_reg_new(VALUE, int);
 
449
VALUE rb_reg_match(VALUE, VALUE);
 
450
VALUE rb_reg_match2(VALUE);
 
451
int rb_reg_options(VALUE);
 
452
void rb_set_kcode(const char*);
 
453
const char* rb_get_kcode(void);
 
454
/* ruby.c */
 
455
RUBY_EXTERN VALUE rb_argv;
 
456
RUBY_EXTERN VALUE rb_argv0;
 
457
void *rb_load_file(const char*);
 
458
void ruby_script(const char*);
 
459
void ruby_prog_init(void);
 
460
void ruby_set_argv(int, char**);
 
461
void *ruby_process_options(int, char**);
 
462
void ruby_init_loadpath(void);
 
463
void ruby_incpush(const char*);
 
464
/* signal.c */
 
465
VALUE rb_f_kill(int, VALUE*);
 
466
void rb_gc_mark_trap_list(void);
 
467
#ifdef POSIX_SIGNAL
 
468
#define posix_signal ruby_posix_signal
 
469
void posix_signal(int, RETSIGTYPE (*)(int));
 
470
#endif
 
471
void rb_trap_exit(void);
 
472
void rb_trap_exec(void);
 
473
const char *ruby_signal_name(int);
 
474
void ruby_default_signal(int);
 
475
/* sprintf.c */
 
476
VALUE rb_f_sprintf(int, const VALUE*);
 
477
PRINTF_ARGS(VALUE rb_sprintf(const char*, ...), 1, 2);
 
478
VALUE rb_vsprintf(const char*, va_list);
 
479
VALUE rb_str_format(int, const VALUE *, VALUE);
 
480
/* string.c */
 
481
VALUE rb_str_new(const char*, long);
 
482
VALUE rb_str_new2(const char*);
 
483
VALUE rb_str_new3(VALUE);
 
484
VALUE rb_str_new4(VALUE);
 
485
VALUE rb_str_new5(VALUE, const char*, long);
 
486
VALUE rb_tainted_str_new(const char*, long);
 
487
VALUE rb_tainted_str_new2(const char*);
 
488
VALUE rb_str_buf_new(long);
 
489
VALUE rb_str_buf_new2(const char*);
 
490
void rb_str_free(VALUE);
 
491
VALUE rb_str_buf_append(VALUE, VALUE);
 
492
VALUE rb_str_buf_cat(VALUE, const char*, long);
 
493
VALUE rb_str_buf_cat2(VALUE, const char*);
 
494
VALUE rb_obj_as_string(VALUE);
 
495
VALUE rb_check_string_type(VALUE);
 
496
VALUE rb_str_dup(VALUE);
 
497
VALUE rb_str_locktmp(VALUE);
 
498
VALUE rb_str_unlocktmp(VALUE);
 
499
VALUE rb_str_dup_frozen(VALUE);
 
500
VALUE rb_str_plus(VALUE, VALUE);
 
501
VALUE rb_str_times(VALUE, VALUE);
 
502
int rb_str_sublen(VALUE, int);
 
503
VALUE rb_str_substr(VALUE, long, long);
 
504
VALUE rb_str_subseq(VALUE, long, long);
 
505
void rb_str_modify(VALUE);
 
506
VALUE rb_str_freeze(VALUE);
 
507
void rb_str_set_len(VALUE, long);
 
508
VALUE rb_str_resize(VALUE, long);
 
509
VALUE rb_str_cat(VALUE, const char*, long);
 
510
VALUE rb_str_cat2(VALUE, const char*);
 
511
VALUE rb_str_append(VALUE, VALUE);
 
512
VALUE rb_str_concat(VALUE, VALUE);
 
513
int rb_memhash(const void *ptr, long len);
 
514
int rb_str_hash(VALUE);
 
515
int rb_str_cmp(VALUE, VALUE);
 
516
void rb_str_update(VALUE, long, long, VALUE);
 
517
VALUE rb_str_inspect(VALUE);
 
518
VALUE rb_str_dump(VALUE);
 
519
VALUE rb_str_split(VALUE, const char*);
 
520
void rb_str_associate(VALUE, VALUE);
 
521
VALUE rb_str_associated(VALUE);
 
522
void rb_str_setter(VALUE, ID, VALUE*);
 
523
VALUE rb_str_intern(VALUE);
 
524
VALUE rb_sym_to_s(VALUE);
 
525
VALUE rb_str_length(VALUE);
 
526
/* struct.c */
 
527
VALUE rb_struct_new(VALUE, ...);
 
528
VALUE rb_struct_define(const char*, ...);
 
529
VALUE rb_struct_alloc(VALUE, VALUE);
 
530
VALUE rb_struct_aref(VALUE, VALUE);
 
531
VALUE rb_struct_aset(VALUE, VALUE, VALUE);
 
532
VALUE rb_struct_getmember(VALUE, ID);
 
533
VALUE rb_struct_iv_get(VALUE, const char*);
 
534
VALUE rb_struct_s_members(VALUE);
 
535
VALUE rb_struct_members(VALUE);
 
536
/* thread.c */
 
537
typedef struct rb_thread_struct rb_thread_t;
 
538
typedef void rb_unblock_function_t(rb_thread_t *, void *);
 
539
typedef VALUE rb_blocking_function_t(rb_thread_t *th, void *);
 
540
VALUE rb_thread_blocking_region(rb_blocking_function_t *func, void *data1,
 
541
                                rb_unblock_function_t *ubf, void *data2);
 
542
#define RB_UBF_DFL ((rb_unblock_function_t *)-1)
 
543
VALUE rb_mutex_new(void);
 
544
VALUE rb_mutex_locked_p(VALUE mutex);
 
545
VALUE rb_mutex_try_lock(VALUE mutex);
 
546
VALUE rb_mutex_lock(VALUE mutex);
 
547
VALUE rb_mutex_unlock(VALUE mutex);
 
548
VALUE rb_mutex_sleep(VALUE self, VALUE timeout);
 
549
VALUE rb_mutex_synchronize(VALUE self);
 
550
VALUE rb_barrier_new(void);
 
551
VALUE rb_barrier_wait(VALUE self);
 
552
VALUE rb_barrier_release(VALUE self);
 
553
/* time.c */
 
554
VALUE rb_time_new(time_t, time_t);
 
555
/* variable.c */
 
556
VALUE rb_mod_name(VALUE);
 
557
VALUE rb_class_path(VALUE);
 
558
void rb_set_class_path(VALUE, VALUE, const char*);
 
559
VALUE rb_path2class(const char*);
 
560
void rb_name_class(VALUE, ID);
 
561
VALUE rb_class_name(VALUE);
 
562
void rb_autoload(VALUE, ID, const char*);
 
563
VALUE rb_autoload_load(VALUE, ID);
 
564
VALUE rb_autoload_p(VALUE, ID);
 
565
void rb_gc_mark_global_tbl(void);
 
566
VALUE rb_f_trace_var(int, VALUE*);
 
567
VALUE rb_f_untrace_var(int, VALUE*);
 
568
VALUE rb_f_global_variables(void);
 
569
void rb_alias_variable(ID, ID);
 
570
struct st_table* rb_generic_ivar_table(VALUE);
 
571
void rb_copy_generic_ivar(VALUE,VALUE);
 
572
void rb_mark_generic_ivar(VALUE);
 
573
void rb_mark_generic_ivar_tbl(void);
 
574
void rb_free_generic_ivar(VALUE);
 
575
VALUE rb_ivar_get(VALUE, ID);
 
576
VALUE rb_ivar_set(VALUE, ID, VALUE);
 
577
VALUE rb_ivar_defined(VALUE, ID);
 
578
VALUE rb_iv_set(VALUE, const char*, VALUE);
 
579
VALUE rb_iv_get(VALUE, const char*);
 
580
VALUE rb_attr_get(VALUE, ID);
 
581
VALUE rb_obj_instance_variables(VALUE);
 
582
VALUE rb_obj_remove_instance_variable(VALUE, VALUE);
 
583
void *rb_mod_const_at(VALUE, void*);
 
584
void *rb_mod_const_of(VALUE, void*);
 
585
VALUE rb_const_list(void*);
 
586
VALUE rb_mod_constants(int, VALUE *, VALUE);
 
587
VALUE rb_mod_remove_const(VALUE, VALUE);
 
588
int rb_const_defined(VALUE, ID);
 
589
int rb_const_defined_at(VALUE, ID);
 
590
int rb_const_defined_from(VALUE, ID);
 
591
VALUE rb_const_get(VALUE, ID);
 
592
VALUE rb_const_get_at(VALUE, ID);
 
593
VALUE rb_const_get_from(VALUE, ID);
 
594
void rb_const_set(VALUE, ID, VALUE);
 
595
VALUE rb_mod_const_missing(VALUE,VALUE);
 
596
VALUE rb_cvar_defined(VALUE, ID);
 
597
void rb_cvar_set(VALUE, ID, VALUE);
 
598
VALUE rb_cvar_get(VALUE, ID);
 
599
void rb_cv_set(VALUE, const char*, VALUE);
 
600
VALUE rb_cv_get(VALUE, const char*);
 
601
void rb_define_class_variable(VALUE, const char*, VALUE);
 
602
VALUE rb_mod_class_variables(VALUE);
 
603
VALUE rb_mod_remove_cvar(VALUE, VALUE);
 
604
/* version.c */
 
605
void ruby_show_version(void);
 
606
void ruby_show_copyright(void);
 
607
 
 
608
ID rb_frame_callee(void);
 
609
VALUE rb_str_succ(VALUE);
 
610
VALUE rb_time_succ(VALUE);
 
611
void Init_stack(VALUE*);
 
612
void rb_frame_pop(void);
 
613
 
 
614
#if defined(__cplusplus)
 
615
#if 0
 
616
{ /* satisfy cc-mode */
 
617
#endif
 
618
}  /* extern "C" { */
 
619
#endif
 
620
 
 
621
#endif /* RUBY_INTERN_H */