better_caller 0.0.1 → 0.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/.document +5 -0
- data/Gemfile +11 -0
- data/Gemfile.lock +20 -0
- data/{LICENSE → LICENSE.txt} +1 -1
- data/README.textile +71 -0
- data/Rakefile +36 -0
- data/VERSION +1 -0
- data/better_caller.gemspec +94 -0
- data/ext/better_caller.c +3 -44
- data/ext/debug.h +1 -1
- data/ext/dln.h +3 -3
- data/ext/encdb.h +18 -2
- data/ext/eval_intern.h +23 -6
- data/ext/extconf.rb +1 -0
- data/ext/gc.h +6 -4
- data/ext/id.h +25 -18
- data/ext/iseq.h +10 -9
- data/ext/method.h +103 -0
- data/ext/node.h +14 -47
- data/ext/parse.h +12 -14
- data/ext/regenc.h +7 -3
- data/ext/regint.h +16 -17
- data/ext/regparse.h +4 -1
- data/ext/revision.h +1 -1
- data/ext/thread_pthread.h +4 -1
- data/ext/thread_win32.h +1 -1
- data/ext/timev.h +21 -0
- data/ext/transcode_data.h +17 -14
- data/ext/transdb.h +32 -0
- data/ext/version.h +17 -17
- data/ext/vm_core.h +105 -45
- data/ext/vm_insnhelper.h +26 -14
- data/ext/vm_opts.h +1 -1
- data/lib/better_caller/extensions.rb +14 -0
- metadata +103 -53
- data/README.rdoc +0 -69
- data/spec/better_caller_spec.rb +0 -7
- data/spec/spec_helper.rb +0 -8
data/ext/method.h
ADDED
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
/**********************************************************************
|
|
2
|
+
|
|
3
|
+
method.h -
|
|
4
|
+
|
|
5
|
+
$Author: ko1 $
|
|
6
|
+
created at: Wed Jul 15 20:02:33 2009
|
|
7
|
+
|
|
8
|
+
Copyright (C) 2009 Koichi Sasada
|
|
9
|
+
|
|
10
|
+
**********************************************************************/
|
|
11
|
+
#ifndef METHOD_H
|
|
12
|
+
#define METHOD_H
|
|
13
|
+
|
|
14
|
+
typedef enum {
|
|
15
|
+
NOEX_PUBLIC = 0x00,
|
|
16
|
+
NOEX_NOSUPER = 0x01,
|
|
17
|
+
NOEX_PRIVATE = 0x02,
|
|
18
|
+
NOEX_PROTECTED = 0x04,
|
|
19
|
+
NOEX_MASK = 0x06,
|
|
20
|
+
NOEX_BASIC = 0x08,
|
|
21
|
+
NOEX_UNDEF = NOEX_NOSUPER,
|
|
22
|
+
NOEX_MODFUNC = 0x12,
|
|
23
|
+
NOEX_SUPER = 0x20,
|
|
24
|
+
NOEX_VCALL = 0x40,
|
|
25
|
+
NOEX_RESPONDS = 0x80
|
|
26
|
+
} rb_method_flag_t;
|
|
27
|
+
|
|
28
|
+
#define NOEX_SAFE(n) ((int)((n) >> 8) & 0x0F)
|
|
29
|
+
#define NOEX_WITH(n, s) ((s << 8) | (n) | (ruby_running ? 0 : NOEX_BASIC))
|
|
30
|
+
#define NOEX_WITH_SAFE(n) NOEX_WITH(n, rb_safe_level())
|
|
31
|
+
|
|
32
|
+
/* method data type */
|
|
33
|
+
|
|
34
|
+
typedef enum {
|
|
35
|
+
VM_METHOD_TYPE_ISEQ,
|
|
36
|
+
VM_METHOD_TYPE_CFUNC,
|
|
37
|
+
VM_METHOD_TYPE_ATTRSET,
|
|
38
|
+
VM_METHOD_TYPE_IVAR,
|
|
39
|
+
VM_METHOD_TYPE_BMETHOD,
|
|
40
|
+
VM_METHOD_TYPE_ZSUPER,
|
|
41
|
+
VM_METHOD_TYPE_UNDEF,
|
|
42
|
+
VM_METHOD_TYPE_NOTIMPLEMENTED,
|
|
43
|
+
VM_METHOD_TYPE_OPTIMIZED, /* Kernel#send, Proc#call, etc */
|
|
44
|
+
VM_METHOD_TYPE_MISSING /* wrapper for method_missing(id) */
|
|
45
|
+
} rb_method_type_t;
|
|
46
|
+
|
|
47
|
+
typedef struct rb_method_cfunc_struct {
|
|
48
|
+
VALUE (*func)(ANYARGS);
|
|
49
|
+
int argc;
|
|
50
|
+
} rb_method_cfunc_t;
|
|
51
|
+
|
|
52
|
+
typedef struct rb_method_attr_struct {
|
|
53
|
+
ID id;
|
|
54
|
+
VALUE location;
|
|
55
|
+
} rb_method_attr_t;
|
|
56
|
+
|
|
57
|
+
typedef struct rb_iseq_struct rb_iseq_t;
|
|
58
|
+
|
|
59
|
+
typedef struct rb_method_definition_struct {
|
|
60
|
+
rb_method_type_t type; /* method type */
|
|
61
|
+
ID original_id;
|
|
62
|
+
union {
|
|
63
|
+
rb_iseq_t *iseq; /* should be mark */
|
|
64
|
+
rb_method_cfunc_t cfunc;
|
|
65
|
+
rb_method_attr_t attr;
|
|
66
|
+
VALUE proc; /* should be mark */
|
|
67
|
+
enum method_optimized_type {
|
|
68
|
+
OPTIMIZED_METHOD_TYPE_SEND,
|
|
69
|
+
OPTIMIZED_METHOD_TYPE_CALL
|
|
70
|
+
} optimize_type;
|
|
71
|
+
} body;
|
|
72
|
+
int alias_count;
|
|
73
|
+
} rb_method_definition_t;
|
|
74
|
+
|
|
75
|
+
typedef struct rb_method_entry_struct {
|
|
76
|
+
rb_method_flag_t flag;
|
|
77
|
+
char mark;
|
|
78
|
+
rb_method_definition_t *def;
|
|
79
|
+
ID called_id;
|
|
80
|
+
VALUE klass; /* should be mark */
|
|
81
|
+
} rb_method_entry_t;
|
|
82
|
+
|
|
83
|
+
struct unlinked_method_entry_list_entry {
|
|
84
|
+
struct unlinked_method_entry_list_entry *next;
|
|
85
|
+
rb_method_entry_t *me;
|
|
86
|
+
};
|
|
87
|
+
|
|
88
|
+
#define UNDEFINED_METHOD_ENTRY_P(me) (!(me) || !(me)->def || (me)->def->type == VM_METHOD_TYPE_UNDEF)
|
|
89
|
+
|
|
90
|
+
void rb_add_method_cfunc(VALUE klass, ID mid, VALUE (*func)(ANYARGS), int argc, rb_method_flag_t noex);
|
|
91
|
+
rb_method_entry_t *rb_add_method(VALUE klass, ID mid, rb_method_type_t type, void *option, rb_method_flag_t noex);
|
|
92
|
+
rb_method_entry_t *rb_method_entry(VALUE klass, ID id);
|
|
93
|
+
|
|
94
|
+
rb_method_entry_t *rb_method_entry_get_without_cache(VALUE klass, ID id);
|
|
95
|
+
rb_method_entry_t *rb_method_entry_set(VALUE klass, ID mid, const rb_method_entry_t *, rb_method_flag_t noex);
|
|
96
|
+
|
|
97
|
+
int rb_method_entry_arity(const rb_method_entry_t *me);
|
|
98
|
+
|
|
99
|
+
void rb_mark_method_entry(const rb_method_entry_t *me);
|
|
100
|
+
void rb_free_method_entry(rb_method_entry_t *me);
|
|
101
|
+
void rb_sweep_method_entry(void *vm);
|
|
102
|
+
|
|
103
|
+
#endif /* METHOD_H */
|
data/ext/node.h
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
node.h -
|
|
4
4
|
|
|
5
|
-
$Author:
|
|
5
|
+
$Author: muraken $
|
|
6
6
|
created at: Fri May 28 15:14:02 JST 1993
|
|
7
7
|
|
|
8
8
|
Copyright (C) 1993-2007 Yukihiro Matsumoto
|
|
@@ -20,12 +20,6 @@ extern "C" {
|
|
|
20
20
|
#endif
|
|
21
21
|
|
|
22
22
|
enum node_type {
|
|
23
|
-
NODE_METHOD,
|
|
24
|
-
#define NODE_METHOD NODE_METHOD
|
|
25
|
-
NODE_FBODY,
|
|
26
|
-
#define NODE_FBODY NODE_FBODY
|
|
27
|
-
NODE_CFUNC,
|
|
28
|
-
#define NODE_CFUNC NODE_CFUNC
|
|
29
23
|
NODE_SCOPE,
|
|
30
24
|
#define NODE_SCOPE NODE_SCOPE
|
|
31
25
|
NODE_BLOCK,
|
|
@@ -202,8 +196,6 @@ enum node_type {
|
|
|
202
196
|
#define NODE_FLIP2 NODE_FLIP2
|
|
203
197
|
NODE_FLIP3,
|
|
204
198
|
#define NODE_FLIP3 NODE_FLIP3
|
|
205
|
-
NODE_ATTRSET,
|
|
206
|
-
#define NODE_ATTRSET NODE_ATTRSET
|
|
207
199
|
NODE_SELF,
|
|
208
200
|
#define NODE_SELF NODE_SELF
|
|
209
201
|
NODE_NIL,
|
|
@@ -260,7 +252,7 @@ typedef struct RNode {
|
|
|
260
252
|
struct RNode *node;
|
|
261
253
|
ID id;
|
|
262
254
|
long state;
|
|
263
|
-
struct
|
|
255
|
+
struct rb_global_entry *entry;
|
|
264
256
|
long cnt;
|
|
265
257
|
VALUE value;
|
|
266
258
|
} u3;
|
|
@@ -270,17 +262,18 @@ typedef struct RNode {
|
|
|
270
262
|
|
|
271
263
|
/* 0..4:T_TYPES, 5:FL_MARK, 6:reserved, 7:NODE_FL_NEWLINE */
|
|
272
264
|
#define NODE_FL_NEWLINE (((VALUE)1)<<7)
|
|
265
|
+
#define NODE_FL_CREF_PUSHED_BY_EVAL NODE_FL_NEWLINE
|
|
273
266
|
|
|
274
267
|
#define NODE_TYPESHIFT 8
|
|
275
268
|
#define NODE_TYPEMASK (((VALUE)0x7f)<<NODE_TYPESHIFT)
|
|
276
269
|
|
|
277
270
|
#define nd_type(n) ((int) (((RNODE(n))->flags & NODE_TYPEMASK)>>NODE_TYPESHIFT))
|
|
278
271
|
#define nd_set_type(n,t) \
|
|
279
|
-
RNODE(n)->flags=((RNODE(n)->flags&~NODE_TYPEMASK)|(((t)<<NODE_TYPESHIFT)&NODE_TYPEMASK))
|
|
272
|
+
RNODE(n)->flags=((RNODE(n)->flags&~NODE_TYPEMASK)|((((unsigned long)t)<<NODE_TYPESHIFT)&NODE_TYPEMASK))
|
|
280
273
|
|
|
281
274
|
#define NODE_LSHIFT (NODE_TYPESHIFT+7)
|
|
282
275
|
#define NODE_LMASK (((SIGNED_VALUE)1<<(sizeof(VALUE)*CHAR_BIT-NODE_LSHIFT))-1)
|
|
283
|
-
#define nd_line(n) (
|
|
276
|
+
#define nd_line(n) (int)(RNODE(n)->flags>>NODE_LSHIFT)
|
|
284
277
|
#define nd_set_line(n,l) \
|
|
285
278
|
RNODE(n)->flags=((RNODE(n)->flags&~(-1<<NODE_LSHIFT))|(((l)&NODE_LMASK)<<NODE_LSHIFT))
|
|
286
279
|
|
|
@@ -355,11 +348,8 @@ typedef struct RNode {
|
|
|
355
348
|
|
|
356
349
|
#define NEW_NODE(t,a0,a1,a2) rb_node_newnode((t),(VALUE)(a0),(VALUE)(a1),(VALUE)(a2))
|
|
357
350
|
|
|
358
|
-
#define NEW_METHOD(n,x,v) NEW_NODE(NODE_METHOD,x,n,v)
|
|
359
|
-
#define NEW_FBODY(n,i) NEW_NODE(NODE_FBODY,i,n,0)
|
|
360
351
|
#define NEW_DEFN(i,a,d,p) NEW_NODE(NODE_DEFN,0,i,NEW_SCOPE(a,d))
|
|
361
352
|
#define NEW_DEFS(r,i,a,d) NEW_NODE(NODE_DEFS,r,i,NEW_SCOPE(a,d))
|
|
362
|
-
#define NEW_CFUNC(f,c) NEW_NODE(NODE_CFUNC,f,c,0)
|
|
363
353
|
#define NEW_IFUNC(f,c) NEW_NODE(NODE_IFUNC,f,c,0)
|
|
364
354
|
#define NEW_SCOPE(a,b) NEW_NODE(NODE_SCOPE,local_tbl(),b,a)
|
|
365
355
|
#define NEW_BLOCK(a) NEW_NODE(NODE_BLOCK,a,0,0)
|
|
@@ -445,7 +435,6 @@ typedef struct RNode {
|
|
|
445
435
|
#define NEW_COLON3(i) NEW_NODE(NODE_COLON3,0,i,0)
|
|
446
436
|
#define NEW_DOT2(b,e) NEW_NODE(NODE_DOT2,b,e,0)
|
|
447
437
|
#define NEW_DOT3(b,e) NEW_NODE(NODE_DOT3,b,e,0)
|
|
448
|
-
#define NEW_ATTRSET(a) NEW_NODE(NODE_ATTRSET,a,0,0)
|
|
449
438
|
#define NEW_SELF() NEW_NODE(NODE_SELF,0,0,0)
|
|
450
439
|
#define NEW_NIL() NEW_NODE(NODE_NIL,0,0,0)
|
|
451
440
|
#define NEW_TRUE() NEW_NODE(NODE_TRUE,0,0,0)
|
|
@@ -459,30 +448,6 @@ typedef struct RNode {
|
|
|
459
448
|
#define NEW_PRELUDE(p,b) NEW_NODE(NODE_PRELUDE,p,b,0)
|
|
460
449
|
#define NEW_OPTBLOCK(a) NEW_NODE(NODE_OPTBLOCK,a,0,0)
|
|
461
450
|
|
|
462
|
-
#define NOEX_PUBLIC 0x00
|
|
463
|
-
#define NOEX_NOSUPER 0x01
|
|
464
|
-
#define NOEX_PRIVATE 0x02
|
|
465
|
-
#define NOEX_PROTECTED 0x04
|
|
466
|
-
#define NOEX_MASK 0x06 /* 0110 */
|
|
467
|
-
#define NOEX_BASIC 0x08
|
|
468
|
-
|
|
469
|
-
#define NOEX_UNDEF NOEX_NOSUPER
|
|
470
|
-
|
|
471
|
-
#define NOEX_MODFUNC 0x12
|
|
472
|
-
#define NOEX_SUPER 0x20
|
|
473
|
-
#define NOEX_VCALL 0x40
|
|
474
|
-
|
|
475
|
-
#define NOEX_SAFE(n) (((n) >> 8) & 0x0F)
|
|
476
|
-
#define NOEX_WITH(n, s) ((s << 8) | (n) | (ruby_running ? 0 : NOEX_BASIC))
|
|
477
|
-
#define NOEX_WITH_SAFE(n) NOEX_WITH(n, rb_safe_level())
|
|
478
|
-
|
|
479
|
-
#define CALL_PUBLIC 0
|
|
480
|
-
#define CALL_FCALL 1
|
|
481
|
-
#define CALL_VCALL 2
|
|
482
|
-
#define CALL_SUPER 3
|
|
483
|
-
|
|
484
|
-
#define RUBY_VM_METHOD_NODE NODE_METHOD
|
|
485
|
-
|
|
486
451
|
VALUE rb_parser_new(void);
|
|
487
452
|
VALUE rb_parser_end_seen_p(VALUE);
|
|
488
453
|
VALUE rb_parser_encoding(VALUE);
|
|
@@ -495,16 +460,18 @@ NODE *rb_compile_cstr(const char*, const char*, int, int);
|
|
|
495
460
|
NODE *rb_compile_string(const char*, VALUE, int);
|
|
496
461
|
NODE *rb_compile_file(const char*, VALUE, int);
|
|
497
462
|
|
|
498
|
-
void rb_add_method(VALUE, ID, NODE *, int);
|
|
499
463
|
NODE *rb_node_newnode(enum node_type,VALUE,VALUE,VALUE);
|
|
464
|
+
NODE *rb_node_newnode_longlife(enum node_type,VALUE,VALUE,VALUE);
|
|
500
465
|
|
|
501
|
-
|
|
502
|
-
|
|
466
|
+
struct rb_global_entry {
|
|
467
|
+
struct rb_global_variable *var;
|
|
468
|
+
ID id;
|
|
469
|
+
};
|
|
503
470
|
|
|
504
|
-
struct
|
|
505
|
-
VALUE rb_gvar_get(struct
|
|
506
|
-
VALUE rb_gvar_set(struct
|
|
507
|
-
VALUE rb_gvar_defined(struct
|
|
471
|
+
struct rb_global_entry *rb_global_entry(ID);
|
|
472
|
+
VALUE rb_gvar_get(struct rb_global_entry *);
|
|
473
|
+
VALUE rb_gvar_set(struct rb_global_entry *, VALUE);
|
|
474
|
+
VALUE rb_gvar_defined(struct rb_global_entry *);
|
|
508
475
|
|
|
509
476
|
#if defined(__cplusplus)
|
|
510
477
|
#if 0
|
data/ext/parse.h
CHANGED
|
@@ -1,10 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
/* A Bison parser, made by GNU Bison 2.4.1. */
|
|
1
|
+
/* A Bison parser, made by GNU Bison 2.4.3. */
|
|
3
2
|
|
|
4
3
|
/* Skeleton interface for Bison's Yacc-like parsers in C
|
|
5
4
|
|
|
6
|
-
Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006
|
|
7
|
-
Free Software Foundation, Inc.
|
|
5
|
+
Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006,
|
|
6
|
+
2009, 2010 Free Software Foundation, Inc.
|
|
8
7
|
|
|
9
8
|
This program is free software: you can redistribute it and/or modify
|
|
10
9
|
it under the terms of the GNU General Public License as published by
|
|
@@ -150,14 +149,13 @@
|
|
|
150
149
|
idRespond_to = 366,
|
|
151
150
|
idIFUNC = 367,
|
|
152
151
|
idCFUNC = 368,
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
tLAST_TOKEN = 376
|
|
152
|
+
id_core_set_method_alias = 369,
|
|
153
|
+
id_core_set_variable_alias = 370,
|
|
154
|
+
id_core_undef_method = 371,
|
|
155
|
+
id_core_define_method = 372,
|
|
156
|
+
id_core_define_singleton_method = 373,
|
|
157
|
+
id_core_set_postexe = 374,
|
|
158
|
+
tLAST_TOKEN = 375
|
|
161
159
|
};
|
|
162
160
|
#endif
|
|
163
161
|
|
|
@@ -167,7 +165,7 @@
|
|
|
167
165
|
typedef union YYSTYPE
|
|
168
166
|
{
|
|
169
167
|
|
|
170
|
-
/* Line
|
|
168
|
+
/* Line 1685 of yacc.c */
|
|
171
169
|
|
|
172
170
|
VALUE val;
|
|
173
171
|
NODE *node;
|
|
@@ -177,7 +175,7 @@ typedef union YYSTYPE
|
|
|
177
175
|
|
|
178
176
|
|
|
179
177
|
|
|
180
|
-
/* Line
|
|
178
|
+
/* Line 1685 of yacc.c */
|
|
181
179
|
} YYSTYPE;
|
|
182
180
|
# define YYSTYPE_IS_TRIVIAL 1
|
|
183
181
|
# define yystype YYSTYPE /* obsolescent; will be withdrawn */
|
data/ext/regenc.h
CHANGED
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
regenc.h - Oniguruma (regular expression library)
|
|
5
5
|
**********************************************************************/
|
|
6
6
|
/*-
|
|
7
|
-
* Copyright (c) 2002-
|
|
7
|
+
* Copyright (c) 2002-2008 K.Kosako <sndgk393 AT ybb DOT ne DOT jp>
|
|
8
8
|
* All rights reserved.
|
|
9
9
|
*
|
|
10
10
|
* Redistribution and use in source and binary forms, with or without
|
|
@@ -96,11 +96,12 @@ typedef struct {
|
|
|
96
96
|
|
|
97
97
|
|
|
98
98
|
typedef struct {
|
|
99
|
-
UChar
|
|
99
|
+
const UChar *name;
|
|
100
100
|
int ctype;
|
|
101
101
|
short int len;
|
|
102
102
|
} PosixBracketEntryType;
|
|
103
103
|
|
|
104
|
+
#define PosixBracketEntryInit(name, ctype) {(const UChar *)name, ctype, (short int)(sizeof(name) - 1)}
|
|
104
105
|
|
|
105
106
|
/* #define USE_CRNL_AS_LINE_TERMINATOR */
|
|
106
107
|
#define USE_UNICODE_PROPERTIES
|
|
@@ -152,6 +153,9 @@ ONIG_EXTERN int onigenc_unicode_mbc_case_fold P_((OnigEncoding enc, OnigCaseFold
|
|
|
152
153
|
ONIG_EXTERN int onigenc_unicode_apply_all_case_fold P_((OnigCaseFoldType flag, OnigApplyAllCaseFoldFunc f, void* arg, OnigEncoding enc));
|
|
153
154
|
|
|
154
155
|
|
|
156
|
+
#define UTF16_IS_SURROGATE_FIRST(c) (((c) & 0xfc) == 0xd8)
|
|
157
|
+
#define UTF16_IS_SURROGATE_SECOND(c) (((c) & 0xfc) == 0xdc)
|
|
158
|
+
|
|
155
159
|
#define ONIGENC_ISO_8859_1_TO_LOWER_CASE(c) \
|
|
156
160
|
OnigEncISO_8859_1_ToLowerCaseTable[c]
|
|
157
161
|
#define ONIGENC_ISO_8859_1_TO_UPPER_CASE(c) \
|
|
@@ -181,7 +185,7 @@ ONIG_EXTERN const unsigned short OnigEncAsciiCtypeTable[];
|
|
|
181
185
|
#define ONIGENC_IS_ASCII_CODE_CASE_AMBIG(code) \
|
|
182
186
|
(ONIGENC_IS_ASCII_CODE_CTYPE(code, ONIGENC_CTYPE_UPPER) ||\
|
|
183
187
|
ONIGENC_IS_ASCII_CODE_CTYPE(code, ONIGENC_CTYPE_LOWER))
|
|
184
|
-
|
|
188
|
+
|
|
185
189
|
#ifdef ONIG_ENC_REGISTER
|
|
186
190
|
extern int ONIG_ENC_REGISTER(const char *, OnigEncodingType*);
|
|
187
191
|
#define OnigEncodingName(n) encoding_##n
|
data/ext/regint.h
CHANGED
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
regint.h - Oniguruma (regular expression library)
|
|
5
5
|
**********************************************************************/
|
|
6
6
|
/*-
|
|
7
|
-
* Copyright (c) 2002-
|
|
7
|
+
* Copyright (c) 2002-2008 K.Kosako <sndgk393 AT ybb DOT ne DOT jp>
|
|
8
8
|
* All rights reserved.
|
|
9
9
|
*
|
|
10
10
|
* Redistribution and use in source and binary forms, with or without
|
|
@@ -352,7 +352,7 @@ typedef unsigned char Bits;
|
|
|
352
352
|
typedef Bits BitSet[BITSET_SIZE];
|
|
353
353
|
typedef Bits* BitSetRef;
|
|
354
354
|
|
|
355
|
-
#define SIZE_BITSET sizeof(BitSet)
|
|
355
|
+
#define SIZE_BITSET (int)sizeof(BitSet)
|
|
356
356
|
|
|
357
357
|
#define BITSET_CLEAR(bs) do {\
|
|
358
358
|
int i;\
|
|
@@ -582,15 +582,15 @@ typedef short int StateCheckNumType;
|
|
|
582
582
|
typedef void* PointerType;
|
|
583
583
|
|
|
584
584
|
#define SIZE_OPCODE 1
|
|
585
|
-
#define SIZE_RELADDR sizeof(RelAddrType)
|
|
586
|
-
#define SIZE_ABSADDR sizeof(AbsAddrType)
|
|
587
|
-
#define SIZE_LENGTH sizeof(LengthType)
|
|
588
|
-
#define SIZE_MEMNUM sizeof(MemNumType)
|
|
589
|
-
#define SIZE_STATE_CHECK_NUM sizeof(StateCheckNumType)
|
|
590
|
-
#define SIZE_REPEATNUM sizeof(RepeatNumType)
|
|
591
|
-
#define SIZE_OPTION sizeof(OnigOptionType)
|
|
592
|
-
#define SIZE_CODE_POINT sizeof(OnigCodePoint)
|
|
593
|
-
#define SIZE_POINTER sizeof(PointerType)
|
|
585
|
+
#define SIZE_RELADDR (int)sizeof(RelAddrType)
|
|
586
|
+
#define SIZE_ABSADDR (int)sizeof(AbsAddrType)
|
|
587
|
+
#define SIZE_LENGTH (int)sizeof(LengthType)
|
|
588
|
+
#define SIZE_MEMNUM (int)sizeof(MemNumType)
|
|
589
|
+
#define SIZE_STATE_CHECK_NUM (int)sizeof(StateCheckNumType)
|
|
590
|
+
#define SIZE_REPEATNUM (int)sizeof(RepeatNumType)
|
|
591
|
+
#define SIZE_OPTION (int)sizeof(OnigOptionType)
|
|
592
|
+
#define SIZE_CODE_POINT (int)sizeof(OnigCodePoint)
|
|
593
|
+
#define SIZE_POINTER (int)sizeof(PointerType)
|
|
594
594
|
|
|
595
595
|
|
|
596
596
|
#define GET_RELADDR_INC(addr,p) PLATFORM_GET_INC(addr, p, RelAddrType)
|
|
@@ -716,7 +716,7 @@ typedef struct {
|
|
|
716
716
|
BBuf* mbuf; /* multi-byte info or NULL */
|
|
717
717
|
} CClassNode;
|
|
718
718
|
|
|
719
|
-
typedef
|
|
719
|
+
typedef intptr_t OnigStackIndex;
|
|
720
720
|
|
|
721
721
|
typedef struct _OnigStackType {
|
|
722
722
|
unsigned int type;
|
|
@@ -760,7 +760,7 @@ typedef struct _OnigStackType {
|
|
|
760
760
|
|
|
761
761
|
typedef struct {
|
|
762
762
|
void* stack_p;
|
|
763
|
-
|
|
763
|
+
size_t stack_n;
|
|
764
764
|
OnigOptionType options;
|
|
765
765
|
OnigRegion* region;
|
|
766
766
|
const UChar* start; /* search start position (for \G: BEGIN_POSITION) */
|
|
@@ -788,7 +788,7 @@ typedef struct {
|
|
|
788
788
|
|
|
789
789
|
extern OnigOpInfoType OnigOpInfo[];
|
|
790
790
|
|
|
791
|
-
extern void onig_print_compiled_byte_code P_((FILE* f, UChar* bp, UChar** nextp, OnigEncoding enc));
|
|
791
|
+
/* extern void onig_print_compiled_byte_code P_((FILE* f, UChar* bp, UChar* bpend, UChar** nextp, OnigEncoding enc)); */
|
|
792
792
|
|
|
793
793
|
#ifdef ONIG_DEBUG_STATISTICS
|
|
794
794
|
extern void onig_statistics_init P_((void));
|
|
@@ -799,8 +799,7 @@ extern void onig_print_statistics P_((FILE* f));
|
|
|
799
799
|
extern UChar* onig_error_code_to_format P_((int code));
|
|
800
800
|
extern void onig_snprintf_with_pattern PV_((UChar buf[], int bufsize, OnigEncoding enc, UChar* pat, UChar* pat_end, const UChar *fmt, ...));
|
|
801
801
|
extern int onig_bbuf_init P_((BBuf* buf, int size));
|
|
802
|
-
extern int
|
|
803
|
-
extern int onig_compile P_((regex_t* reg, const UChar* pattern, const UChar* pattern_end, OnigErrorInfo* einfo));
|
|
802
|
+
extern int onig_compile P_((regex_t* reg, const UChar* pattern, const UChar* pattern_end, OnigErrorInfo* einfo, const char *sourcefile, int sourceline));
|
|
804
803
|
extern void onig_chain_reduce P_((regex_t* reg));
|
|
805
804
|
extern void onig_chain_link_add P_((regex_t* to, regex_t* add));
|
|
806
805
|
extern void onig_transfer P_((regex_t* to, regex_t* from));
|
|
@@ -816,7 +815,7 @@ typedef st_data_t hash_data_type;
|
|
|
816
815
|
typedef unsigned long hash_data_type;
|
|
817
816
|
#endif
|
|
818
817
|
|
|
819
|
-
extern hash_table_type* onig_st_init_strend_table_with_size P_((
|
|
818
|
+
extern hash_table_type* onig_st_init_strend_table_with_size P_((st_index_t size));
|
|
820
819
|
extern int onig_st_lookup_strend P_((hash_table_type* table, const UChar* str_key, const UChar* end_key, hash_data_type *value));
|
|
821
820
|
extern int onig_st_insert_strend P_((hash_table_type* table, const UChar* str_key, const UChar* end_key, hash_data_type value));
|
|
822
821
|
|
data/ext/regparse.h
CHANGED
|
@@ -192,7 +192,7 @@ typedef struct {
|
|
|
192
192
|
AbsAddrType call_addr;
|
|
193
193
|
/* for multiple call reference */
|
|
194
194
|
OnigDistance min_len; /* min length (byte) */
|
|
195
|
-
OnigDistance max_len; /* max length (byte) */
|
|
195
|
+
OnigDistance max_len; /* max length (byte) */
|
|
196
196
|
int char_len; /* character length */
|
|
197
197
|
int opt_count; /* referenced count in optimize_node_left() */
|
|
198
198
|
} EncloseNode;
|
|
@@ -306,6 +306,9 @@ typedef struct {
|
|
|
306
306
|
int curr_max_regnum;
|
|
307
307
|
int has_recursion;
|
|
308
308
|
#endif
|
|
309
|
+
int warnings_flag;
|
|
310
|
+
const char* sourcefile;
|
|
311
|
+
int sourceline;
|
|
309
312
|
} ScanEnv;
|
|
310
313
|
|
|
311
314
|
|
data/ext/revision.h
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
#define RUBY_REVISION
|
|
1
|
+
#define RUBY_REVISION 30365
|
data/ext/thread_pthread.h
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
thread_pthread.h -
|
|
4
4
|
|
|
5
|
-
$Author:
|
|
5
|
+
$Author: naruse $
|
|
6
6
|
|
|
7
7
|
Copyright (C) 2004-2007 Koichi Sasada
|
|
8
8
|
|
|
@@ -12,6 +12,9 @@
|
|
|
12
12
|
#define RUBY_THREAD_PTHREAD_H
|
|
13
13
|
|
|
14
14
|
#include <pthread.h>
|
|
15
|
+
#ifdef HAVE_PTHREAD_NP_H
|
|
16
|
+
#include <pthread_np.h>
|
|
17
|
+
#endif
|
|
15
18
|
typedef pthread_t rb_thread_id_t;
|
|
16
19
|
typedef pthread_mutex_t rb_thread_lock_t;
|
|
17
20
|
typedef pthread_cond_t rb_thread_cond_t;
|
data/ext/thread_win32.h
CHANGED
data/ext/timev.h
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
#ifndef RUBY_TIMEV_H
|
|
2
|
+
#define RUBY_TIMEV_H
|
|
3
|
+
|
|
4
|
+
struct vtm {
|
|
5
|
+
VALUE year; /* 2000 for example. Integer. */
|
|
6
|
+
int mon; /* 1..12 */
|
|
7
|
+
int mday; /* 1..31 */
|
|
8
|
+
int hour; /* 0..23 */
|
|
9
|
+
int min; /* 0..59 */
|
|
10
|
+
int sec; /* 0..60 */
|
|
11
|
+
VALUE subsecx; /* 0 <= subsecx < TIME_SCALE. possibly Rational. */
|
|
12
|
+
VALUE utc_offset; /* -3600 as -01:00 for example. possibly Rational. */
|
|
13
|
+
int wday; /* 0:Sunday, 1:Monday, ..., 6:Saturday */
|
|
14
|
+
int yday; /* 1..366 */
|
|
15
|
+
int isdst; /* 0:StandardTime 1:DayLightSavingTime */
|
|
16
|
+
const char *zone; /* "JST", "EST", "EDT", etc. */
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
#define TIME_SCALE 1000000000
|
|
20
|
+
|
|
21
|
+
#endif
|
data/ext/transcode_data.h
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
transcode_data.h -
|
|
4
4
|
|
|
5
|
-
$Author:
|
|
5
|
+
$Author: duerst $
|
|
6
6
|
created at: Mon 10 Dec 2007 14:01:47 JST 2007
|
|
7
7
|
|
|
8
8
|
Copyright (C) 2007 Martin Duerst
|
|
@@ -22,7 +22,7 @@
|
|
|
22
22
|
|
|
23
23
|
#define PType (unsigned int)
|
|
24
24
|
|
|
25
|
-
#define NOMAP (PType 0x01) /*
|
|
25
|
+
#define NOMAP (PType 0x01) /* direct map */
|
|
26
26
|
#define ONEbt (0x02) /* one byte payload */
|
|
27
27
|
#define TWObt (0x03) /* two bytes payload */
|
|
28
28
|
#define THREEbt (0x05) /* three bytes payload */
|
|
@@ -36,27 +36,29 @@
|
|
|
36
36
|
#define FUNso (PType 0x0F) /* function from start to output */
|
|
37
37
|
#define STR1 (PType 0x11) /* string 4 <= len <= 259 bytes: 1byte length + content */
|
|
38
38
|
#define GB4bt (PType 0x12) /* GB18030 four bytes payload */
|
|
39
|
+
#define FUNsio (PType 0x13) /* function from start and info to output */
|
|
39
40
|
|
|
40
|
-
#define STR1_LENGTH(byte_addr) (*(byte_addr) + 4)
|
|
41
|
+
#define STR1_LENGTH(byte_addr) (unsigned int)(*(byte_addr) + 4)
|
|
41
42
|
#define STR1_BYTEINDEX(w) ((w) >> 6)
|
|
42
43
|
#define makeSTR1(bi) (((bi) << 6) | STR1)
|
|
43
44
|
#define makeSTR1LEN(len) ((len)-4)
|
|
44
45
|
|
|
45
46
|
#define o1(b1) (PType((((unsigned char)(b1))<<8)|ONEbt))
|
|
46
47
|
#define o2(b1,b2) (PType((((unsigned char)(b1))<<8)|(((unsigned char)(b2))<<16)|TWObt))
|
|
47
|
-
#define o3(b1,b2,b3) (PType(((((unsigned char)(b1))<<8)|(((unsigned char)(b2))<<16)|(((unsigned char)(b3))<<24)|THREEbt)&0xffffffffU))
|
|
48
|
+
#define o3(b1,b2,b3) (PType(((((unsigned char)(b1))<<8)|(((unsigned char)(b2))<<16)|(((unsigned int)(unsigned char)(b3))<<24)|THREEbt)&0xffffffffU))
|
|
48
49
|
#define o4(b0,b1,b2,b3) (PType(((((unsigned char)(b1))<<8)|(((unsigned char)(b2))<<16)|(((unsigned char)(b3))<<24)|((((unsigned char)(b0))&0x07)<<5)|FOURbt)&0xffffffffU))
|
|
49
|
-
#define g4(b0,b1,b2,b3) (PType(((((unsigned char)(b0))<<8)|(((unsigned char)(b2))<<16)|((((unsigned char)(b1))&0x0f)<<24)|((((unsigned char)(b3))&0x0f)<<28)|GB4bt)&0xffffffffU))
|
|
50
|
+
#define g4(b0,b1,b2,b3) (PType(((((unsigned char)(b0))<<8)|(((unsigned char)(b2))<<16)|((((unsigned char)(b1))&0x0f)<<24)|((((unsigned int)(unsigned char)(b3))&0x0f)<<28)|GB4bt)&0xffffffffU))
|
|
51
|
+
#define funsio(diff) (PType((((unsigned int)(diff))<<8)|FUNsio))
|
|
50
52
|
|
|
51
|
-
#define getBT1(a) (((a)>> 8)
|
|
52
|
-
#define getBT2(a) (((a)>>16)
|
|
53
|
-
#define getBT3(a) (((a)>>24)
|
|
54
|
-
#define getBT0(a) ((((a)>> 5)&0x07)|0xF0) /* for UTF-8 only!!! */
|
|
53
|
+
#define getBT1(a) ((unsigned char)((a)>> 8))
|
|
54
|
+
#define getBT2(a) ((unsigned char)((a)>>16))
|
|
55
|
+
#define getBT3(a) ((unsigned char)((a)>>24))
|
|
56
|
+
#define getBT0(a) (((unsigned char)((a)>> 5)&0x07)|0xF0) /* for UTF-8 only!!! */
|
|
55
57
|
|
|
56
|
-
#define getGB4bt0(a) (((a)>> 8)
|
|
57
|
-
#define getGB4bt1(a) (((a)>>24)&0x0F|0x30)
|
|
58
|
-
#define getGB4bt2(a) (((a)>>16)
|
|
59
|
-
#define getGB4bt3(a) (((a)>>28)&0x0F|0x30)
|
|
58
|
+
#define getGB4bt0(a) ((unsigned char)((a)>> 8))
|
|
59
|
+
#define getGB4bt1(a) ((unsigned char)((a)>>24)&0x0F|0x30)
|
|
60
|
+
#define getGB4bt2(a) ((unsigned char)((a)>>16))
|
|
61
|
+
#define getGB4bt3(a) ((unsigned char)((a)>>28)&0x0F|0x30)
|
|
60
62
|
|
|
61
63
|
#define o2FUNii(b1,b2) (PType((((unsigned char)(b1))<<8)|(((unsigned char)(b2))<<16)|FUNii))
|
|
62
64
|
|
|
@@ -69,7 +71,7 @@ typedef enum {
|
|
|
69
71
|
asciicompat_converter, /* ASCII-compatible -> ASCII-compatible */
|
|
70
72
|
asciicompat_decoder, /* ASCII-incompatible -> ASCII-compatible */
|
|
71
73
|
asciicompat_encoder /* ASCII-compatible -> ASCII-incompatible */
|
|
72
|
-
/* ASCII-incompatible -> ASCII-incompatible is intentionally
|
|
74
|
+
/* ASCII-incompatible -> ASCII-incompatible is intentionally omitted. */
|
|
73
75
|
} rb_transcoder_asciicompat_type_t;
|
|
74
76
|
|
|
75
77
|
typedef struct rb_transcoder rb_transcoder;
|
|
@@ -98,6 +100,7 @@ struct rb_transcoder {
|
|
|
98
100
|
ssize_t (*finish_func)(void*, unsigned char*, size_t); /* -> output */
|
|
99
101
|
ssize_t (*resetsize_func)(void*); /* -> len */
|
|
100
102
|
ssize_t (*resetstate_func)(void*, unsigned char*, size_t); /* -> output */
|
|
103
|
+
ssize_t (*func_sio)(void*, const unsigned char*, size_t, VALUE, unsigned char*, size_t); /* start -> output */
|
|
101
104
|
};
|
|
102
105
|
|
|
103
106
|
void rb_declare_transcoder(const char *enc1, const char *enc2, const char *lib);
|
data/ext/transdb.h
CHANGED
|
@@ -1,9 +1,35 @@
|
|
|
1
1
|
rb_declare_transcoder("Big5", "UTF-8", "big5");
|
|
2
2
|
rb_declare_transcoder("UTF-8", "Big5", "big5");
|
|
3
|
+
rb_declare_transcoder("Big5-HKSCS", "UTF-8", "big5");
|
|
4
|
+
rb_declare_transcoder("UTF-8", "Big5-HKSCS", "big5");
|
|
5
|
+
rb_declare_transcoder("Big5-UAO", "UTF-8", "big5");
|
|
6
|
+
rb_declare_transcoder("UTF-8", "Big5-UAO", "big5");
|
|
3
7
|
rb_declare_transcoder("GB2312", "UTF-8", "chinese");
|
|
4
8
|
rb_declare_transcoder("GB12345", "UTF-8", "chinese");
|
|
5
9
|
rb_declare_transcoder("UTF-8", "GB2312", "chinese");
|
|
6
10
|
rb_declare_transcoder("UTF-8", "GB12345", "chinese");
|
|
11
|
+
rb_declare_transcoder("UTF8-DoCoMo", "UTF8-KDDI", "emoji");
|
|
12
|
+
rb_declare_transcoder("UTF8-DoCoMo", "UTF8-SoftBank", "emoji");
|
|
13
|
+
rb_declare_transcoder("UTF8-DoCoMo", "UTF-8", "emoji");
|
|
14
|
+
rb_declare_transcoder("UTF8-KDDI", "UTF8-DoCoMo", "emoji");
|
|
15
|
+
rb_declare_transcoder("UTF8-KDDI", "UTF8-SoftBank", "emoji");
|
|
16
|
+
rb_declare_transcoder("UTF8-KDDI", "UTF-8", "emoji");
|
|
17
|
+
rb_declare_transcoder("UTF8-SoftBank", "UTF8-DoCoMo", "emoji");
|
|
18
|
+
rb_declare_transcoder("UTF8-SoftBank", "UTF8-KDDI", "emoji");
|
|
19
|
+
rb_declare_transcoder("UTF8-SoftBank", "UTF-8", "emoji");
|
|
20
|
+
rb_declare_transcoder("UTF-8", "UTF8-DoCoMo", "emoji");
|
|
21
|
+
rb_declare_transcoder("UTF-8", "UTF8-KDDI", "emoji");
|
|
22
|
+
rb_declare_transcoder("UTF-8", "UTF8-SoftBank", "emoji");
|
|
23
|
+
rb_declare_transcoder("stateless-ISO-2022-JP-KDDI", "UTF8-KDDI", "emoji_iso2022_kddi");
|
|
24
|
+
rb_declare_transcoder("UTF8-KDDI", "stateless-ISO-2022-JP-KDDI", "emoji_iso2022_kddi");
|
|
25
|
+
rb_declare_transcoder("ISO-2022-JP-KDDI", "stateless-ISO-2022-JP-KDDI", "emoji_iso2022_kddi");
|
|
26
|
+
rb_declare_transcoder("stateless-ISO-2022-JP-KDDI", "ISO-2022-JP-KDDI", "emoji_iso2022_kddi");
|
|
27
|
+
rb_declare_transcoder("SJIS-DOCOMO", "UTF8-DOCOMO", "emoji_sjis_docomo");
|
|
28
|
+
rb_declare_transcoder("UTF8-DOCOMO", "SJIS-DOCOMO", "emoji_sjis_docomo");
|
|
29
|
+
rb_declare_transcoder("SJIS-KDDI", "UTF8-KDDI", "emoji_sjis_kddi");
|
|
30
|
+
rb_declare_transcoder("UTF8-KDDI", "SJIS-KDDI", "emoji_sjis_kddi");
|
|
31
|
+
rb_declare_transcoder("SJIS-SoftBank", "UTF8-SoftBank", "emoji_sjis_softbank");
|
|
32
|
+
rb_declare_transcoder("UTF8-SoftBank", "SJIS-SoftBank", "emoji_sjis_softbank");
|
|
7
33
|
rb_declare_transcoder("", "amp_escape", "escape");
|
|
8
34
|
rb_declare_transcoder("", "xml_text_escape", "escape");
|
|
9
35
|
rb_declare_transcoder("", "xml_attr_content_escape", "escape");
|
|
@@ -16,6 +42,10 @@ rb_declare_transcoder("ISO-2022-JP", "stateless-ISO-2022-JP", "iso2022");
|
|
|
16
42
|
rb_declare_transcoder("stateless-ISO-2022-JP", "ISO-2022-JP", "iso2022");
|
|
17
43
|
rb_declare_transcoder("stateless-ISO-2022-JP", "EUC-JP", "iso2022");
|
|
18
44
|
rb_declare_transcoder("EUC-JP", "stateless-ISO-2022-JP", "iso2022");
|
|
45
|
+
rb_declare_transcoder("CP50220", "cp51932", "iso2022");
|
|
46
|
+
rb_declare_transcoder("CP50221", "cp51932", "iso2022");
|
|
47
|
+
rb_declare_transcoder("CP51932", "CP50221", "iso2022");
|
|
48
|
+
rb_declare_transcoder("CP51932", "CP50220", "iso2022");
|
|
19
49
|
rb_declare_transcoder("EUC-JP", "Shift_JIS", "japanese");
|
|
20
50
|
rb_declare_transcoder("Shift_JIS", "EUC-JP", "japanese");
|
|
21
51
|
rb_declare_transcoder("EUC-JP", "UTF-8", "japanese_euc");
|
|
@@ -137,6 +167,8 @@ rb_declare_transcoder("CP852", "UTF-8", "single_byte");
|
|
|
137
167
|
rb_declare_transcoder("UTF-8", "CP852", "single_byte");
|
|
138
168
|
rb_declare_transcoder("CP855", "UTF-8", "single_byte");
|
|
139
169
|
rb_declare_transcoder("UTF-8", "CP855", "single_byte");
|
|
170
|
+
rb_declare_transcoder("UTF-8", "UTF8-MAC", "utf8_mac");
|
|
171
|
+
rb_declare_transcoder("UTF8-MAC", "UTF-8", "utf8_mac");
|
|
140
172
|
rb_declare_transcoder("UTF-16BE", "UTF-8", "utf_16_32");
|
|
141
173
|
rb_declare_transcoder("UTF-8", "UTF-16BE", "utf_16_32");
|
|
142
174
|
rb_declare_transcoder("UTF-16LE", "UTF-8", "utf_16_32");
|