Are you expected to run five Python type-checkers now?

(pyrefly.org)

98 points | by ocamoss 7 hours ago

14 comments

  • dsign 4 hours ago
    If you are going to be super-strict with type-checking, wouldn’t it be best to switch to a statically typed language and get the performance gains as well?
    • Animats 14 minutes ago
      The modern approach seems to be to require full typing on items seen from outside the function or object. Within functions, have the compiler infer as much as it can. Newer languages (Go, Rust) seem to be converging on this approach.

      Function parameters need type info as guidance for people and LLMs calling the function. Even though cross-function type inference is technically possible, it's too confusing. Long-distance inference failures tend to generate poor messages.

      Within a function, if you have typed parameters, the type inference engine has a local starting point and a good chance of success on most local variables.

      Unchecked advisory typing in Python was a terrible idea. All the work of writing type declarations with none of the benefits.

    • pmontra 4 hours ago
      Hallelujah, that's always been my position. To the static typing folks: leave my dynamically typed languages alone and go coding with something that really suit your needs. If the answer is that Python, Ruby, JS, whatever are really much more pleasant to code with, my reply is that they are so precisely because we don't have to type type definitions. Tradeoffs.
      • cogman10 3 hours ago
        It's not an all or nothing thing.

        I think types are particularly valuable for libraries. A library author using copious types really helps the downstream user to know "Ok, this function returns a dict(Foo, Bar)". But after that, it's a matter of preference if you want to add those types to your own code or not.

        Having the types in the libraries makes it a lot easier for your tools/IDEs to give good suggestions and catch bugs that you might otherwise miss.

        • eloisius 2 hours ago
          Yes, where would I be without the _RelationshipBackPopulatesArgument type of

                  sqlalchemy.orm.relationship(argument: _RelationshipArgumentType[Any] | None = None, secondary: _RelationshipSecondaryArgument | None = None, *, uselist: bool | None = None, collection_class: Type[Collection[Any]] | Callable[[], Collection[Any]] | None = None, primaryjoin: _RelationshipJoinConditionArgument | None = None, secondaryjoin: _RelationshipJoinConditionArgument | None = None, back_populates: _RelationshipBackPopulatesArgument | None = None, order_by: _ORMOrderByArgument = False, backref: ORMBackrefArgument | None = None, overlaps: str | None = None, post_update: bool = False, cascade: str = 'save-update, merge', viewonly: bool = False, init: _NoArg | bool = _NoArg.NO_ARG, repr: _NoArg | bool = _NoArg.NO_ARG, default: _NoArg | _T = _NoArg.NO_ARG, default_factory: _NoArg | Callable[[], _T] = _NoArg.NO_ARG, compare: _NoArg | bool = _NoArg.NO_ARG, kw_only: _NoArg | bool = _NoArg.NO_ARG, hash: _NoArg | bool | None = _NoArg.NO_ARG, lazy: _LazyLoadArgumentType = 'select', passive_deletes: Literal['all'] | bool = False, passive_updates: bool = True, active_history: bool = False, enable_typechecks: bool = True, foreign_keys: _ORMColCollectionArgument | None = None, remote_side: _ORMColCollectionArgument | None = None, join_depth: int | None = None, comparator_factory: Type[RelationshipProperty.Comparator[Any]] | None = None, single_parent: bool = False, innerjoin: bool = False, distinct_target_key: bool | None = None, load_on_pending: bool = False, query_class: Type[Query[Any]] | None = None, info: _InfoType | None = None, omit_join: Literal[None, False] = None, sync_backref: bool | None = None, dataclass_metadata: _NoArg | Mapping[Any, Any] | None = _NoArg.NO_ARG, \*kw: Any) → _RelationshipDeclared[Any]*
          • cogman10 1 hour ago
            It's not for you, it's for your IDE. And if you aren't using an IDE then you can pretty much ignore it anyways.

            You are in exactly the same position as if you knew or didn't know that type.

            • nonethewiser 36 minutes ago
              If you're not using and IDE nor an LLM
          • chuckadams 32 minutes ago
            Part of it is due to the really clumsy `_NoArg.NO_ARG` business for optional props. TypeScript and PHP represent it with a single char. Pretty-printing it would also go a long way, but that technology seems too advanced for any language circa 2026.
        • shevy-java 1 hour ago
          This is even worse because you attempt to try to sell why types SOMETIMES make sense. But you aim with this for a language that did not have nor need types to begin with. People don't seem to understand that this is an issue.

          The library-situation is really not different from having types everywhere, and some people will do that too.

          > catch bugs that you might otherwise miss.

          People repeat this a lot. In about 22 years of writing ruby code, I have never ran into a situation once where I would have caught a bug through types. I don't understand why people keep on repeating this. Repetition does not make it anymore true.

          Think in the opposite way: if types would have been necessary to begin with, why would ruby have been successful back in 2006? It was successful without types already. And types were never needed - they came because some people THINK they are needed. This is the biggest problem - the thinking part. They think they are right and all who do not use types, must be wrong and very foolish people.

          • stackskipton 2 minutes ago
            SRE here, I've had multiple outages caused by lack of typing in both Ruby and Python where bad types get passed, something doesn't catch it and either data corruption or constant crashes. Couple cost us big money because it screwed up billing and we were forced to eat the billing cost.
          • dminik 43 minutes ago
            Have you considered these people in general aren't some outsiders out to attack you or your favorite language?

            The people who do end up making and using type checkers are people who have or are actively using these dynamic languages and found out that they CAN help THEM with preventing bugs.

            Also, really? 22 years in which not one type-related error happened? Never? I don't want to say I don't believe you, but I really don't.

      • Tade0 4 hours ago
        Personally I like having my TypeScript cake and eating it.

        I also truly believe those who design type systems would benefit from taking a look what kind of code people programming in dynamically-typed languages produce.

        • joha4270 17 minutes ago
          Could you point me towards the kind of code people programming in dynamically-typed languages produce?

          I have lived in statically typed languages almost all of my life, and even when I don't, I pretend I do, just without having a typechecker. So I'm very curious about what I'm missing.

        • anamexis 3 hours ago
          I do too, but I feel like TypeScript stands alone as an unusually effective and pleasant to use bolted-on type system. I've not seen any other approach come close. (My sample size is Python, Ruby and Elixir)
          • dnautics 48 minutes ago
            you don't think the elixir type system is effective?
        • junon 1 hour ago
          I hate TS's tooling with a burning, deep passion. But its type system is actually pretty incredible for what it is.

          There are times that I yearn for TS's ability to do duck type reasoning in e.g. Rust (despite that not being feasible) when working with very large data types.

      • thr1owaway9621 3 hours ago
        I started using types with Python in 2018-ish, and I never looked back.

        I am not that good a programmer, so maybe I am wrong, but I just like being able to tell what the data is that's moving through the system. Typed function signatures, a little shift+k here and there, a warning that I am trying to add int and a string. I don't see what's the harm in having that?

        At the end of the day, if you don't want to use Python with types -- do not. Unless somebody at work is forcing you, and it feels like putting lipstick on a pig (especially with something like numpy that doesn't easily support types)? Then condolences.

        • nonethewiser 34 minutes ago
          But why does your appreciate of type systesm not lead you to something like Typescript? Which is a lot more robust? Or Rust? C#?

          I guess my speculation is that not every language is good at everything. Sure you might want a better type system with Rust. But for data science?

      • bborud 3 hours ago
        What specifically makes them more pleasant? (not a rhetorical question, I want to know what's important to you)
        • pmontra 3 hours ago
          Historically (80s/90s) I started using Perl because I didn't have to write all those malloc and free I spent years writing in C and I could perform string operations much more easily. Then in the mid 90s because of that wonderful CGI.pm Perl module. But the plus of all those languages, and Java, was managed memory. Then in the mid 2000 I learned Rails, and after Rails I learned Ruby. It was like Perl but much easier to understand and again no types to type. Basically what I did in Java but in a fraction of the time and in a fraction of the lines of code. Then a customer asked me to work with Python on a Django app so I learned Python. It looks like a Ruby designed by Klingons but it's OKish.

          All those bugs I constantly read about, they don't happen very often and are a good tradeoff. Maybe Rails and by Django are shielding me from some bug scenarios.

      • Hizonner 3 hours ago
        The only reason I gave up resisting and started writing any significant code in Python at all was that it got some kind of type system, and thus became less unpleasant to code with.

        "Pleasant to code with" does not describe getting "AttributeError: 'NoneType' object has no attribute 'foo'" 25 levels deep in a stack trace already obfuscated by dynamic object-oriented nonsense. In production, because it's an unusual case and testing missed it. Not that test cases aren't way more work than types anyway.

      • shevy-java 3 hours ago
        I am totally with you and I am glad I am not the only one who is totally against those type-addictions leaking into languages that did not need them in the first place.

        Types in ruby are even worse than in python, because the type systems in use really make ruby turn very ugly. In python it is not as much as a huge problem with regards to syntax, as python has a stricter syntax (e. g. mandating foo.bar() whereas in ruby you can typically omit the (), among other syntax sugar examples).

        We need to keep the type people out of those languages.

        Many years ago, on IRC, on #haskell, they said they don't want everyone to use Haskell. Back then I did not understand it. After the type-addicted people emerged out of nowhere, I now begin to understand why Haskell is so snobbish. If you let every idea float, you end up ruining languages - and then those who wanted this, will retire and move away too. Ultimate damage factor caused as outcome here.

      • kibwen 3 hours ago
        > To the static typing folks: leave my dynamically typed languages alone

        Surely you understand that the push to add types to dynamically-typed languages comes from dynamic-typing folks, not from static-typing folks. People who are deeply into static typing have little incentive to consider e.g. Python, whose support for types is relatively weak, loosely-defined, and rarely-enforced compared to the statically-typed languages that exist today.

    • ocamoss 4 hours ago
      Running more type checkers isn't really about strictness. The main benefit to library maintainers is to make sure that their APIs are compatible with whatever tools their users run.

      This wouldn't really be an issue for most other languages, but Python's typing ecosystem is uniquely fragmented, with only partial standardization between several popular tools.

      • fg137 4 hours ago
        Hmm... that doesn't answer the question?
        • locknitpicker 3 hours ago
          > Hmm... that doesn't answer the question?

          GP's point is obvious: performance is immaterial to the discussion. Static code analysis is about preventing bugs. Therefore OP fails to make any sort of point, as it's a straw man argument.

    • tptacek 34 minutes ago
      No? One has nothing to do with the other.

      I think those of us who work in compiled languages are just snooty about them.

      I'm a compiled language snoot, and happen to be working over the past couple days in typed Python for the first time. It's kind of nice. I like it. It's a huge improvement for me over ordinary Python/Ruby/Javascript; it materially improves the experience of working in the language.

    • Qem 4 hours ago
      > If you are going to be super-strict with type-checking, wouldn’t it be best to switch to a statically typed language and get the performance gains as well?

      You can use type-checking to get better performance already, without leaving Python. See https://blog.glyph.im/2022/04/you-should-compile-your-python...

    • SatvikBeri 4 hours ago
      What statically typed language would you suggest for machine learning and large data pipelines? I don't love Python, but it has by far the largest ecosystem.
      • bborud 3 hours ago
        Well, that's the curse of machine learning: since everyone uses Python you have to deal with Python. Even though Python isn't very nice when things start to get serious and you don't want to spend your time fiddling with noise just to make something work at scale.

        I'd wish the ML/AI/LLM crowd would see that it is in their interest to get better developer ergonomics at scale. (I don't want to have to turn to C++)

      • mountainriver 1 hour ago
        ML is basically the one use case for Python anymore.

        And that even shrinks by the day

      • srean 4 hours ago
        You could try Cython and Lush. An ML dialect for ML would have been nice, but doesn't exist.
        • thr1owaway9621 3 hours ago
          Cython is a niche language for writing perf-critical bits inside your Python codebase. It's like C for people who don't want to learn C. At least that's how I treated it, when I had to write some stuff to make some numpy ops faster.

          Cython is not in any real sense a replacement for a modern data/ml stack.

          • srean 3 hours ago
            True but it's really nice way to get the benefit of type checking in Python.

            Just like you, I had started using Cython for performance but then realized that I can discard a bulk of type errors if I used for type checking.

            The other benefit is that the Python library ecosystem stays available.

        • pdpi 4 hours ago
          As funny as it would be, ML isn't really a great fit for ML, I don't think.
          • srean 3 hours ago
            That's true for current ML offerings.

            However, I think an ML designed for machine learning would be nice, especially if the type system is extended to multidimensional arrays shapes. Pattern matching on array shapes would be rather nice. Ocaml style interactive mode for exploration and compiling for performance would be nice too.

      • locknitpicker 3 hours ago
        > What statically typed language would you suggest for machine learning and large data pipelines? I don't love Python, but it has by far the largest ecosystem.

        Pay no attention to OP. It's nonsensical to even suggest you should migrate away from a whole tech stack just because you want to run static code analysis, specially when the argument is based on having too many static analysis tools to chose from. Utter nonsense.

    • marcosdumay 1 hour ago
      The goal is to be strict, with explicit exceptions.

      You don't use a static language because you want the exceptions, but the type checking can still statically validate most of your code.

    • MeetingsBrowser 3 hours ago
      strict type checking is an incredibly useful tool for cases when you really want to make sure your code is correct and behaving as expected (one of many tools).

      There are lots of people who like python and want to use it for things that where incorrect code has serious consequences. Type checking is helpful in these contexts.

      Type checking remains optional for the masses and is not practical in many cases. Still, pushing away people who want to use all available tools for writing correct python only hurts the community.

    • globular-toast 19 minutes ago
      Show us the language and we'll all switch tomorrow.
    • vadansky 3 hours ago
      Personally because I'm making a blender add on that only uses python, and it's at the complexity where having types catches a ton of bugs easily.
    • bborud 3 hours ago
      Python has other, bigger problems that make it a constant headache. One of them being the dismissive attitude towards any and all of problems that come from versioning, dependencies and quirks that make it challenging to have robustness.

      Criticisms are typically dismissed by suggesting heaping yet another "solution" onto the growing pile of "solutions" that you have to drag around with you. That people have to learn. That you have to install tooling for. That has to be vetted. That has to become part of the toolbox to get even seemingly simple things done. This attitude is a big part of the reason that I strongly advise people against using Python in production. On top of all the problems presented in a real-world setting.

      Almost all of the time, people who are fond of Python are more interested in defending python, disparaging me, downvoting me etc that listen to why I make that recommendation.

      (I get it. People like Python. What I think of Python as a language is irrelevant. In fact I don't have that much against it. But I do have a lot against it in a setting where you need reliability and repeatability)

      I have spent the last month of my life building a system that can run Python tooling reliably in a business critical application. I knew this was going to be a pretty big job when I started, but for every problem I solve, a bunch of new problems arise. I am starting to see light at the end of the tunnel but it hasn't exactly been smooth sailing. I'm almost there for a first version, but there are a bunch of problems still to solve. Mostly because I care about developer ergonomics and that things should "just work". One important goal is that my solution shouldn't impose any significant cognitive burden on people who use it. That's really hard.

      (I don't think the solution will be open source since my contract wouldn't allow for it. But I'll make the case at some point for why it should be open sourced)

      And yes. There are statically typed languages available today that have decent tooling that provides superior developer ergonomics. I can understand that people don't want to learn new languages, but if you have the capacity to do so I would recommend trying to move on if the code you write has to run outside your own workstation. If an old fart like me can learn and adopt new languages, so can you.

      • chuckadams 23 minutes ago
        Python the language is pretty nice. It has its warts, but I make my living in PHP which is practically made of warts. But the python ecosystem still seems to be trying to figure out this whole package management and project setup thing. In most languages I can do some form of `$blub install` where $blub is the language's official package manager or some close equivalent. It's just python that always screams at me that I have to set up and "enter" a virtualenv. I get what venv is for, but it's still a weird hack of hardlinks and relative paths that no other language seems to need, and a clumsy two-step dance of a UX that hasn't improved in like 20 years.
    • IshKebab 3 hours ago
      Yes. If you have a choice.

      For people who don't have a choice, type checked Python is better than nothing.

    • ethagnawl 4 hours ago
      Yeah, I can't say I really get the appeal of gradual typing. It's commented/documented code at best and outright lies at worst. Sure, you can build tooling around it and improve your DX a bit but isn't it always a house of cards?
      • falcojr 27 minutes ago
        If you add one of these type checkers into your CI or a pre-commit hook, it provides the same guarantees you get from a compiler along with the same tooling benefits. It gives you the option of using the structure when you need it, but not being forced to use it when you want to take advantage of some of the more dynamic features of the language.
        • chuckadams 18 minutes ago
          But none of the runtime benefits of having static types in the compiler, since the runtime still can't trust the types. Still, half a loaf is better than none.
      • ocamoss 3 hours ago
        > commented/documented code at best

        Machine-checked documentation is always valuable, IMO

    • thrance 1 hour ago
      Often, when I code in Python, it's because there are some libraries that aren't available in whatever other language would have been my first pick. Then, typing and type-checking are useful tools to stave off the codebase turning into the unruly mess that all Python projects eventually become.
    • UltraSane 2 hours ago
      That is why I'm using C# and Rust more now than Python. You get far better RoI on types. and they are so much faster and can use all cores so much more easily.
    • Hizonner 3 hours ago
      Yes, but unfortunately Python has invaded everything, and one must adapt.

      Python is going to be preinstalled on almost any machine I use, with a reasonable assortment of libraries. And even if they're not preinstalled, the libraries I want are likely to exist. They'll have unstable APIs and weird quirks, and I'll have to take my choice of bad packaging systems to install them, and everything will just generally be a pain, but they'll exist and largely work. That's not true for any language I actually want to code in. I mean, I'm not going to deny that Python is better than shell scripts or (usually) C.

      It's not like it's a pleasant language to code in, especially if you actually want to use the type support, which is weird and irregular and keeps changing and has to work around fundamental design problems at the core of the language.

    • locknitpicker 3 hours ago
      > If you are going to be super-strict with type-checking, wouldn’t it be best to switch to a statically typed language and get the performance gains as well?

      I don't understand your question. The whole point of static code analysis is preventing bugs. Don't you like Python code to not have bugs that are easily caught with static code analysis, or is preventing code a foreign idea that is better left to other languages?

    • scuff3d 3 hours ago
      Seriously, just switch to Go or something
    • hedora 3 hours ago
      [dead]
  • blahgeek 4 hours ago
    > Prioritise running as many type-checkers as possible on your test suite. Run at least one on your source code.

    There are two types of tests: those that test against the public API, and those that test internal codes with various mocks and fakes. I think the vast majority of unit tests is the latter one, in which case the suggestion does not really make sense.

  • semiinfinitely 16 minutes ago
    Everything that isn't uv, ty, ruff is wrong and deprecated
  • voidUpdate 5 hours ago
    > "In Python, any method __eq__ is expected to return bool, and if it doesn't, then we need to explicitly tell type-checkers to ignore the type error. This function in Polars can also return different types depending on the inputs, thus requiring overloads."

    Why would you ever want a == b to not return a bool??

    EDIT: Yes, I understand that you can do element-wise equality checks on numpy arrays now

    • vitamark 4 hours ago
      There are examples like ORM query builders (something like `User.id == user_id` should not return a boolean, but rather some inspectable query part), multi-value comparisons (e.g. numpy arrays and views which could also be used as masks for indexing)

      In general, when you get your hands on operator overloading you get a bunch of various quirky applications for each. Some dunder methods have strict runtime-level rules (e.g. __hash__ or __len__), some don't

    • samsartor 4 hours ago
      Elementwise equality! Given two dataframe columns or ndarrays, users often expect `==` to give out a column or ndarrays of bools (like `+`, ``, `*, `&`, and just about every other binary operator).
    • datsci_est_2015 5 hours ago
      One example is if an and b are arrays (e.g. numpy arrays) it’s not unreasonable for dunder eq to return an array of booleans.

      Another example might be if you have a domain specific representation of equality (e.g. class Equality)

      • voidUpdate 5 hours ago
        I can see the first one making sense, but why would you need a representation of equality other than "yes, these are equal" and "no, these are not equal"?
        • datsci_est_2015 4 hours ago
          Well personally I’m not a fan of turning everything into an object, but if you have properties or methods that exist upon the concept of Equality you might want to encode directly onto a class. Maybe in a domain where “Equality” is an important concept, like mathematics or even something like accounting.

          Could enable a different interface into approximate equality for floating point numbers: Equality.approximate(iota: float) -> bool

        • agons 3 hours ago
          The first use case that comes to mind is if you want a DSL to build expressions that are evaluated later in some different context e.g. when using `polars`:

          ```python df.filter( pl.col("foo") == pl.col("bar"), ) ```

          Sqlalchemy does something equivalent too, and I'm sure there are many others.

    • olooney 4 hours ago
      It could return a vector or a deferred expression? In polars, for example, operations on `pl.col` return `Expr` objects that are used to build queries, not immediately evaluated:

          df.filter(pl.col("status") == "active")
      
      In numpy, `x == y` return a boolean vector of the same shape as x and y, comparing them element-wise.
    • kuschku 3 hours ago
      Primarily, because Python doesn't have quasi-quoting. You can't pass an expression without workarounds like this.
    • xemdetia 5 hours ago
      I thought JavaScript language equality quirks was seen as problematic not a missing feature in Python.
      • voidUpdate 4 hours ago
        At least in javascript, it tells you if things are equal or not. In python, apparently you could answer if A is equal to B with "beans" or 17 or ['a']
        • hmry 4 hours ago
          Never understood this complaint about operator overloading.

          In any language, a function called `isEqual` could wipe your hard drive and replace your wallpaper with a photo of a penguin. Therefore, letting programmers pick the names of their functions is bad? No, obviously naming things for least surprise is the programmer's responsibility.

          But when it's the symbols `==` instead of an ASCII name, it's a problem in language design?

          (FWIW in Javascript, being unable to override == is actually a problem when you want to use objects as Map keys)

      • throwaway894345 4 hours ago
        Python never met a footgun it didn’t need to adopt. In this case, however, it’s not equality checks, but operator overloading. I was a Python developer for a decade before switching to Go and life on this side is so much better.
        • data-ottawa 3 hours ago
          Operator overloading has never been an issue for me, but terminating a line with a comma creating a tuple, or white space (including new lines) between strings to concatenate have cost me days of work over the years.

          I understand why those exist, but they’re pure evil.

    • throwaway894345 4 hours ago
      IIRC, SQLAlchemy overloads this to return an object that represents an equality check in SQL. Because it was returning an object, it was always evaluating to True, because of another of Python’s footguns: truthiness/falsiness. This was a decade ago, and these particular footguns were not even remotely the biggest culprits in our bug backlogs (another honorable mention includes accidentally calling a sync function in an async context, causing timeouts in unrelated endpoints and leading to cascading system failure).
  • kingstnap 4 hours ago
    The fact that this article seems to honestly recommend people run 5 different type checkers on library test suits really reflects the tacked on feeling of Python typing.
    • vitorsr 4 hours ago
      I am not sure it is recommending more than it is commenting on the current state of developing public-facing APIs in Python.

      The downstream users that import the package either have to ignore checking its exported types altogether, manually stub it, or have a subpar development experience to varying degrees.

      This is something I saw the other day with some package that provided comprehensive stubs for an untyped library. The .pyi file was littered with comments about quirks from the numerous type checkers (five now).

    • TremendousJudge 1 hour ago
      It's ridiculous. They should have made it an explicit part of the language. The interpreter knows about types already, it's crazy that they couldn't just let the user make the types explicit rather than implicit, and have the interpreter enforce that.
  • KolmogorovComp 3 hours ago
    Why anyone would still use mypy besides legacy infrastructure is beyond me. It is dog slow as well as being the laziest of all, not catching many mistakes.

    Unfortunately for Django apps switching to any alternative leads to the dreaded “wall of errors” issue. If anyone got to work this out in the past, I’d gladly take advices.

    • thr1owaway9621 3 hours ago
      I use pyright with a 50k LOC Django REST API codebase. I haven't really had problems. From my pyproject.toml:

      django==4.2.30

      djangorestframework==3.16.1

      ---

      django-types==0.15.0

      djangorestframework-types==0.8.0

      pyright==1.1.390

      My dj version is pretty old, but I'd assume things have only gotten better since v 4?

  • __mharrison__ 3 hours ago
    I'm happy w/ ty right now. My agents runs it fast and it seems to provide great guardrails.
  • shermantanktop 4 hours ago
    That blog needs to run a AI checker. Content aside, a lot of the writing is pure AI style.

    > The type checking that matters most (and why you've probably got it backwards)

    Honestly, I don’t care if the author got some AI help. But that click-bait style is ubiquitous and obnoxious.

  • zerof1l 3 hours ago
    From my experience with Python, both personal and professional, I find it immature and not well-suited for large codebases. Typing should have become part of the language a long time ago; it is clear that users want it.

    Take, for example, PHP… look at the features released in the last 6 or so years, starting with PHP 7, and how mature the language has become.

    With the advance of AI-assisted programming, I feel like Python is always a bad choice.

  • ghostly_s 4 hours ago
    Why would users care if you're using the same type checker as them? Surely they're not expecting all their imports to be instrumented for running redundant types checks?
    • Someone 4 hours ago
      Users do not care about that, but they want to not see type errors or warnings when they integrate your API in their code.

      That’s why you want to run their type checker on your API. you cannot know what “their type checker” is, so you want to run all popular type checkers on your API.

      • ForHackernews 3 hours ago
        Sounds like a them-problem. Their type checker can accept my declared typings for my public API, or they can override it with their own custom type stubs if they have objections.
  • prodigycorp 3 hours ago
    what are ppls' impression of pyrefly? i've become completely captive to uv's tooling. it has allowed me to think only about coding versus tooling. dont feel like giving another typechecker a chance unless it offer's something i'm not getting from ty.
  • faangguyindia 4 hours ago
    [dead]
  • shevy-java 3 hours ago
    The type-lovers will be angry! :)

    The blog entry fits into ruby too, to some extent; while the situation is nowhear near as bad as in python, you have the same question-marks why types suddenly emerge out of nowhere. Almost ... almost as if some people have a specific agenda, and try to pull through with it.

    Well, there you have it - the type-addicted people are ruining python.

  • woeirua 5 hours ago
    With agents it no longer makes sense to tie yourself to Python's archaic development experience. How many type checkers are there? Package managers? Don't even get me started on cross-platform deployment.

    Strongly typed, compiled languages have never been easier to use, and agents reap huge benefits from the tight feedback loop that the compiler provides. Moreover the benefits of the Python ecosystem are less significant today than anytime in the past 20 years. Need something that's only available in Python? Just point some agents at it and you can port it.

    • datsci_est_2015 4 hours ago
      > Just point some agents at it and you can port it.

      Don’t think we’re there yet, otherwise we would see a bunch of forks of major libraries to alternative languages - and not just Python. There’s still too much risk of insidious errors and bugs.

      • hedora 3 hours ago
        I've done thus a few times for stuff in the < 10,000 LOC space. It works great.

        There's something particularly satisfying about shipping a 1-10MB static rust binary instead of a 2GiB docker python environment.

        (I'm talking about just porting simple applications, or maybe a missing package/crate at a time. Not both at once, and not typical 100K-10M line internal legacy sprawl)

        • datsci_est_2015 26 minutes ago
          What have you ported, for example? Any 3PL or all internal code?
    • voidUpdate 5 hours ago
      What about the several people worldwide who don't want to use LLMs to program?
      • cryptonym 4 hours ago
        They also "reap huge benefits from the tight feedback loop that the compiler provides".

        When something is easier/requires less context, it tends to work well for both human and LLM.

        • vips7L 4 hours ago
          I've noticed this a lot in LLM generated Java. Since it doesn't know what can or can't be null it tends to wrap everything in Optional<T>. Super strong type systems are becoming even more important.
          • hedora 3 hours ago
            You probably need to tell it to rip as many of those out as possible (and replace them with null annotations).

            I've noticed LLMs sometimes pick a documented anti-pattern (passing Optional around in Java is not recommended), then amplify it (like a human might).

            • vips7L 3 hours ago
              That's because LLMs suck.