| ▲ | smartmic 9 hours ago |
| From the article: > I am also deeply sick and tired of maintaining large Python scripts recently, and crave the modularity and type safety of OCaml. I can totally relate. Switching from Python to a purely functional language can feel like a rebirth. |
|
| ▲ | voidUpdate 9 hours ago | parent | next [-] |
| While python isn't type safe, you can use Pylance or similar in combination with type hinting to get your editor to yell at you if you do something bad type-wise. I've had it turned on for a while in a large web project and it's been very helpful, and almost feels type-safe again |
| |
| ▲ | debugnik 6 hours ago | parent | next [-] | | It just isn't good enough. Anytime Pyright gives up in type checking, which is often, it simply decays the type into one involving Any/"Unknown": Without strict settings, it will let you pass this value as of any other type and introduce a bug. But with strict settings, it will prevent you from recovering the actual type dynamically with type guards, because it flags the existence of the untyped expression itself, even if used in a sound way, which defeats the point of using a gradual checker. Gradual type systems can and should keep the typed fragment sound, not just give up or (figuratively) panic. | |
| ▲ | VorpalWay 7 hours ago | parent | prev [-] | | > I've had it turned on for a while in a large web project and it's been very helpful, and almost feels type-safe again In my experience "almost" is doing a lot of heavy lifting here. Typing in python certainly helps, but you can never quite trust it (or that the checker detects things correctly). And you can't trust that another developer didn't just write `dict` instead of `dict[int, string]` somewhere, which thus defaults to Any for both key and value. And that will type check (at least with mypy) and now you lost safety. Using a statically typed language like C++ is way better, and moving to a language with an advanced type system like that of Rust is yet another massive improvement. | | |
| ▲ | Balinares 6 hours ago | parent [-] | | Yeah, if you're going to use static type checks, which you should, you really want to run the checker in strict mode to catch oversights such as generic container types without a qualifier. Although I've found that much of the pain of static type checks in Python is really that a lot of popular modules expose incorrect type hints that need to be worked around, which really isn't a pleasant way to spend one's finite time on Earth. | | |
| ▲ | girvo 2 hours ago | parent [-] | | > that a lot of popular modules expose incorrect type hints that need to be worked around Typescript (and Flow to a lesser extent) had this problem once upon a time. It’s a lot better today, so I imagine it will continue to improve. |
|
|
|
|
| ▲ | IshKebab 8 hours ago | parent | prev [-] |
| OCaml isn't pure. |
| |
| ▲ | avsm 6 hours ago | parent | next [-] | | (author here) it's actually the module system of OCaml that's amazing for large-scale code, not the effects. I just find that after a certain scale, being able to manipulate module signatures independently makes refactoring of large projects a breeze. Meanwhile, in Python, I just haven't figured out how to effectively do the same (even with uv ruff and other affordances) without writing a ton of tests. I'm sure it's possible, but OCaml's spoilt me enough that I don't want to have to learn it any more :-) | |
| ▲ | pkal 7 hours ago | parent | prev [-] | | I recently realized that "pure functional" has two meanings, one is no side-effects (functional programmers, especially of languages like Haskell use it this way) and the other is that it doesn't have imperative fragments (the jump ISWIM to SASL dropped the non-functional parts inherited from ALGOL 60). A question seems to be whether you want to view sequencing as syntax sugar for lambda expressions or not? | | |
| ▲ | nh2 6 hours ago | parent | next [-] | | Who uses the second meaning? In my experience, "purely functional" always means "you can express pure functions on the type level" (thus guaranteeing that it is referentially transparent and has no side effects) -- see https://en.wikipedia.org/wiki/Pure_function | |
| ▲ | NeutralForest 6 hours ago | parent | prev | next [-] | | I'm working with Python and I'm sympathetic to the problem so I'd be curious if you have examples of what Python issues are fixed with OCaml. | | |
| ▲ | rienbdj 5 hours ago | parent [-] | | A few ways in which Python is not really functional: The scoping rules of Python are not lexical Lambdas in Python are not multiline Recursion is not a practical way to write code due to stack overflows Monkey patching |
| |
| ▲ | nesarkvechnep 4 hours ago | parent | prev [-] | | Pure functional doesn't mean no side effects but controlled side effects. |
|
|