немного переписав его ... с моими предложениями и с использованием модификатора пробела, чтобы он действительно читался. :)
s{
(?:^|\G) # start of the last match, so you never backtrack and don't capture.
(?!//) # a section without //
(.*?) # followed by anything
(
http:// # with http://
[^\s]+ # and non-spaces - you could also use \S
)
}
{$1<$2>}xmg;
Пробуя это в Perl, мы получаем:
sub test {
my ($str, $expect) = @_;
my $mod = $str;
$mod =~ s{
(?:^|\G) # start of the last match, so you never backtrack.
(?!//) # a section without //
(.*?) # followed by anything
(
http:// # with http://
[^\s]+ # and non-spaces - you could also use \S
)
}
{$1<$2>}xmg;
print "Expecting '$expect' got '$mod' - ";
print $mod eq $expect ? "passed\n" : "failed\n";
}
test("http://foo.com", "<http://foo.com>");
test("// http://foo.com", "// http://foo.com");
test("foo\nhttp://a.com","foo\n<http://a.com>");
# output is
# Expecting '<http://foo.com>' got '<http://foo.com>' - passed
# Expecting '// http://foo.com' got '// http://foo.com' - passed
# Expecting 'foo
# <http://a.com>' got 'foo
# <http://a.com>' - passed
Редактировать: Пара изменений: добавлен модификатор 'm', чтобы убедиться, что он совпадает с начала строки, и измените \ G на (^ | \ G), чтобы убедиться, что он начинает смотреть в начале линия тоже.