]> granicus.if.org Git - postgresql/commit
Add ipv6 address parsing support to 'inet' and 'cidr' data types.
authorBruce Momjian <bruce@momjian.us>
Tue, 24 Jun 2003 22:21:24 +0000 (22:21 +0000)
committerBruce Momjian <bruce@momjian.us>
Tue, 24 Jun 2003 22:21:24 +0000 (22:21 +0000)
commit945543d919ced497e3fc8165b11142ddc014b9cb
tree78b5bc6d56d9d8b85040aa9a45bec4d8c2adaa70
parent4dab978c52700b6323919876463ae23c5d7ddf9f
    Add ipv6 address parsing support to 'inet' and 'cidr' data types.

        Regression tests for IPv6 operations added.

        Documentation updated to document IPv6 bits.

        Stop treating IPv4 as an "unsigned int" and IPv6 as an array of
        characters.  Instead, always use the array of characters so we
        can have one function fits all.  This makes bitncmp(), addressOK(),
        and several other functions "just work" on both address families.

        add family() function which returns integer 4 or 6 for IPv4 or
        IPv6.  (See examples below)  Note that to add this new function
        you will need to dump/initdb/reload or find the correct magic
        to add the function to the postgresql function catalogs.

        IPv4 addresses always sort before IPv6.

        On disk we use AF_INET for IPv4, and AF_INET+1 for IPv6 addresses.
        This prevents the need for a dump and reload, but lets IPv6 parsing
        work on machines without AF_INET6.

        To select all IPv4 addresses from a table:

                select * from foo where family(addr) = 4 ...

        Order by and other bits should all work.

Michael Graff
doc/src/sgml/datatype.sgml
src/backend/utils/adt/inet_net_ntop.c
src/backend/utils/adt/inet_net_pton.c
src/backend/utils/adt/network.c
src/include/catalog/pg_proc.h
src/include/utils/builtins.h
src/include/utils/inet.h
src/test/regress/expected/inet.out
src/test/regress/sql/inet.sql