• @[email protected]
      link
      fedilink
      61 year ago

      Fuck that, if for whatever reason I’m writing an IP validator by hand I’m disallowing leading zeros. Parsers are very inconsistent, some will parse 010 as 10, others as 0o10 == 8 (you can try that right now with a POSIX ping). Talk about a footgun.

      • @[email protected]
        link
        fedilink
        61 year ago

        some will parse 010 as 10, others as 0o10 == 8

        …and that’s me in the fetal position, thanks.

    • Danny M
      link
      fedilink
      3
      edit-2
      1 year ago

      Definitely, tho if you store it as a u32 that is fixed magically. Because 1.2.3.4 and 1.02.003.04 both map to the same number.

      What I mean by storing it as a u32 is to convert it to a number, similar to how the IP gets sent over the wire, so for v4:

      octet[3] | octet[2] << 8 | octet[1] << 16 | octet[0] << 24

      or in more human terms:

      (fourth octet) + (third octet * 256) + (second octet * 256^2) + (first octet * 256^3)
      
      • @[email protected]
        link
        fedilink
        21 year ago

        True enough for database or dictionary storage, but a lot of times things get implemented in arrays where you still wind up with two copies of the same uint32.

      • @[email protected]
        link
        fedilink
        21 year ago

        Because 1.2.3.4 and 1.02.003.04 both map to the same number.

        But 10.20.30.40 and 010.020.030.040 map to different numbers. It’s often best to reject IPv4 addresses with leading zeroes to avoid the decimal vs. octal ambiguity.

        • Danny M
          link
          fedilink
          21 year ago

          I don’t know why anyone would write their IPs in octal, but fair point

          • @[email protected]
            link
            fedilink
            21 year ago

            It’s not about how people write them, it’s how parsers parse them. IPv4 has been around since 1982, and most parsers interpret leading zeros as octal.