Class: MatchData

Inherits:
Object show all
Defined in:
opal/opal/corelib/marshal/write_buffer.rb,
opal/opal/corelib/regexp.rb
more...

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(regexp, match_groups, no_matchdata: false) ⇒ MatchData

Returns a new instance of MatchData.

[View source]

295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
# File 'opal/opal/corelib/regexp.rb', line 295

def initialize(regexp, match_groups, no_matchdata: false)
  $~          = self unless no_matchdata
  @regexp     = regexp
  @begin      = `match_groups.index`
  @string     = `match_groups.input`
  @pre_match  = `match_groups.input.slice(0, match_groups.index)`
  @post_match = `match_groups.input.slice(match_groups.index + match_groups[0].length)`
  @matches    = []

  %x{
    for (var i = 0, length = match_groups.length; i < length; i++) {
      var group = match_groups[i];

      if (group == null) {
        #{@matches}.push(nil);
      }
      else {
        #{@matches}.push(group);
      }
    }
  }
end

Instance Attribute Details

#post_matchObject (readonly)

Returns the value of attribute post_match.


293
294
295
# File 'opal/opal/corelib/regexp.rb', line 293

def post_match
  @post_match
end

#pre_matchObject (readonly)

Returns the value of attribute pre_match.


293
294
295
# File 'opal/opal/corelib/regexp.rb', line 293

def pre_match
  @pre_match
end

#regexpObject (readonly)

Returns the value of attribute regexp.


293
294
295
# File 'opal/opal/corelib/regexp.rb', line 293

def regexp
  @regexp
end

#stringObject (readonly)

Returns the value of attribute string.


293
294
295
# File 'opal/opal/corelib/regexp.rb', line 293

def string
  @string
end

Instance Method Details

#==(other) ⇒ Object Also known as: eql?

[View source]

353
354
355
356
357
358
359
360
361
# File 'opal/opal/corelib/regexp.rb', line 353

def ==(other)
  return false unless ::MatchData === other

  `self.string == other.string` &&
    `self.regexp.toString() == other.regexp.toString()` &&
    `self.pre_match == other.pre_match` &&
    `self.post_match == other.post_match` &&
    `self.begin == other.begin`
end

#[](*args) ⇒ Object

[View source]

330
331
332
333
334
335
336
337
338
339
340
341
342
# File 'opal/opal/corelib/regexp.rb', line 330

def [](*args)
  %x{
    if (args[0].$$is_string) {
      if (#{!regexp.names.include?(args[0])}) {
        #{::Kernel.raise ::IndexError, "undefined group name reference: #{args[0]}"}
      }
      return #{named_captures[args[0]]}
    }
    else {
      return #{@matches[*args]}
    }
  }
end

#__marshal__(buffer) ⇒ Object

[View source]

107
108
109
# File 'opal/opal/corelib/marshal/write_buffer.rb', line 107

def __marshal__(buffer)
  ::Kernel.raise ::TypeError, "no _dump_data is defined for class #{self.class}"
end

#begin(n) ⇒ Object

[View source]

363
364
365
366
367
368
369
370
# File 'opal/opal/corelib/regexp.rb', line 363

def begin(n)
  %x{
    if (n !== 0) {
      #{::Kernel.raise ::ArgumentError, 'MatchData#begin only supports 0th element'}
    }
    return self.begin;
  }
end

#capturesObject

[View source]

381
382
383
# File 'opal/opal/corelib/regexp.rb', line 381

def captures
  `#{@matches}.slice(1)`
end

#end(n) ⇒ Object

[View source]

372
373
374
375
376
377
378
379
# File 'opal/opal/corelib/regexp.rb', line 372

def end(n)
  %x{
    if (n !== 0) {
      #{::Kernel.raise ::ArgumentError, 'MatchData#end only supports 0th element'}
    }
    return self.begin + self.matches[n].length;
  }
end

#inspectObject

[View source]

396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
# File 'opal/opal/corelib/regexp.rb', line 396

def inspect
  %x{
    var str = "#<MatchData " + #{`#{@matches}[0]`.inspect};

    if (#{regexp.names.empty?}) {
      for (var i = 1, length = #{@matches}.length; i < length; i++) {
        str += " " + i + ":" + #{`#{@matches}[i]`.inspect};
      }
    }
    else {
      #{ named_captures.each do |k, v|
           %x{
             str += " " + #{k} + ":" + #{v.inspect}
           }
         end }
    }

    return str + ">";
  }
end

#lengthObject Also known as: size

[View source]

417
418
419
# File 'opal/opal/corelib/regexp.rb', line 417

def length
  `#{@matches}.length`
end

#match(idx) ⇒ Object

[View source]

318
319
320
321
322
323
324
# File 'opal/opal/corelib/regexp.rb', line 318

def match(idx)
  if (match = self[idx])
    match
  elsif idx.is_a?(Integer) && idx >= length
    ::Kernel.raise ::IndexError, "index #{idx} out of matches"
  end
end

#match_length(idx) ⇒ Object

[View source]

326
327
328
# File 'opal/opal/corelib/regexp.rb', line 326

def match_length(idx)
  match(idx)&.length
end

#named_capturesObject

[View source]

385
386
387
388
389
390
# File 'opal/opal/corelib/regexp.rb', line 385

def named_captures
  matches = captures
  regexp.named_captures.transform_values do |i|
    matches[i.last - 1]
  end
end

#namesObject

[View source]

392
393
394
# File 'opal/opal/corelib/regexp.rb', line 392

def names
  regexp.names
end

#offset(n) ⇒ Object

[View source]

344
345
346
347
348
349
350
351
# File 'opal/opal/corelib/regexp.rb', line 344

def offset(n)
  %x{
    if (n !== 0) {
      #{::Kernel.raise ::ArgumentError, 'MatchData#offset only supports 0th element'}
    }
    return [self.begin, self.begin + self.matches[n].length];
  }
end

#to_aObject

[View source]

421
422
423
# File 'opal/opal/corelib/regexp.rb', line 421

def to_a
  @matches
end

#to_sObject

[View source]

425
426
427
# File 'opal/opal/corelib/regexp.rb', line 425

def to_s
  `#{@matches}[0]`
end

#values_at(*args) ⇒ Object

[View source]

429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
# File 'opal/opal/corelib/regexp.rb', line 429

def values_at(*args)
  %x{
    var i, a, index, values = [];

    for (i = 0; i < args.length; i++) {

      if (args[i].$$is_range) {
        a = #{`args[i]`.to_a};
        a.unshift(i, 1);
        Array.prototype.splice.apply(args, a);
      }

      index = #{::Opal.coerce_to!(`args[i]`, ::Integer, :to_int)};

      if (index < 0) {
        index += #{@matches}.length;
        if (index < 0) {
          values.push(nil);
          continue;
        }
      }

      values.push(#{@matches}[index]);
    }

    return values;
  }
end