Beefy Boxes and Bandwidth Generously Provided by pair Networks
Perl: the Markov chain saw

Re: Regexp: Private IP Addresses

by ikegami (Pope)
on Aug 25, 2009 at 19:25 UTC ( #791164=note: print w/replies, xml ) Need Help??

in reply to Regexp: Private IP Addresses

One often works with IP addresses in packed form which allows for a very efficient regex match:

sub is_private { my ($packed_ip) = @_; return $packed_ip =~ m{ ^ (?: \x0A # | \xAC[\x10-\x1F] # | \xC0\xA8 # ) }x; }


use strict; use warnings; use Socket qw( inet_aton ); sub is_private { my ($packed_ip) = @_; return $packed_ip =~ m{ ^ (?: \x0A # | \xAC[\x10-\x1F] # | \xC0\xA8 # ) }x; } my $result = ''; for (qw( )) { my $packed_ip = inet_aton($_); $result .= is_private($packed_ip) ? 1 : 0; } print("got: $result\n"); print("expect: ", "0110"x3, "\n");
got: 011001100110 expect: 011001100110

Update: Alternatives:

sub is_private { my ($packed_ip) = @_; return ($packed_ip & "\xFF\x00\x00\x00") eq "\x0A\x00\x00\x00" || ($packed_ip & "\xFF\xF0\x00\x00") eq "\xAC\x10\x00\x00" || ($packed_ip & "\xFF\xFF\x00\x00") eq "\xC0\xA8\x00\x00"; }
sub is_private { my $nummy_ip = unpack('N', shift); return ($nummy_ip & 0xFF000000) == 0x0A000000 # || ($nummy_ip & 0xFFF00000) == 0xAC100000 # || ($nummy_ip & 0xFFFF0000) == 0xC0A80000; # }
use Inline CPP => <<'__EOI__'; // Assumes the arg had UTF8=0 IV is_private(const char* packed_ip) { // XXX Alignment issues const U16& hi = *(const U16*)packed_ip; // The irrelevant branch will be optimised away. if (*(const U16*)("\x12\x34") == 0x1234) { // Little endian if ( hi == 0xC0A8 || (hi & 0xFFF0) == 0xAC10 || (hi & 0xFF00) == 0x0A00 ) return 1; } else { // Little endian if ( hi == 0xA8C0 || (hi & 0xF0FF) == 0x10AC || (hi & 0x00FF) == 0x000A ) return 1; } return 0; } __EOI__

Replies are listed 'Best First'.
Re^2: Regexp: Private IP Addresses
by markkawika (Monk) on Aug 26, 2009 at 21:20 UTC

      No. There are similarities between all the solutions provided in this discussion (including between mine and that module's), but the module's solution is far from being exactly the same as any of mine.

      According to the docs, it uses the binary representation of the address (a long string of zeros and ones), whereas all of my solutions work with the address as a native number (C long). That makes some of them byte-oriented and some of them mask-oriented, but none are bit-oriented like that module.

      Mind you, any of the solutions in this discussion could be given the same interface as that module.

Log In?

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://791164]
[Discipulus]: The Count of Moret; The Red Sphinx is a single book appeared with different titles. it is one of the best and alot of understimed Dumas book.
choroba has only read the first two
[Discipulus]: if i can suggest La Reine Margot too is a great book and obviously The Count of Monte Cristo that is a chef-d'œuvre
[Discipulus]: The red sphinx is about Rechilieu, absolutely thrilling
[erix]: thanks, Discipulus - I got them lined up at gutenberg :)
[erix]: I red the musketeers and Monte Cristo but both a very long time ago (many decades ago)
[erix]: *read

How do I use this? | Other CB clients
Other Users?
Others chilling in the Monastery: (9)
As of 2017-05-24 07:21 GMT
Find Nodes?
    Voting Booth?