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.
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: yugui $
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 global_entry *entry;
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) ((VALUE)(((RNODE(n))->flags>>NODE_LSHIFT)&NODE_LMASK))
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
- NODE* rb_method_node(VALUE klass, ID id);
502
- int rb_node_arity(NODE* node);
466
+ struct rb_global_entry {
467
+ struct rb_global_variable *var;
468
+ ID id;
469
+ };
503
470
 
504
- struct global_entry *rb_global_entry(ID);
505
- VALUE rb_gvar_get(struct global_entry *);
506
- VALUE rb_gvar_set(struct global_entry *, VALUE);
507
- VALUE rb_gvar_defined(struct global_entry *);
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
- idThrowState = 369,
154
- id_core_set_method_alias = 370,
155
- id_core_set_variable_alias = 371,
156
- id_core_undef_method = 372,
157
- id_core_define_method = 373,
158
- id_core_define_singleton_method = 374,
159
- id_core_set_postexe = 375,
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 1676 of yacc.c */
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 1676 of yacc.c */
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-2007 K.Kosako <sndgk393 AT ybb DOT ne DOT jp>
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 *name;
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-2007 K.Kosako <sndgk393 AT ybb DOT ne DOT jp>
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 long OnigStackIndex;
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
- int stack_n;
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 onig_alloc_init P_((regex_t** reg, OnigOptionType option, OnigCaseFoldType case_fold_flag, OnigEncoding enc, const OnigSyntaxType* syntax));
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_((int size));
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 26041
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: nobu $
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
@@ -2,7 +2,7 @@
2
2
 
3
3
  thread_win32.h -
4
4
 
5
- $Author: usa $
5
+ $Author: akr $
6
6
 
7
7
  Copyright (C) 2004-2007 Koichi Sasada
8
8
 
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: yugui $
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) /* single byte direct map */
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)&0xFF)
52
- #define getBT2(a) (((a)>>16)&0xFF)
53
- #define getBT3(a) (((a)>>24)&0xFF)
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)&0xFF)
57
- #define getGB4bt1(a) (((a)>>24)&0x0F|0x30)
58
- #define getGB4bt2(a) (((a)>>16)&0xFF)
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 ommitted. */
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");