blob: b05c54788911eaaf1bfa5a30b67ca67d741f447d (
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
 | use strict;
use warnings;
package incdec;
sub incdec {
	my ($line, $point_position, $is_backward) = @_;
	$point_position ||= 0;
	$is_backward ||= 0;
	my $start_position = 0;
	my @points = ();
	my $previous_match_start = 0;
	my $previous_match_end = 0;
	while ($line =~ /(\d+)/g) {
		if ($is_backward) {
			# print "pos[$point_position] -[$-[0]]- +[$+[0]]+\n";
			# if $point_position < $-[0]
			# && previous $+[0] <= $point_position
			# if ($previous_match_end <= $point_position && $point_position < $-[0]) {
			if ($-[0] <= $point_position && $point_position < $+[0]) {
				# print "matched";
				$start_position = $-[0];
				last;
			}
			$previous_match_start = $-[0];
			$previous_match_end = $+[0];
		}
		else {
		if ($point_position < $+[0]) {
			$start_position = $-[0];
			last;
		}
		}
	}
	if ($is_backward && $point_position == length $line) {
		$start_position = $previous_match_start;
	}
	pos($line) = $start_position;
	$line =~ s/\G([^\d]*)(\d+)/$1 . ($2 + 1)/e;
	return $line;
}
1;
 |