• hedgehog@ttrpg.network
    link
    fedilink
    arrow-up
    1
    ·
    20 hours ago

    Where are you getting these typeless function signatures? You should get them from somewhere else.

    The Ecmascript Spec for parseInt doesn’t have a type listed for the first argument, but it does call the argument “string,” which should be a pretty clear hint that it’s expected to be a string. It also explicitly states that the first step of parseInt is to coerce the first argument to a string. You should view older versions of the spec to see how it performs in older browsers / runtimes.

    The MDN entry for parseInt makes it clear that parseInt expects a string or a string and explicit radix (i.e., 10 for base 10/decimal, or 16 for hexadecimal). MDN is what I recommend anyone who’s writing JavaScript use as their first resource for core JS features, for what that’s worth.

    I use WebStorm to write JavaScript (and more frequently, TypeScript), and if I type parseInt( and pause a second, it pops up a type hint that reads string: string, radix?: number.

    I checked in VSCode, too, and it pops up this:

    parseInt(string: string, radix?: number | undefined): number`
    A string to convert into a number.
    Converts a string to an integer.

    You can set something similar up with an LSP in Vim or Neovim, and presumably in Emacs as well.

    • Traister101
      link
      fedilink
      arrow-up
      1
      ·
      20 hours ago

      You have argued that it’s expected to be a string congrats. You’ll notice from the grammer you used that there isn’t an actual type here, you specifically pointed out how your IDE displays a type hint which is only slightly better than somebody writing some form of documentation on what the type is. Dynamic languages don’t have typed args, least none that I’ve heard of.