http://www.perlmonks.org?node_id=496483


in reply to /^[^A-Za-z0-9 ]*$/

Using Deparse just takes away all the magic, leaving me with a little to no understanding of how it works... =P

How do you translate from "noise" to alphanumeric characters?

Replies are listed 'Best First'.
Re^2: /^[^A-Za-z0-9 ]*$/
by Roger_B (Scribe) on Sep 30, 2005 at 20:47 UTC
    Yes, that amused me when I tried it. My clue about deparse was in case anyone's perl wasn't called 'perl' or wasn't on the path; the deparsed version shows that part of how it works.

    Here's a partially de-obfuscated version:

    $_ = ( '_[]@^' ^ '/>/,~' ) . # 'perl ' '-' . # '-' ( '>]' ^ '[}' ) . # 'e ' '"' . # '"' ( '^])@*{.|~%{{]\\-' ^ './@.^[}(:`))}-\\' ) . # 'print STDERR qq' '(' . # '(' ( '*\\(]{\\./(@[-^-%^,{(!]+>^' ^ '@)[)[=@@\\(>_~]@,@[@@>@[,' ) . # 'just another perl hacker' '\\' . # '\' ( '.' ^ '@' ) . # 'n' ')"'; # ')"' `$_`

    basically it's a concatenation of strings, using the bitwise xor operator '^' to generate alphanumeric characters, per chester's line noise JAPH. For example the 'p' in the first 'perl' comes by xoring '_' and '/':

    perl -e "print '_' ^ '/'" p

    Deparsing de-obfuscates it because the entire xoring and concatenation is made up of literals, so the compiler calculates the result and substitutes it into the compiled version. Deparse simply translates the compiled code back into Perl code. A simpler example might be:

    perl -MO=Deparse -e "print 2 * 2" print 4; -e syntax OK

    '2 * 2' is translated to '4' at compile time and deparse leaves it that way.

    HTH

    Roger

    P.S. blokhead pointed out to me that this too has been done before!