ox 2.14.14 → 2.14.15

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/ox/builder.c CHANGED
@@ -4,41 +4,42 @@
4
4
  */
5
5
 
6
6
  #include <errno.h>
7
- #include <stdlib.h>
8
7
  #include <stdio.h>
8
+ #include <stdlib.h>
9
9
  #include <string.h>
10
10
 
11
+ #include "buf.h"
12
+ #include "err.h"
13
+ #include "ox.h"
11
14
  #include "ruby.h"
12
15
  #include "ruby/encoding.h"
13
16
  #include "ruby/version.h"
14
- #include "ox.h"
15
- #include "buf.h"
16
- #include "err.h"
17
17
 
18
- #define MAX_DEPTH 128
18
+ #define MAX_DEPTH 128
19
19
 
20
20
  typedef struct _element {
21
- char *name;
22
- char buf[64];
23
- long len;
24
- bool has_child;
25
- bool non_text_child;
21
+ char *name;
22
+ char buf[64];
23
+ long len;
24
+ bool has_child;
25
+ bool non_text_child;
26
26
  } *Element;
27
27
 
28
28
  typedef struct _builder {
29
- struct _buf buf;
30
- int indent;
31
- char encoding[64];
32
- int depth;
33
- FILE *file;
34
- struct _element stack[MAX_DEPTH];
35
- long line;
36
- long col;
37
- long pos;
29
+ struct _buf buf;
30
+ int indent;
31
+ char encoding[64];
32
+ int depth;
33
+ FILE *file;
34
+ struct _element stack[MAX_DEPTH];
35
+ long line;
36
+ long col;
37
+ long pos;
38
38
  } *Builder;
39
39
 
40
- static VALUE builder_class = Qundef;
41
- static const char indent_spaces[] = "\n "; // 128 spaces
40
+ static VALUE builder_class = Qundef;
41
+ static const char indent_spaces[] = "\n "
42
+ " "; // 128 spaces
42
43
 
43
44
  // The : character is equivalent to 10. Used for replacement characters up to
44
45
  // 10 characters long such as '&#x10FFFF;'. From
@@ -57,7 +58,7 @@ static const char xml_friendly_chars[257] = "\
57
58
 
58
59
  // From 2.3 of the XML 1.1 spec. All over 0x20 except <&", > also. Builder
59
60
  // uses double quotes for attributes.
60
- static const char xml_attr_chars[257] = "\
61
+ static const char xml_attr_chars[257] = "\
61
62
  :::::::::11::1::::::::::::::::::\
62
63
  11611151111111111111111111114141\
63
64
  11111111111111111111111111111111\
@@ -68,7 +69,7 @@ static const char xml_attr_chars[257] = "\
68
69
  11111111111111111111111111111111";
69
70
 
70
71
  // From 3.1 of the XML 1.1 spec. All over 0x20 except <&, > also.
71
- static const char xml_element_chars[257] = "\
72
+ static const char xml_element_chars[257] = "\
72
73
  :::::::::11::1::::::::::::::::::\
73
74
  11111151111111111111111111114141\
74
75
  11111111111111111111111111111111\
@@ -78,152 +79,134 @@ static const char xml_element_chars[257] = "\
78
79
  11111111111111111111111111111111\
79
80
  11111111111111111111111111111111";
80
81
 
