NAME

Array::IntSpan::Fields - IntSpan array using integer fields as indices

SYNOPSIS

use Array::IntSpan::Fields;

my $foo = Array::IntSpan::Fields
 ->new( '1.2.4',
        ['0.0.1','0.1.0','ab'],
        ['1.0.0','1.0.3','cd']);

print "Address 0.0.15 has ".$foo->lookup("0.0.15").".\n";

$foo->set_range('1.0.4','1.1.0','ef') ;

DESCRIPTION

Array::IntSpan::Fields brings the advantages of Array::IntSpan to indices made of integer fields like an IP address and an ANSI SS7 point code.

The number of integer and their maximum value is defined when calling the constructor (or the set_format method). The example in the synopsis defines an indice with 3 fields where their maximum values are 1,3,15 (or 0x1,0x3,0xf).

This module converts the fields into integer before storing them into the Array::IntSpan module.

CONSTRUCTOR

new (...)

The first parameter defines the size of the integer of the fields, in number of bits. For an IP address, the field definition would be 8,8,8,8.

METHODS

All methods of Array::IntSpan are available.

set_format( field_description )

Set another field description. Beware: no conversion or checking is done. When changing the format, old indices may become illegal.

int_to_field ( integer )

Returns the field representation of the integer.

field_to_int ( field )

Returns the integer value of the field. May craok if the fields values are too great with respect to the filed description.

AUTHOR

Dominique Dumont, ddumont@cpan.org

Copyright (c) 2003 Dominique Dumont. All rights reserved.

This module is distributed under the Artistic 2.0 License. See https://www.perlfoundation.org/artistic-license-20.html