this post was submitted on 20 Nov 2024
26 points (93.3% liked)

Python

6400 readers
13 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 1 year ago
MODERATORS
 

Welcome to a new era of interconnected content discussion with PieFed – a link aggregator, a forum, a hub of social interaction and information, built for the fediverse. Our focus is on individual control, safety, and decentralised power.


Like other platforms in the fediverse, we are a self-governed space for social link aggregation and conversation. We operate without the influence of corporate entities – ensuring that your experience is free of advertisements, invasive tracking, or secret algorithms. On our platform, content is grouped into communities, allowing you to engage with topics of interest and disregard the irrelevant ones. We utilise a voting system to highlight the best content.


Video introduction the codebase

you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 4 points 3 days ago (2 children)

Pretty much.

It's a hobby project so we work on things we find fun or interesting. To me, tests are neither of those.

[–] [email protected] 1 points 3 days ago

Rimu I love your approach to mod tools!

Sorry if I ask this but now that Lemmy has extism plugins, wouldn’t it be better if you tried to extend lemmy with your python skills rather than keeping to build from 0? Would help the fun even more I think (?)

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

πŸ˜„ understandable. Are you open to one or more of the things I mentioned being added? Strict type checking, tests, formatter, linting?

Anti Commercial-AI license

[–] [email protected] 3 points 3 days ago* (last edited 3 days ago) (1 children)

BTW I recently added the database structure for post licenses and have PeerTube video licence information being saved into the DB when they federate to us. However there is no UI that will let people specify a license for their PieFed posts or comments. The UI needs to present a list of licenses to choose from and reading about all the different ones made my eyes glaze over.

You might like to start there as it seems to be an interest of yours!

[–] [email protected] 2 points 3 days ago

I feel like I'm getting nerd-sniped πŸ˜„ Believe it or not, writing tests, adding type hints, adding a formatter and linting, are actually more interesting to me than UI-work πŸ˜‡

I'll see if I can make some time this week, but no guarantees!

Anti Commercial-AI license

[–] [email protected] 3 points 3 days ago* (last edited 3 days ago) (1 children)

Yes we could really do with all of those. Patches welcome. Other than a preference for PEP 8 I don't have strong opinions about particular linters or formatters.

I see the benefits of types but am not puritanical about it. I'm ok with the way we're using types at the moment. Most utility functions have types specified, especially those that return database objects so the type information flows up to the routes pretty well. I mostly see it as a way to help my IDE autocomplete work better than as a holy grail. I'm sure there are places where more types could be added but making it a policy that every function must have a type signature seems OTT.

[–] [email protected] 1 points 1 day ago

To keep it simple

testing and static type checking -- catches all the bugs

linting and formatters -- so git diff isn't pure noise showing trailing and unnecessary whitespace and collaborators won't have to go back to correct things that coulda been automagically fixed.

in code documentation -- Can be extracted by Sphinx as part of the documentation process. Hint: interrogate is your friend.

gh workflows -- to have the test suite run against various py versions, os, and maybe architectures. Without which not even confident it runs well on your own machine let alone anywhere else.

requirements.txt -- is an output file. Where is requirements.in ??

xz hacker sends his love

Makefile -- for people who like a ton of shell scripts in their Python packages. Up until realize that ya know which Python interpreter is being run, but can't have any level of confidence about the shell interpreter. Cuz it's a big unknown and unknowable. Gotta just take it on faith.