81
- inline static size_t
82
- xml_str_len(const unsigned char *str, size_t len, const char *table) {
83
- size_t size = 0;
82
+ inline static size_t xml_str_len(const unsigned char *str, size_t len, const char *table) {
83
+ size_t size = 0;
84
84
 
85
85
  for (; 0 < len; str++, len--) {
86
- size += table[*str];
86
+ size += table[*str];
87
87
  }
88
88
  return size - len * (size_t)'0';
89
89
  }
90
90
 
91
- static void
92
- append_indent(Builder b) {
91
+ static void append_indent(Builder b) {
93
92
  if (0 >= b->indent) {
94
- return;
93
+ return;
95
94
  }
96
95
  if (b->buf.head < b->buf.tail) {
97
- int cnt = (b->indent * (b->depth + 1)) + 1;
96
+ int cnt = (b->indent * (b->depth + 1)) + 1;
98
97
 
99
- if (sizeof(indent_spaces) <= (size_t)cnt) {
100
- cnt = sizeof(indent_spaces) - 1;
101
- }
102
- buf_append_string(&b->buf, indent_spaces, cnt);
103
- b->line++;
104
- b->col = cnt - 1;
105
- b->pos += cnt;
98
+ if (sizeof(indent_spaces) <= (size_t)cnt) {
99
+ cnt = sizeof(indent_spaces) - 1;
100
+ }
101
+ buf_append_string(&b->buf, indent_spaces, cnt);
102
+ b->line++;
103
+ b->col = cnt - 1;
104
+ b->pos += cnt;
106
105
  }
107
106
  }
108
107
 
109
- static void
110
- append_string(Builder b, const char *str, size_t size, const char *table, bool strip_invalid_chars) {
111
- size_t xsize = xml_str_len((const unsigned char*)str, size, table);
108
+ static void append_string(Builder b, const char *str, size_t size, const char *table, bool strip_invalid_chars) {
109
+ size_t xsize = xml_str_len((const unsigned char *)str, size, table);
112
110
 
113
111
  if (size == xsize) {
114
- const char *s = str;
115
- const char *end = str + size;
112
+ const char *s = str;
113
+ const char *end = str + size;
116
114
 
117
- buf_append_string(&b->buf, str, size);
118
- b->col += size;
115
+ buf_append_string(&b->buf, str, size);
116
+ b->col += size;
119
117
  s = strchr(s, '\n');
120
118
  while (NULL != s) {
121
119
  b->line++;
122
120
  b->col = end - s;
123
- s = strchr(s + 1, '\n');
121
+ s = strchr(s + 1, '\n');
124
122
  }
125
- b->pos += size;
123
+ b->pos += size;
126
124
  } else {
127
- char buf[256];
128
- char *end = buf + sizeof(buf) - 1;
129
- char *bp = buf;
130
- size_t i = size;
131
- int fcnt;
132
-
133
- for (; '\0' != *str && 0 < i; i--, str++) {
134
- if ('1' == (fcnt = table[(unsigned char)*str])) {
135
- if (end <= bp) {
136
- buf_append_string(&b->buf, buf, bp - buf);
137
- bp = buf;
138
- }
139
- if ('\n' == *str) {
140
- b->line++;
141
- b->col = 1;
142
- } else {
143
- b->col++;
144
- }
145
- b->pos++;
146
- *bp++ = *str;
147
- } else {
148
- b->pos += fcnt - '0';
149
- b->col += fcnt - '0';
150
- if (buf < bp) {
151
- buf_append_string(&b->buf, buf, bp - buf);
152
- bp = buf;
153
- }
154
- switch (*str) {
155
- case '"':
156
- buf_append_string(&b->buf, "&quot;", 6);
157
- break;
158
- case '&':
159
- buf_append_string(&b->buf, "&amp;", 5);
160
- break;
161
- case '\'':
162
- buf_append_string(&b->buf, "&apos;", 6);
163
- break;
164
- case '<':
165
- buf_append_string(&b->buf, "&lt;", 4);
166
- break;
167
- case '>':
168
- buf_append_string(&b->buf, "&gt;", 4);
169
- break;
170
- default:
171
- // Must be one of the invalid characters.
172
- if (!strip_invalid_chars) {
173
- rb_raise(ox_syntax_error_class, "'\\#x%02x' is not a valid XML character.", *str);
174
- }
175
- break;
176
- }
177
- }
178
- }
179
- if (buf < bp) {
180
- buf_append_string(&b->buf, buf, bp - buf);
181
- bp = buf;
182
- }
125
+ char buf[256];
126
+ char *end = buf + sizeof(buf) - 1;
127
+ char *bp = buf;
128
+ size_t i = size;
129
+ int fcnt;
130
+
131
+ for (; '\0' != *str && 0 < i; i--, str++) {
132
+ if ('1' == (fcnt = table[(unsigned char)*str])) {
133
+ if (end <= bp) {
134
+ buf_append_string(&b->buf, buf, bp - buf);
135
+ bp = buf;
136
+ }
137
+ if ('\n' == *str) {
138
+ b->line++;
139
+ b->col = 1;
140
+ } else {
141
+ b->col++;
142
+ }
143
+ b->pos++;
144
+ *bp++ = *str;
145
+ } else {
146
+ b->pos += fcnt - '0';
147
+ b->col += fcnt - '0';
148
+ if (buf < bp) {
149
+ buf_append_string(&b->buf, buf, bp - buf);
150
+ bp = buf;
151
+ }
152
+ switch (*str) {
153
+ case '"': buf_append_string(&b->buf, "&quot;", 6); break;
154
+ case '&': buf_append_string(&b->buf, "&amp;", 5); break;
155
+ case '\'': buf_append_string(&b->buf, "&apos;", 6); break;
156
+ case '<': buf_append_string(&b->buf, "&lt;", 4); break;
157
+ case '>': buf_append_string(&b->buf, "&gt;", 4); break;
158
+ default:
159
+ // Must be one of the invalid characters.
160
+ if (!strip_invalid_chars) {
161
+ rb_raise(ox_syntax_error_class, "'\\#x%02x' is not a valid XML character.", *str);
162
+ }
163
+ break;
164
+ }
165
+ }
166
+ }
167
+ if (buf < bp) {
168
+ buf_append_string(&b->buf, buf, bp - buf);
169
+ bp = buf;
170
+ }
183
171
  }
184
172
  }
185
173
 
186
- static void
187
- append_sym_str(Builder b, VALUE v) {
188
- const char *s;
189
- long len;
174
+ static void append_sym_str(Builder b, VALUE v) {
175
+ const char *s;
176
+ long len;
190
177
 
191
178
  switch (rb_type(v)) {
192
179
  case T_STRING:
193
- s = StringValuePtr(v);
194
- len = RSTRING_LEN(v);
195
- break;
180
+ s = StringValuePtr(v);
181
+ len = RSTRING_LEN(v);
182
+ break;
196
183
  case T_SYMBOL:
197
- s = rb_id2name(SYM2ID(v));
198
- len = strlen(s);
199
- break;
200
- default:
201
- rb_raise(ox_arg_error_class, "expected a Symbol or String");
202
- break;
184
+ s = rb_id2name(SYM2ID(v));
185
+ len = strlen(s);
186
+ break;
187
+ default: rb_raise(ox_arg_error_class, "expected a Symbol or String"); break;
203
188
  }
204
189
  append_string(b, s, len, xml_element_chars, false);
205
190
  }
206
191
 
207
- static void
208
- i_am_a_child(Builder b, bool is_text) {
192
+ static void i_am_a_child(Builder b, bool is_text) {
209
193
  if (0 <= b->depth) {
210
- Element e = &b->stack[b->depth];
211
-
212
- if (!e->has_child) {
213
- e->has_child = true;
214
- buf_append(&b->buf, '>');
215
- b->col++;
216
- b->pos++;
217
- }
218
- if (!is_text) {
219
- e->non_text_child = true;
220
- }
194
+ Element e = &b->stack[b->depth];
195
+
196
+ if (!e->has_child) {
197
+ e->has_child = true;
198
+ buf_append(&b->buf, '>');
199
+ b->col++;
200
+ b->pos++;
201
+ }
202
+ if (!is_text) {
203
+ e->non_text_child = true;
204
+ }
221
205
  }
222
206
  }
223
207
 
224
- static int
225
- append_attr(VALUE key, VALUE value, VALUE bv) {
226
- Builder b = (Builder)bv;
208
+ static int append_attr(VALUE key, VALUE value, VALUE bv) {
209
+ Builder b = (Builder)bv;
227
210
 
228
211
  buf_append(&b->buf, ' ');
229
212
  b->col++;
@@ -241,100 +224,95 @@ append_attr(VALUE key, VALUE value, VALUE bv) {
241
224
  return ST_CONTINUE;
242
225
  }
243
226
 
244
- static void
245
- init(Builder b, int fd, int indent, long initial_size) {
227
+ static void init(Builder b, int fd, int indent, long initial_size) {
246
228
  buf_init(&b->buf, fd, initial_size);
247
- b->indent = indent;
229
+ b->indent = indent;
248
230
  *b->encoding = '\0';
249
- b->depth = -1;
250
- b->line = 1;
251
- b->col = 1;
252
- b->pos = 0;
231
+ b->depth = -1;
232
+ b->line = 1;
233
+ b->col = 1;
234
+ b->pos = 0;
253
235
  }
254
236
 
255
- static void
256
- builder_free(void *ptr) {
257
- Builder b;
258
- Element e;
259
- int d;
237
+ static void builder_free(void *ptr) {
238
+ Builder b;
239
+ Element e;
240
+ int d;
260
241
 
261
242
  if (0 == ptr) {
262
- return;
243
+ return;
263
244
  }
264
245
  b = (Builder)ptr;
265
246
  buf_cleanup(&b->buf);
266
247
  for (e = b->stack, d = b->depth; 0 < d; d--, e++) {
267
- if (e->name != e->buf) {
268
- free(e->name);
269
- }
248
+ if (e->name != e->buf) {
249
+ free(e->name);
250
+ }
270
251
  }
271
252
  xfree(ptr);
272
253
  }
273
254
 
274
- static void
275
- pop(Builder b) {
276
- Element e;
255
+ static void pop(Builder b) {
256
+ Element e;
277
257
 
278
258
  if (0 > b->depth) {
279
- rb_raise(ox_arg_error_class, "closed too many elements");
259
+ rb_raise(ox_arg_error_class, "closed too many elements");
280
260
  }
281
261
  e = &b->stack[b->depth];
282
262
  b->depth--;
283
263
  if (e->has_child) {
284
- if (e->non_text_child) {
285
- append_indent(b);
286
- }
287
- buf_append_string(&b->buf, "</", 2);
288
- append_string(b, e->name, e->len, xml_element_chars, false);
289
- buf_append(&b->buf, '>');
290
- b->col += e->len + 3;
291
- b->pos += e->len + 3;
292
- if (e->buf != e->name) {
293
- free(e->name);
294
- e->name = 0;
295
- }
264
+ if (e->non_text_child) {
265
+ append_indent(b);
266
+ }
267
+ buf_append_string(&b->buf, "</", 2);
268
+ append_string(b, e->name, e->len, xml_element_chars, false);
269
+ buf_append(&b->buf, '>');
270
+ b->col += e->len + 3;
271
+ b->pos += e->len + 3;
272
+ if (e->buf != e->name) {
273
+ free(e->name);
274
+ e->name = 0;
275
+ }
296
276
  } else {
297
- buf_append_string(&b->buf, "/>", 2);
298
- b->col += 2;
299
- b->pos += 2;
277
+ buf_append_string(&b->buf, "/>", 2);
278
+ b->col += 2;
279
+ b->pos += 2;
300
280
  }
301
281
  }
302
282
 
303
- static void
304
- bclose(Builder b) {
283
+ static void bclose(Builder b) {
305
284
  while (0 <= b->depth) {
306
- pop(b);
285
+ pop(b);
307
286
  }
308
287
  if (0 <= b->indent) {
309
- buf_append(&b->buf, '\n');
288
+ buf_append(&b->buf, '\n');
310
289
  }
311
290
  b->line++;
312
291
  b->col = 1;
313
292
  b->pos++;
314
293
  buf_finish(&b->buf);
315
294
  if (NULL != b->file) {
316
- fclose(b->file);
295
+ fclose(b->file);
317
296
  }
318
297
  }
319
298
 
320
- static VALUE
321
- to_s(Builder b) {
322
- volatile VALUE rstr;
299
+ static VALUE to_s(Builder b) {
300
+ volatile VALUE rstr;
323
301
 
324
302
  if (0 != b->buf.fd) {
325
- rb_raise(ox_arg_error_class, "can not create a String with a stream or file builder.");
303
+ rb_raise(ox_arg_error_class, "can not create a String with a stream or file builder.");
326
304
  }
327
305
  if (0 <= b->indent && '\n' != *(b->buf.tail - 1)) {
328
- buf_append(&b->buf, '\n');
329
- b->line++;
330
- b->col = 1;
331
- b->pos++;
306
+ buf_append(&b->buf, '\n');
307
+ b->line++;
308
+ b->col = 1;
309
+ b->pos++;
332
310
  }
333
- *b->buf.tail = '\0'; // for debugging
334
- rstr = rb_str_new(b->buf.head, buf_len(&b->buf));
311
+ *b->buf.tail = '\0'; // for debugging
312
+ rstr = rb_str_new(b->buf.head, buf_len(&b->buf));
335
313
 
336
314
  if ('\0' != *b->encoding) {
337
- rb_enc_associate(rstr, rb_enc_find(b->encoding));
315
+ rb_enc_associate(rstr, rb_enc_find(b->encoding));
338
316
  }
339
317
  return rstr;
340
318
  }
@@ -349,49 +327,48 @@ to_s(Builder b) {
349
327
  * - +:indent+ (Fixnum) indentaion level, negative values excludes terminating newline
350
328
  * - +:size+ (Fixnum) the initial size of the string buffer
351
329
  */
352
- static VALUE
353
- builder_new(int argc, VALUE *argv, VALUE self) {
354
- Builder b = ALLOC(struct _builder);
355
- int indent = ox_default_options.indent;
356
- long buf_size = 0;
330
+ static VALUE builder_new(int argc, VALUE *argv, VALUE self) {
331
+ Builder b = ALLOC(struct _builder);
332
+ int indent = ox_default_options.indent;
333
+ long buf_size = 0;
357
334
 
358
335
  if (1 == argc) {
359
- volatile VALUE v;
336
+ volatile VALUE v;
360
337
 
361
- rb_check_type(*argv, T_HASH);
362
- if (Qnil != (v = rb_hash_lookup(*argv, ox_indent_sym))) {
338
+ rb_check_type(*argv, T_HASH);
339
+ if (Qnil != (v = rb_hash_lookup(*argv, ox_indent_sym))) {
363
340
  #ifdef RUBY_INTEGER_UNIFICATION
364
- if (rb_cInteger != rb_obj_class(v)) {
341
+ if (rb_cInteger != rb_obj_class(v)) {
365
342
  #else
366
- if (rb_cFixnum != rb_obj_class(v)) {
343
+ if (rb_cFixnum != rb_obj_class(v)) {
367
344
  #endif
368
- rb_raise(ox_parse_error_class, ":indent must be a fixnum.\n");
369
- }
370
- indent = NUM2INT(v);
371
- }
372
- if (Qnil != (v = rb_hash_lookup(*argv, ox_size_sym))) {
345
+ rb_raise(ox_parse_error_class, ":indent must be a fixnum.\n");
346
+ }
347
+ indent = NUM2INT(v);
348
+ }
349
+ if (Qnil != (v = rb_hash_lookup(*argv, ox_size_sym))) {
373
350
  #ifdef RUBY_INTEGER_UNIFICATION
374
- if (rb_cInteger != rb_obj_class(v)) {
351
+ if (rb_cInteger != rb_obj_class(v)) {
375
352
  #else
376
- if (rb_cFixnum != rb_obj_class(v)) {
353
+ if (rb_cFixnum != rb_obj_class(v)) {
377
354
  #endif
378
- rb_raise(ox_parse_error_class, ":size must be a fixnum.\n");
379
- }
380
- buf_size = NUM2LONG(v);
381
- }
355
+ rb_raise(ox_parse_error_class, ":size must be a fixnum.\n");
356
+ }
357
+ buf_size = NUM2LONG(v);
358
+ }
382
359
  }
383
360
  b->file = NULL;
384
361
  init(b, 0, indent, buf_size);
385
362
 
386
363
  if (rb_block_given_p()) {
387
- volatile VALUE rb = Data_Wrap_Struct(builder_class, NULL, builder_free, b);
364
+ volatile VALUE rb = Data_Wrap_Struct(builder_class, NULL, builder_free, b);
388
365
 
389
- rb_yield(rb);
390
- bclose(b);
366
+ rb_yield(rb);
367
+ bclose(b);
391
368
 
392
- return to_s(b);
369
+ return to_s(b);
393
370
  } else {
394
- return Data_Wrap_Struct(builder_class, NULL, builder_free, b);
371
+ return Data_Wrap_Struct(builder_class, NULL, builder_free, b);
395
372
  }
396
373
  }
397
374
 
@@ -404,56 +381,55 @@ builder_new(int argc, VALUE *argv, VALUE self) {
404
381
  * - +:indent+ (Fixnum) indentaion level, negative values excludes terminating newline
405
382
  * - +:size+ (Fixnum) the initial size of the string buffer
406
383
  */
407
- static VALUE
408
- builder_file(int argc, VALUE *argv, VALUE self) {
409
- Builder b = ALLOC(struct _builder);
410
- int indent = ox_default_options.indent;
411
- long buf_size = 0;
412
- FILE *f;
384
+ static VALUE builder_file(int argc, VALUE *argv, VALUE self) {
385
+ Builder b = ALLOC(struct _builder);
386
+ int indent = ox_default_options.indent;
387
+ long buf_size = 0;
388
+ FILE *f;
413
389
 
414
390
  if (1 > argc) {
415
- rb_raise(ox_arg_error_class, "missing filename");
391
+ rb_raise(ox_arg_error_class, "missing filename");
416
392
  }
417
393
  Check_Type(*argv, T_STRING);
418
394
  if (NULL == (f = fopen(StringValuePtr(*argv), "w"))) {
419
- xfree(b);
420
- rb_raise(rb_eIOError, "%s\n", strerror(errno));
395
+ xfree(b);
396
+ rb_raise(rb_eIOError, "%s\n", strerror(errno));
421
397
  }
422
398
  if (2 == argc) {
423
- volatile VALUE v;
399
+ volatile VALUE v;
424
400
 
425
- rb_check_type(argv[1], T_HASH);
426
- if (Qnil != (v = rb_hash_lookup(argv[1], ox_indent_sym))) {
401
+ rb_check_type(argv[1], T_HASH);
402
+ if (Qnil != (v = rb_hash_lookup(argv[1], ox_indent_sym))) {
427
403
  #ifdef RUBY_INTEGER_UNIFICATION
428
- if (rb_cInteger != rb_obj_class(v)) {
404
+ if (rb_cInteger != rb_obj_class(v)) {
429
405
  #else
430
- if (rb_cFixnum != rb_obj_class(v)) {
406
+ if (rb_cFixnum != rb_obj_class(v)) {
431
407
  #endif
432
- rb_raise(ox_parse_error_class, ":indent must be a fixnum.\n");
433
- }
434
- indent = NUM2INT(v);
435
- }
436
- if (Qnil != (v = rb_hash_lookup(argv[1], ox_size_sym))) {
408
+ rb_raise(ox_parse_error_class, ":indent must be a fixnum.\n");
409
+ }
410
+ indent = NUM2INT(v);
411
+ }
412
+ if (Qnil != (v = rb_hash_lookup(argv[1], ox_size_sym))) {
437
413
  #ifdef RUBY_INTEGER_UNIFICATION
438
- if (rb_cInteger != rb_obj_class(v)) {
414
+ if (rb_cInteger != rb_obj_class(v)) {
439
415
  #else
440
- if (rb_cFixnum != rb_obj_class(v)) {
416
+ if (rb_cFixnum != rb_obj_class(v)) {
441
417
  #endif
442
- rb_raise(ox_parse_error_class, ":size must be a fixnum.\n");
443
- }
444
- buf_size = NUM2LONG(v);
445
- }
418
+ rb_raise(ox_parse_error_class, ":size must be a fixnum.\n");
419
+ }
420
+ buf_size = NUM2LONG(v);
421
+ }
446
422
  }
447
423
  b->file = f;
448
424
  init(b, fileno(f), indent, buf_size);
449
425
 
450
426
  if (rb_block_given_p()) {
451
- volatile VALUE rb = Data_Wrap_Struct(builder_class, NULL, builder_free, b);
452
- rb_yield(rb);
453
- bclose(b);
454
- return Qnil;
427
+ volatile VALUE rb = Data_Wrap_Struct(builder_class, NULL, builder_free, b);
428
+ rb_yield(rb);
429
+ bclose(b);
430
+ return Qnil;
455
431
  } else {
456
- return Data_Wrap_Struct(builder_class, NULL, builder_free, b);
432
+ return Data_Wrap_Struct(builder_class, NULL, builder_free, b);
457
433
  }
458
434
  }
459
435
 
@@ -466,57 +442,55 @@ builder_file(int argc, VALUE *argv, VALUE self) {
466
442
  * - +:indent+ (Fixnum) indentaion level, negative values excludes terminating newline
467
443
  * - +:size+ (Fixnum) the initial size of the string buffer
468
444
  */
469
- static VALUE
470
- builder_io(int argc, VALUE *argv, VALUE self) {
471
- Builder b = ALLOC(struct _builder);
472
- int indent = ox_default_options.indent;
473
- long buf_size = 0;
474
- int fd;
475
- volatile VALUE v;
445
+ static VALUE builder_io(int argc, VALUE *argv, VALUE self) {
446
+ Builder b = ALLOC(struct _builder);
447
+ int indent = ox_default_options.indent;
448
+ long buf_size = 0;
449
+ int fd;
450
+ volatile VALUE v;
476
451
 
477
452
  if (1 > argc) {
478
- rb_raise(ox_arg_error_class, "missing IO object");
453
+ rb_raise(ox_arg_error_class, "missing IO object");
479
454
  }
480
- if (!rb_respond_to(*argv, ox_fileno_id) ||
481
- Qnil == (v = rb_funcall(*argv, ox_fileno_id, 0)) ||
482
- 0 == (fd = FIX2INT(v))) {
483
- rb_raise(rb_eIOError, "expected an IO that has a fileno.");
455
+ if (!rb_respond_to(*argv, ox_fileno_id) || Qnil == (v = rb_funcall(*argv, ox_fileno_id, 0)) ||
456
+ 0 == (fd = FIX2INT(v))) {
457
+ rb_raise(rb_eIOError, "expected an IO that has a fileno.");
484
458
  }
485
459
  if (2 == argc) {
486
- volatile VALUE v;
460
+ volatile VALUE v;
487
461
 
488
- rb_check_type(argv[1], T_HASH);
489
- if (Qnil != (v = rb_hash_lookup(argv[1], ox_indent_sym))) {
462
+ rb_check_type(argv[1], T_HASH);
463
+ if (Qnil != (v = rb_hash_lookup(argv[1], ox_indent_sym))) {
490
464
  #ifdef RUBY_INTEGER_UNIFICATION
491
- if (rb_cInteger != rb_obj_class(v)) {
465
+ if (rb_cInteger != rb_obj_class(v)) {
492
466
  #else
493
- if (rb_cFixnum != rb_obj_class(v)) {
467
+ if (rb_cFixnum != rb_obj_class(v)) {
494
468
  #endif
495
- rb_raise(ox_parse_error_class, ":indent must be a fixnum.\n");
496
- }
497
- indent = NUM2INT(v);
498
- }
499
- if (Qnil != (v = rb_hash_lookup(argv[1], ox_size_sym))) {
469
+ rb_raise(ox_parse_error_class, ":indent must be a fixnum.\n");
470
+ }
471
+ indent = NUM2INT(v);
472
+ }
473
+ if (Qnil != (v = rb_hash_lookup(argv[1], ox_size_sym))) {
500
474
  #ifdef RUBY_INTEGER_UNIFICATION
501
- if (rb_cInteger != rb_obj_class(v)) {
475
+ if (rb_cInteger != rb_obj_class(v)) {
502
476
  #else
503
- if (rb_cFixnum != rb_obj_class(v)) {
477
+ if (rb_cFixnum != rb_obj_class(v)) {
504
478
  #endif
505
- rb_raise(ox_parse_error_class, ":size must be a fixnum.\n");
506
- }
507
- buf_size = NUM2LONG(v);
508
- }
479
+ rb_raise(ox_parse_error_class, ":size must be a fixnum.\n");
480
+ }
481
+ buf_size = NUM2LONG(v);
482
+ }
509
483
  }
510
484
  b->file = NULL;
511
485
  init(b, fd, indent, buf_size);
512
486
 
513
487
  if (rb_block_given_p()) {
514
- volatile VALUE rb = Data_Wrap_Struct(builder_class, NULL, builder_free, b);
515
- rb_yield(rb);
516
- bclose(b);
517
- return Qnil;
488
+ volatile VALUE rb = Data_Wrap_Struct(builder_class, NULL, builder_free, b);
489
+ rb_yield(rb);
490
+ bclose(b);
491
+ return Qnil;
518
492
  } else {
519
- return Data_Wrap_Struct(builder_class, NULL, builder_free, b);
493
+ return Data_Wrap_Struct(builder_class, NULL, builder_free, b);
520
494
  }
521
495
  }
522
496
 
@@ -527,65 +501,64 @@ builder_io(int argc, VALUE *argv, VALUE self) {
527
501
  * - +decl+ - (String) 'xml' expected
528
502
  * - +options+ - (Hash) version or encoding
529
503
  */
530
- static VALUE
531
- builder_instruct(int argc, VALUE *argv, VALUE self) {
532
- Builder b = (Builder)DATA_PTR(self);
504
+ static VALUE builder_instruct(int argc, VALUE *argv, VALUE self) {
505
+ Builder b = (Builder)DATA_PTR(self);
533
506
 
534
507
  i_am_a_child(b, false);
535
508
  append_indent(b);
536
509
  if (0 == argc) {
537
- buf_append_string(&b->buf, "<?xml?>", 7);
538
- b->col += 7;
539
- b->pos += 7;
510
+ buf_append_string(&b->buf, "<?xml?>", 7);
511
+ b->col += 7;
512
+ b->pos += 7;
540
513
  } else {
541
- volatile VALUE v;
542
-
543
- buf_append_string(&b->buf, "<?", 2);
544
- b->col += 2;
545
- b->pos += 2;
546
- append_sym_str(b, *argv);
547
- if (1 < argc && rb_cHash == rb_obj_class(argv[1])) {
548
- int len;
549
-
550
- if (Qnil != (v = rb_hash_lookup(argv[1], ox_version_sym))) {
551
- if (rb_cString != rb_obj_class(v)) {
552
- rb_raise(ox_parse_error_class, ":version must be a Symbol.\n");
553
- }
554
- len = (int)RSTRING_LEN(v);
555
- buf_append_string(&b->buf, " version=\"", 10);
556
- buf_append_string(&b->buf, StringValuePtr(v), len);
557
- buf_append(&b->buf, '"');
558
- b->col += len + 11;
559
- b->pos += len + 11;
560
- }
561
- if (Qnil != (v = rb_hash_lookup(argv[1], ox_encoding_sym))) {
562
- if (rb_cString != rb_obj_class(v)) {
563
- rb_raise(ox_parse_error_class, ":encoding must be a Symbol.\n");
564
- }
565
- len = (int)RSTRING_LEN(v);
566
- buf_append_string(&b->buf, " encoding=\"", 11);
567
- buf_append_string(&b->buf, StringValuePtr(v), len);
568
- buf_append(&b->buf, '"');
569
- b->col += len + 12;
570
- b->pos += len + 12;
571
- strncpy(b->encoding, StringValuePtr(v), sizeof(b->encoding));
572
- b->encoding[sizeof(b->encoding) - 1] = '\0';
573
- }
574
- if (Qnil != (v = rb_hash_lookup(argv[1], ox_standalone_sym))) {
575
- if (rb_cString != rb_obj_class(v)) {
576
- rb_raise(ox_parse_error_class, ":standalone must be a Symbol.\n");
577
- }
578
- len = (int)RSTRING_LEN(v);
579
- buf_append_string(&b->buf, " standalone=\"", 13);
580
- buf_append_string(&b->buf, StringValuePtr(v), len);
581
- buf_append(&b->buf, '"');
582
- b->col += len + 14;
583
- b->pos += len + 14;
584
- }
585
- }
586
- buf_append_string(&b->buf, "?>", 2);
587
- b->col += 2;
588
- b->pos += 2;
514
+ volatile VALUE v;
515
+
516
+ buf_append_string(&b->buf, "<?", 2);
517
+ b->col += 2;
518
+ b->pos += 2;
519
+ append_sym_str(b, *argv);
520
+ if (1 < argc && rb_cHash == rb_obj_class(argv[1])) {
521
+ int len;
522
+
523
+ if (Qnil != (v = rb_hash_lookup(argv[1], ox_version_sym))) {
524
+ if (rb_cString != rb_obj_class(v)) {
525
+ rb_raise(ox_parse_error_class, ":version must be a Symbol.\n");
526
+ }
527
+ len = (int)RSTRING_LEN(v);
528
+ buf_append_string(&b->buf, " version=\"", 10);
529
+ buf_append_string(&b->buf, StringValuePtr(v), len);
530
+ buf_append(&b->buf, '"');
531
+ b->col += len + 11;
532
+ b->pos += len + 11;
533
+ }
534
+ if (Qnil != (v = rb_hash_lookup(argv[1], ox_encoding_sym))) {
535
+ if (rb_cString != rb_obj_class(v)) {
536
+ rb_raise(ox_parse_error_class, ":encoding must be a Symbol.\n");
537
+ }
538
+ len = (int)RSTRING_LEN(v);
539
+ buf_append_string(&b->buf, " encoding=\"", 11);
540
+ buf_append_string(&b->buf, StringValuePtr(v), len);
541
+ buf_append(&b->buf, '"');
542
+ b->col += len + 12;
543
+ b->pos += len + 12;
544
+ strncpy(b->encoding, StringValuePtr(v), sizeof(b->encoding));
545
+ b->encoding[sizeof(b->encoding) - 1] = '\0';
546
+ }
547
+ if (Qnil != (v = rb_hash_lookup(argv[1], ox_standalone_sym))) {
548
+ if (rb_cString != rb_obj_class(v)) {
549
+ rb_raise(ox_parse_error_class, ":standalone must be a Symbol.\n");
550
+ }
551
+ len = (int)RSTRING_LEN(v);
552
+ buf_append_string(&b->buf, " standalone=\"", 13);
553
+ buf_append_string(&b->buf, StringValuePtr(v), len);
554
+ buf_append(&b->buf, '"');
555
+ b->col += len + 14;
556
+ b->pos += len + 14;
557
+ }
558
+ }
559
+ buf_append_string(&b->buf, "?>", 2);
560
+ b->col += 2;
561
+ b->pos += 2;
589
562
  }
590
563
  return Qnil;
591
564
  }
@@ -598,45 +571,42 @@ builder_instruct(int argc, VALUE *argv, VALUE self) {
598
571
  * - +name+ - (String) name of the element
599
572
  * - +attributes+ - (Hash) of the element
600
573
  */
601
- static VALUE
602
- builder_element(int argc, VALUE *argv, VALUE self) {
603
- Builder b = (Builder)DATA_PTR(self);
604
- Element e;
605
- const char *name;
606
- long len;
574
+ static VALUE builder_element(int argc, VALUE *argv, VALUE self) {
575
+ Builder b = (Builder)DATA_PTR(self);
576
+ Element e;
577
+ const char *name;
578
+ long len;
607
579
 
608
580
  if (1 > argc) {
609
- rb_raise(ox_arg_error_class, "missing element name");
581
+ rb_raise(ox_arg_error_class, "missing element name");
610
582
  }
611
583
  i_am_a_child(b, false);
612
584
  append_indent(b);
613
585
  b->depth++;
614
586
  if (MAX_DEPTH <= b->depth) {
615
- rb_raise(ox_arg_error_class, "XML too deeply nested");
587
+ rb_raise(ox_arg_error_class, "XML too deeply nested");
616
588
  }
617
589
  switch (rb_type(*argv)) {
618
590
  case T_STRING:
619
- name = StringValuePtr(*argv);
620
- len = RSTRING_LEN(*argv);
621
- break;
591
+ name = StringValuePtr(*argv);
592
+ len = RSTRING_LEN(*argv);
593
+ break;
622
594
  case T_SYMBOL:
623
- name = rb_id2name(SYM2ID(*argv));
624
- len = strlen(name);
625
- break;
626
- default:
627
- rb_raise(ox_arg_error_class, "expected a Symbol or String for an element name");
628
- break;
595
+ name = rb_id2name(SYM2ID(*argv));
596
+ len = strlen(name);
597
+ break;
598
+ default: rb_raise(ox_arg_error_class, "expected a Symbol or String for an element name"); break;
629
599
  }
630
600
  e = &b->stack[b->depth];
631
601
  if (sizeof(e->buf) <= (size_t)len) {
632
- e->name = strdup(name);
633
- *e->buf = '\0';
602
+ e->name = strdup(name);
603
+ *e->buf = '\0';
634
604
  } else {
635
- strcpy(e->buf, name);
636
- e->name = e->buf;
605
+ strcpy(e->buf, name);
606
+ e->name = e->buf;
637
607
  }
638
- e->len = len;
639
- e->has_child = false;
608
+ e->len = len;
609
+ e->has_child = false;
640
610
  e->non_text_child = false;
641
611
 
642
612
  buf_append(&b->buf, '<');
@@ -644,12 +614,12 @@ builder_element(int argc, VALUE *argv, VALUE self) {
644
614
  b->pos++;
645
615
  append_string(b, e->name, len, xml_element_chars, false);
646
616
  if (1 < argc && T_HASH == rb_type(argv[1])) {
647
- rb_hash_foreach(argv[1], append_attr, (VALUE)b);
617
+ rb_hash_foreach(argv[1], append_attr, (VALUE)b);
648
618
  }
649
619
  // Do not close with > or /> yet. That is done with i_am_a_child() or pop().
650
620
  if (rb_block_given_p()) {
651
- rb_yield(self);
652
- pop(b);
621
+ rb_yield(self);
622
+ pop(b);
653
623
  }
654
624
  return Qnil;
655
625
  }
@@ -661,39 +631,37 @@ builder_element(int argc, VALUE *argv, VALUE self) {
661
631
  * - +name+ - (String) name of the element
662
632
  * - +attributes+ - (Hash) of the element
663
633
  */
664
- static VALUE
665
- builder_void_element(int argc, VALUE *argv, VALUE self) {
666
- Builder b = (Builder)DATA_PTR(self);
667
- const char *name;
668
- long len;
634
+ static VALUE builder_void_element(int argc, VALUE *argv, VALUE self) {
635
+ Builder b = (Builder)DATA_PTR(self);
636
+ const char *name;
637
+ long len;
669
638
 
670
639
  if (1 > argc) {
671
- rb_raise(ox_arg_error_class, "missing element name");
640
+ rb_raise(ox_arg_error_class, "missing element name");
672
641
  }
673
642
  i_am_a_child(b, false);
674
643
  append_indent(b);
675
644
  switch (rb_type(*argv)) {
676
645
  case T_STRING:
677
- name = StringValuePtr(*argv);
678
- len = RSTRING_LEN(*argv);
679
- break;
646
+ name = StringValuePtr(*argv);
647
+ len = RSTRING_LEN(*argv);
648
+ break;
680
649
  case T_SYMBOL:
681
- name = rb_id2name(SYM2ID(*argv));
682
- len = strlen(name);
683
- break;
684
- default:
685
- rb_raise(ox_arg_error_class, "expected a Symbol or String for an element name");
686
- break;
650
+ name = rb_id2name(SYM2ID(*argv));
651
+ len = strlen(name);
652
+ break;
653
+ default: rb_raise(ox_arg_error_class, "expected a Symbol or String for an element name"); break;
687
654
  }
688
655
  buf_append(&b->buf, '<');
689
656
  b->col++;
690
657
  b->pos++;
691
658
  append_string(b, name, len, xml_element_chars, false);
692
659
  if (1 < argc && T_HASH == rb_type(argv[1])) {
693
- rb_hash_foreach(argv[1], append_attr, (VALUE)b);
660
+ rb_hash_foreach(argv[1], append_attr, (VALUE)b);
694
661
  }
695
662
  buf_append_string(&b->buf, ">", 1);
696
- b->col++;;
663
+ b->col++;
664
+ ;
697
665
  b->pos++;
698
666
 
699
667
  return Qnil;
@@ -704,9 +672,8 @@ builder_void_element(int argc, VALUE *argv, VALUE self) {
704
672
  * Adds a comment element to the XML string being formed.
705
673
  * - +text+ - (String) contents of the comment
706
674
  */
707
- static VALUE
708
- builder_comment(VALUE self, VALUE text) {
709
- Builder b = (Builder)DATA_PTR(self);
675
+ static VALUE builder_comment(VALUE self, VALUE text) {
676
+ Builder b = (Builder)DATA_PTR(self);
710
677
 
711
678
  rb_check_type(text, T_STRING);
712
679
  i_am_a_child(b, false);
@@ -727,9 +694,8 @@ builder_comment(VALUE self, VALUE text) {
727
694
  * Adds a DOCTYPE element to the XML string being formed.
728
695
  * - +text+ - (String) contents of the doctype
729
696
  */
730
- static VALUE
731
- builder_doctype(VALUE self, VALUE text) {
732
- Builder b = (Builder)DATA_PTR(self);
697
+ static VALUE builder_doctype(VALUE self, VALUE text) {
698
+ Builder b = (Builder)DATA_PTR(self);
733
699
 
734
700
  rb_check_type(text, T_STRING);
735
701
  i_am_a_child(b, false);
@@ -751,24 +717,23 @@ builder_doctype(VALUE self, VALUE text) {
751
717
  * - +text+ - (String) contents of the text field
752
718
  * - +strip_invalid_chars+ - [true|false] strips any characters invalid for XML, defaults to false
753
719
  */
754
- static VALUE
755
- builder_text(int argc, VALUE *argv, VALUE self) {
756
- Builder b = (Builder)DATA_PTR(self);
757
- volatile VALUE v;
758
- volatile VALUE strip_invalid_chars;
720
+ static VALUE builder_text(int argc, VALUE *argv, VALUE self) {
721
+ Builder b = (Builder)DATA_PTR(self);
722
+ volatile VALUE v;
723
+ volatile VALUE strip_invalid_chars;
759
724
 
760
725
  if ((0 == argc) || (argc > 2)) {
761
- rb_raise(rb_eArgError, "wrong number of arguments (given %d, expected 1..2)", argc);
726
+ rb_raise(rb_eArgError, "wrong number of arguments (given %d, expected 1..2)", argc);
762
727
  }
763
728
  v = argv[0];
764
729
  if (2 == argc) {
765
- strip_invalid_chars = argv[1];
730
+ strip_invalid_chars = argv[1];
766
731
  } else {
767
- strip_invalid_chars = Qfalse;
732
+ strip_invalid_chars = Qfalse;
768
733
  }
769
734
 
770
735
  if (T_STRING != rb_type(v)) {
771
- v = rb_funcall(v, ox_to_s_id, 0);
736
+ v = rb_funcall(v, ox_to_s_id, 0);
772
737
  }
773
738
  i_am_a_child(b, true);
774
739
  append_string(b, StringValuePtr(v), RSTRING_LEN(v), xml_element_chars, RTEST(strip_invalid_chars));
@@ -781,21 +746,20 @@ builder_text(int argc, VALUE *argv, VALUE self) {
781
746
  * Adds a CDATA element to the XML string being formed.
782
747
  * - +data+ - (String) contents of the CDATA element
783
748
  */
784
- static VALUE
785
- builder_cdata(VALUE self, VALUE data) {
786
- Builder b = (Builder)DATA_PTR(self);
787
- volatile VALUE v = data;
788
- const char *str;
789
- const char *s;
790
- const char *end;
791
- int len;
749
+ static VALUE builder_cdata(VALUE self, VALUE data) {
750
+ Builder b = (Builder)DATA_PTR(self);
751
+ volatile VALUE v = data;
752
+ const char *str;
753
+ const char *s;
754
+ const char *end;
755
+ int len;
792
756
 
793
757
  if (T_STRING != rb_type(v)) {
794
- v = rb_funcall(v, ox_to_s_id, 0);
758
+ v = rb_funcall(v, ox_to_s_id, 0);
795
759
  }
796
760
  str = StringValuePtr(v);
797
761
  len = (int)RSTRING_LEN(v);
798
- s = str;
762
+ s = str;
799
763
  end = str + len;
800
764
  i_am_a_child(b, false);
801
765
  append_indent(b);
@@ -808,7 +772,7 @@ builder_cdata(VALUE self, VALUE data) {
808
772
  while (NULL != s) {
809
773
  b->line++;
810
774
  b->col = end - s;
811
- s = strchr(s + 1, '\n');
775
+ s = strchr(s + 1, '\n');
812
776
  }
813
777
  b->pos += len;
814
778
  buf_append_string(&b->buf, "]]>", 3);
@@ -824,21 +788,20 @@ builder_cdata(VALUE self, VALUE data) {
824
788
  *
825
789
  * - +text+ - (String) contents to be added
826
790
  */
827
- static VALUE
828
- builder_raw(VALUE self, VALUE text) {
829
- Builder b = (Builder)DATA_PTR(self);
830
- volatile VALUE v = text;
831
- const char *str;
832
- const char *s;
833
- const char *end;
834
- int len;
791
+ static VALUE builder_raw(VALUE self, VALUE text) {
792
+ Builder b = (Builder)DATA_PTR(self);
793
+ volatile VALUE v = text;
794
+ const char *str;
795
+ const char *s;
796
+ const char *end;
797
+ int len;
835
798
 
836
799
  if (T_STRING != rb_type(v)) {
837
- v = rb_funcall(v, ox_to_s_id, 0);
800
+ v = rb_funcall(v, ox_to_s_id, 0);
838
801
  }
839
802
  str = StringValuePtr(v);
840
803
  len = (int)RSTRING_LEN(v);
841
- s = str;
804
+ s = str;
842
805
  end = str + len;
843
806
  i_am_a_child(b, true);
844
807
  buf_append_string(&b->buf, str, len);
@@ -847,7 +810,7 @@ builder_raw(VALUE self, VALUE text) {
847
810
  while (NULL != s) {
848
811
  b->line++;
849
812
  b->col = end - s;
850
- s = strchr(s + 1, '\n');
813
+ s = strchr(s + 1, '\n');
851
814
  }
852
815
  b->pos += len;
853
816
 
@@ -858,8 +821,7 @@ builder_raw(VALUE self, VALUE text) {
858
821
  *
859
822
  * Returns the JSON document string in what ever state the construction is at.
860
823
  */
861
- static VALUE
862
- builder_to_s(VALUE self) {
824
+ static VALUE builder_to_s(VALUE self) {
863
825
  return to_s((Builder)DATA_PTR(self));
864
826
  }
865
827
 
@@ -867,8 +829,7 @@ builder_to_s(VALUE self) {
867
829
  *
868
830
  * Returns the current line in the output. The first line is line 1.
869
831
  */
870
- static VALUE
871
- builder_line(VALUE self) {
832
+ static VALUE builder_line(VALUE self) {
872
833
  return LONG2NUM(((Builder)DATA_PTR(self))->line);
873
834
  }
874
835
 
@@ -877,8 +838,7 @@ builder_line(VALUE self) {
877
838
  * Returns the current column in the output. The first character in a line is at
878
839
  * column 1.
879
840
  */
880
- static VALUE
881
- builder_column(VALUE self) {
841
+ static VALUE builder_column(VALUE self) {
882
842
  return LONG2NUM(((Builder)DATA_PTR(self))->col);
883
843
  }
884
844
 
@@ -886,8 +846,7 @@ builder_column(VALUE self) {
886
846
  *
887
847
  * Returns the indentation level
888
848
  */
889
- static VALUE
890
- builder_get_indent(VALUE self) {
849
+ static VALUE builder_get_indent(VALUE self) {
891
850
  return INT2NUM(((Builder)DATA_PTR(self))->indent);
892
851
  }
893
852
 
@@ -897,14 +856,13 @@ builder_get_indent(VALUE self) {
897
856
  *
898
857
  * - +indent+ (Fixnum) indentaion level, negative values excludes terminating newline
899
858
  */
900
- static VALUE
901
- builder_set_indent(VALUE self, VALUE indent) {
859
+ static VALUE builder_set_indent(VALUE self, VALUE indent) {
902
860
  #ifdef RUBY_INTEGER_UNIFICATION
903
861
  if (rb_cInteger != rb_obj_class(indent)) {
904
862
  #else
905
863
  if (rb_cFixnum != rb_obj_class(indent)) {
906
864
  #endif
907
- rb_raise(ox_parse_error_class, "indent must be a fixnum.\n");
865
+ rb_raise(ox_parse_error_class, "indent must be a fixnum.\n");
908
866
  }
909
867
 
910
868
  ((Builder)DATA_PTR(self))->indent = NUM2INT(indent);
@@ -915,8 +873,7 @@ builder_set_indent(VALUE self, VALUE indent) {
915
873
  *
916
874
  * Returns the number of bytes written.
917
875
  */
918
- static VALUE
919
- builder_pos(VALUE self) {
876
+ static VALUE builder_pos(VALUE self) {
920
877
  return LONG2NUM(((Builder)DATA_PTR(self))->pos);
921
878
  }
922
879
 
@@ -934,8 +891,7 @@ static VALUE builder_pop(VALUE self) {
934
891
  *
935
892
  * Closes the all elements and the document.
936
893
  */
937
- static VALUE
938
- builder_close(VALUE self) {
894
+ static VALUE builder_close(VALUE self) {
939
895
  bclose((Builder)DATA_PTR(self));
940
896
 
941
897
  return Qnil;
@@ -946,8 +902,7 @@ builder_close(VALUE self) {
946
902
  *
947
903
  * An XML builder.
948
904
  */
949
- void
950
- ox_init_builder(VALUE ox) {
905
+ void ox_init_builder(VALUE ox) {
951
906
  #if 0
952
907
  // Just for rdoc.
953
908
  ox = rb_define_module("Ox");