in reply to Re: substitute characters in the RHS of a search & replace
in thread substitute characters in the RHS of a search & replace

Ah - I forgot you could do s/// on $1 - I guess the /r switch allows you to do it as it doesn't modify $1. Thanks, good call. I'll check it's supported on my version of perl.

  • Comment on Re^2: substitute characters in the RHS of a search & replace

Replies are listed 'Best First'.
Re^3: substitute characters in the RHS of a search & replace
by LanX (Saint) on Mar 08, 2013 at 23:57 UTC
    > I guess the /r switch allows you to do it as it doesn't modify $1. Thanks, good call. I'll check it's supported on my version of perl.

    If not try this instead:

    my $x = q{Here are [[a variable]] number [[of words]] in brackets}; say $x; $x =~ s{\[\[(.*?)\]\]}{ (my $x=$1) =~ s/ /_/g; $x }ge; say $x;

    added a /g to allow multiple chunks to be processed.

    Here are [[a variable]] number [[of words]] in brackets Here are a_variable number of_words in brackets

    But to improve readability I would rather opt against one-liner and call a function in the replacement part

    sub blank2under { my $x=shift; $x =~ s/ /_/g; return $x; }

    Cheers Rolf

    update

    and here a generic function to simulate /r

    sub rx (&$) { my $c_regex=shift; local $_=shift; $c_regex->(); return $_ } my $x = q{Here are [[a variable]] number [[of words]] in brackets}; print "$x\n"; $x =~ s(\[\[(.*?)\]\])( rx {s/ /_/g} $1 )ge; print "$x\n";
      ... a generic function to simulate /r ...

      Defining functions that take 'naked' subroutine blocks is, IMHO, one of the few valid reasons for using prototypes. However, there's a subtle pitfall here that belies the word 'generic' in the description of the function. The use of the  $ prototype causes behavior that will almost certainly cause puzzlement in a wider, i.e., more generic, context by imposing scalar context on its argument. Better, I think, to use  @ instead.

      >perl -wMstrict -le "sub rx (&$) { my $c_regex = shift; local $_ = shift; $c_regex->(); return $_; } ;; my $s = 'a b c'; print rx { s/ /_/g } $s; ;; my @ra = 'p q r'; print rx { s/ /_/g } @ra; " a_b_c 1 >perl -wMstrict -le "sub rx (&@) { my $c_regex = shift; local $_ = shift; $c_regex->(); return $_; } ;; my $s = 'a b c'; print rx { s/ /_/g } $s; ;; my @ra = 'p q r'; print rx { s/ /_/g } @ra; " a_b_c p_q_r
        I think a call on @something should rather generate a warning instead of trying DWIM.

        But no (good) idea how to implement that.

        Maybe better iterate over all arguments and returning a list? something called rxmap maybe?

        Cheers Rolf