Have to add that we work exclusively in strongly-typed languages. Kinda want to see how it plays out, but I can’t help but argue with him, so I think I’ll just go.

    • @[email protected]
      link
      fedilink
      83 months ago

      I worked as a subcontractor with a lead architect that used casting to void * as an only method of sending data. Argument to a function? Void *. Return value? Void *. Multithread pipe? Cast to a void *, no big deal. 80% of my job was investigating segfaults. 20% was heavy drinking to prevent suicidal thoughts.

      • @[email protected]
        link
        fedilink
        English
        53 months ago

        I do mainly C and C++ and for a while, I had to check out some JS code…
        I wouldn’t want to take your place.

        The only case I remember using a void* in is when passing a function as an argument for a callback, to an RTC peripheral. Even then, the function was returning a void.

    • @[email protected]OP
      link
      fedilink
      233 months ago

      Did you know that the type of a variable is determined by the frequency of plasma oscillations among the objects valence electrons?

  • @[email protected]
    link
    fedilink
    113 months ago

    I recently tried out Python. I had no idea it still doesn’t have runtime enforced typing…

    I didn’t realize that PHP was decades ahead of it.

    • exu
      link
      fedilink
      English
      223 months ago

      Python is dynamically strong typed, meaning you don’t need to specify any types, but unlike JavaScript you can’t just use a string where an int was expected. In that sense it’s absolutely runtime enforced typing.

      • @[email protected]
        link
        fedilink
        93 months ago

        … and yet… it lacks clear and enforced type restrictions which help with clear code contracts. It’s certainly better than Javascript but the lack of runtime enforced type checking can force defensive programming in an unnecessary manner.

        Your statement isn’t strict type checking. It’s a restricted form of type coercion. Given how common this feature is in other languages it’s weird that pythonistas feel so defensive when discussing the feature. I enjoy strict type checking, but that’s my opinion - it makes it a poor choice for the sorts of projects I work on but if it’s good for you then enjoy!

        • @[email protected]
          link
          fedilink
          English
          23 months ago

          You said it’s not runtime type checking but then switched to “strict type checking” - those aren’t the same. Other person has it right, it has runtime type checking. The type checking happens when running your code. I don’t think that’s particularly useful, it’s pretty much sugar on top of what would throw an error anyway.

        • @[email protected]
          link
          fedilink
          22 months ago

          it lacks clear and enforced type restrictions which help with clear code contracts

          Not anymore! Gradual typing is supported by the core language and pyright is a fantastic incremental type checker that you can use both in your editor and in CI.

    • @[email protected]
      link
      fedilink
      26
      edit-2
      3 months ago

      Python 3.x will never have static typing because that would break backwards compatibility.

      However, typing hints have been Integrated into Python for a while, and you are heavily recommended to use them, so your IDE can enforce typing.

      • @[email protected]
        link
        fedilink
        33 months ago

        Considering there is typing in the code why is there no switch to enable type checking at runtime? PHP does this with a per file declare(strict_types) - why would python be unable to have either a global or per file flag to enable checks?

        • @[email protected]
          link
          fedilink
          103 months ago

          Typing when you need it gives you more freedom over a toggle. You can choose to type some parts of the code while leaving other parts untyped.

          For example, if I’m writing a quick and simple Python script I may forgo typing, but when iterating on it I’d go back and add the types I need.

          • @[email protected]
            link
            fedilink
            43 months ago

            This isn’t an issue, though. PHP has the same partial typing flexibility. There are ways to solve that issue and even typed PHP still allows union types including mixed which allows any types.

        • @[email protected]
          link
          fedilink
          English
          2
          edit-2
          3 months ago

          why is there no switch to enable type checking at runtime?

          Have you got problems this would solve? I’ve done a lot of type annotated Python at scale and I can’t think of an example.

          Edit: given nobody in their right mind allows code that’s not checker clean.

      • @[email protected]
        link
        fedilink
        22 months ago

        Also have the option of selectively/strictly enforcing in CI, to get an experience & protections similar to “compile-time type checking”

    • @[email protected]
      link
      fedilink
      103 months ago

      i mean yeah it’s a scripting language, what did you expect?

      do you want bash to add typing as well?

  • @[email protected]
    link
    fedilink
    93 months ago

    What about the caller? IMO types are more helpful for the consumer of the code than the original developer.

  • @[email protected]
    link
    fedilink
    6
    edit-2
    3 months ago

    That guy in corporate is creepy as fuck. I think he’s a pedophile. He’s always saying “TIME TO GET BUSY MINORS!”