this post was submitted on 29 Jun 2023
13 points (100.0% liked)

Python

6485 readers
1 users here now

Welcome to the Python community on the programming.dev Lemmy instance!

πŸ“… Events

PastNovember 2023

October 2023

July 2023

August 2023

September 2023

🐍 Python project:
πŸ’“ Python Community:
✨ Python Ecosystem:
🌌 Fediverse
Communities
Projects
Feeds

founded 2 years ago
MODERATORS
top 5 comments
sorted by: hot top controversial new old
[–] [email protected] 1 points 2 years ago (1 children)

I'm increasingly convinced that Python/JS-style duck typing is always a mistake, since you can't do default function impls for traits. Just use inheritance.

Rust's enums are even weirder, since they mix structuring with discrimination. You end up having to write everything twice most of the time. Again, use inheritance, though you'll have to choose between if chains and virtual function calls.

Python's pathlib has a major footgun in that ./foo collapses to foo, negating the main point of writing it that way in the first place.

[–] [email protected] 1 points 2 years ago

More obnoxiously than that even, imo, it’s that pathlib removes trailing slashes. Its impossible (afaict) to reproduce path.join(β€˜a’, β€˜b/β€˜) with pathlib

[–] [email protected] 1 points 2 years ago (2 children)

I've never understood returns (https://github.com/dry-python/returns), is it just a gimmick or do people actually use it? It seems like it would be awkward to use and is working against how the language was designed.

[–] [email protected] 2 points 2 years ago

I don't use this library, but one I wrote myself with maybes, eithers, validators, and various other monads in production code.

While not pythonic, I don't think its a gimmick. I allow my junior engineers to write imperative and we will pair program to convert it to use monad structures like the ones in this library. We tend to find a lot of bugs and reduce the lines of code.

While we could probably clean up their imperative code to remove bugs and duplicated logic, but I find using monad chains makes it easier to find abstractions.

Data validation and error handling probably net the most return on investment in my experience. Simply return a left at some unit of code and handle it at the end of the chain.

[–] Xophmeister 1 points 2 years ago

I like the idea of Returns β€” and partially rolled my own equivalent, before I knew it existed β€” but it probably goes against the Python grain a little too much to make productive use of it.