I like looking for issues that are tagged as „good first issue“.
There are sites that make this even easier.
Look for projects that you think you might want to support in a language you know and help them out in those issues.
I like looking for issues that are tagged as „good first issue“.
There are sites that make this even easier.
Look for projects that you think you might want to support in a language you know and help them out in those issues.
Oh that is great! Thats exactly what I was searching for. Thank you!
When you say you like Javascript, do you like web frontend dev? If so, you could try contributing to lemmy UI - could be pretty rewarding to see your work being deployed on the instance you use!
I did some projects in React and Vue. I see Lemmy is using inferno. I don't know that one yet, but I will look into it. Thank you for the hint.
There is a new SvelteKit JavaScript project for a lemmy-ui alternative: https://lemmy.world/comment/258368
From what I've heard - it's similar to React! Hopefully you like it
https://github.com/topics/good-first-issue
Any issue marked "good first issue" should be good for someone new to the project to tackle. The link I posted, the 2nd entry is a repo with docs on how to contribute to projects.
My best recommendation would be to find a project that is written in languages you're familiar with and maybe even is on a subject you're familiar with (e.g. data management, audio transformation, business logic, statistics, whatever) and just dive in.
Any chance you know more than one human language? Some projects need translators!
.
That really depends on the language pair. Even a big language like Chinese has a lot of interesting stuff on github that never gets translated because the number of people can and are willing to translate isn't that high.
English and German. And that is an interesting idea as well.
It's not as "glamorous" as coding often is seen as, but what almost every open source project needs is better documentation. It's also something that can help you be productive as you're learning a codebase.
.
Honestly, just contribute to whatever software you're already using! The most obvious example (that somebody else mentioned already) is Lemmy itself, but surely there are many other open source pieces of software that you use on a daily basis. If there's something that annoys you, or think it could be improved... there you go.
At least, that's how I got into programming.
For me, it was starting to use neovim that got me into open source. Because it has so many plugins, and authors are usually super thankful for contributions (most of them have day jobs and limited free time).
I wrote my own neovim plugin and I got like 10 people making contributions to it within a few months. It doesn't sound like much but it actually feels really nice and fun.
But yeah, if you want python, it's not the right start for you. Plugins are written in lua and it's not as full featured as python. But much faster.
wait people still use lua?
There is nothing better for small footprint and amazing speed, unless you want to write C directly. Neovim has it integrated in it's core, which means plugins are really fast.
Lua is incredibly easy to embed.
The most rewarding thing is contributing to some project you are using, helps keep it alive.
.
First check if anything you're using is on github, accepts contributions and has some open issues that looks simple to solve, or if theres some new feature u want to propose, then follow their steps for contributing.
Don't go looking for issues on stuff u don't use or don't plan to use, or at least some friend/family uses, it'll feel like a chore and you will have to spend a lot of time figuring out how stuff is supposed to be used what anything does and why...
This is an unusual question, but how have you been programming for four years and not know how OSS works?
Don’t you interact regularly with GitHub for work?
I have met a lot of people that don't interact with most of the outside code world for various reasons. Mostly it's draconian rules (sometimes company mandated, sometimes regulatory), but sometimes what they've been working on is just so niche that there really aren't anything out there for them to interact with.
I'd be so sad if I were in that position :(
But maybe I'd also be making so much money that I'd be happy :)
They asked how to discover good projects to work on. They didn't say they didn't know how GitHub works. I've been a developer for almost 20 years and, while I love open-source software, I don't interact with many open-source projects on GitHub because my day job and my own projects take up a lot of time. I've made a couple of contributions but time has never permitted me to get too deeply involved.
Eh its fair enough, but the actual process of OSS isn't much different to just working software at a job.
Now finding a project to get your teeth stuck in, that's a bit harder. But that's less a technical skill and more about having enough introspection to figure out what you'd like to work on for free haha
.
Searching github by the "good first issue" tag can be a good way to get your feet wet on open-source contribution with small, often low-risk tasks that'll get you used to the contrivution flow. Then, you can find a project you care about, find (and open) an issue with it, and make the improvement yourself! It doesn't have to be big, a lot of small contributions add up quickly.
If you're into JavaScript, https://github.com/dynamoose/dynamoose is a project I maintain, and has a lot of great documentation, Slack channels, and more.
Although my attention on it goes in waves, it could for sure use more help. I'm also totally willing to help answer questions and point people in the right direction.
We currently have 80 open issues, 6 open PRs. 9 of those issues are marked as "good first issues" and 8 are marked as "help wanted".
So there are for sure some easy jumping off points to get started. But I'm also always happy to answer questions and assist in anyway I can as well.
Beyond that, it's all about diving into something. I found Dynamoose when it was much smaller, and just started with small contributions and built up from there. Following developers on social media, and following programming communities and newsletters can be helpful too.
Sounds like you want to contribute to something for the sake of contributing (hopefully that's not true). You're skill is worth something.
Going to spew some jaded bs: Don't pick a project that makes you sign some bullshit release, pick something that some rando started and released with no intention of monetizing. Volunteer to work on a passion project that you're also passionate about. Not something that will be used by some 9-5 300k a year tech bro. That's just my opinion though. "Open source" has been used by big companies to generate free labor (looking at you Adobe, etc).
Off the top of my head, the SignalK project is something I've wanted to volunteer for. They make some software that lets marine sensors (depth sounders, Windex, speed paddles, temp sensors, etc.) Communicate in one standard format. They built a web app with node and react as a proof of concept. It could for sure be improved. It'd be neat if it caught on because vendor lock-in is huge in marine hardware / software.
When I released my chrome extension a few years ago, someone went in and immediately send a pull request for dark mode support, then gone in a flash. I was super impressed.
All things programming and coding related. Subcommunity of Technology.
This community's icon was made by Aaron Schneider, under the CC-BY-NC-SA 4.0 license.