• xmunk@sh.itjust.works
    link
    fedilink
    arrow-up
    57
    arrow-down
    1
    ·
    9 months ago

    If you’re not using tz_database or equivalents for literally all date-time logic, if 24 or 60*60 are constants defined in your project… you’re doing it fucking wrong. I don’t know how many times we need to break out the idiot club, but date, time and timezones are extremely complicated - unless your business is primarily concerned with them you must use a library or service.

    Do Not Reinvent This Wheel

    • jsomae
      link
      fedilink
      arrow-up
      5
      ·
      9 months ago

      What does tz_database do? Wikipedia makes it seem like it basically converts a pair (geocoordinatr, utc time) to local time

      • InputZero
        link
        fedilink
        arrow-up
        7
        ·
        9 months ago

        From my very basic understanding, yeah that’s basically what it does. However it accounts for a whole lot more into adding or subtracting from UTC. Timezones aren’t absolute, they’re political. Timezones have weird rules, and history that needs to be somehow expressed in the code to get the right time. That’s what’s sets tz_database apart from just looking at a map and saying it’s +7 UTC.

        • jsomae
          link
          fedilink
          arrow-up
          3
          ·
          9 months ago

          So it updates now and then with new rules, and it keeps historical rules for past dates?

          • InputZero
            link
            fedilink
            arrow-up
            2
            ·
            9 months ago

            I think so. Like I said, I have a very basic understanding of it. There are definitely a lot of people who know more about this than I do.