aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Subst/Complex.pm
blob: 39db68822344ed9f8e0d7500e6646999f33a1532 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
# Copyright (C) 2008 Arne Georg Gleditsch <lxr@linux.no>.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License along
# with this program; if not, write to the Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
#
# The full GNU General Public License is included in this distribution
# in the file called COPYING.

package Subst::Complex;

use strict;

sub new {
    my ($self, @args) = @_;

    my (@re, @ac);
    my $l = 1;
    while (@args) {
	my ($r, $a) = splice(@args, 0, 2);
	"" =~ /|$r/;

	push(@ac, [$l+1, $l+1+$#+, $a]);
	$l += 1+$#+;

	push(@re, "($r)");
    }

    return bless {'re' => '((?s:.*?))(?:'.join('|', @re).')',
		  'ac' => \@ac}, $self;
}

sub s {
    my $self;
    my $str;

    if (ref($_[0])) {
	$self = shift;
	$str  = shift;
    }
    else {
	$str  = shift;
	$self = __PACKAGE__->new(@_);
    }

    my @res;
#    $str =~ s{$$self{'re'}}{
#	push(@res, $1) if length($1);
#	my ($a) = grep { defined $-[$$_[0]] } @{$$self{'ac'}};
#	my @g = map { substr($str, $-[$_], $+[$_] - $-[$_]);
#		  } $$a[0]..$$a[1];
#	push(@res, $$a[2]->(@g));
#	'';
#    }ge;
    $str =~ s{$$self{'re'}}{
	push(@res, $1) if length($1);
	my ($a) = grep { defined $-[$$_[0]] } @{$$self{'ac'}};
	my @g = map { substr($str, $-[$_], $+[$_] - $-[$_]);
		  } $$a[0]..$$a[1];
	push(@res, [$$a[2], [@g]]);
	'';
    }ge;

    push(@res, $str) if length($str);
    @res = map {
	ref($_) ? $$_[0]->(@{$$_[1]}) : $_
	} @res;
    
    return @res;
}

1;