blob: 84990c0b6f0e86529e5d3bb8d6fb2d5f0faaeb9a (
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
|
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;
while ($line =~ /(\d+)/g) {
if ($is_backward) {
$previous_match_start = $-[0];
# if $point_position < $-[0]
# && previous $+[0] <= $point_position
# if ($point_position >= $-[0]) {
# $start_position = $-[0];
#
# last;
# }
}
else {
if ($point_position < $+[0]) {
$start_position = $-[0];
last;
}
}
}
if ($is_backward) {
$start_position = $previous_match_start;
}
pos($line) = $start_position;
$line =~ s/\G([^\d]*)(\d+)/$1 . ($2 + 1)/e;
return $line;
}
1;
|