• 0 Posts
  • 21 Comments
Joined 1 year ago
cake
Cake day: June 30th, 2023

help-circle






  • I don’t mind paying for tools that help me do my job. For several years I even had a personal licence for “all products pack” thing. Their IDEs do a decent job.

    There are better tools for specific things, but overall as an IDE, it’s pretty good and makes you effective. And especially if you have to use Windows, it’s integrating enough tools that you don’t have to mess with the Windows crappy tooling that often.

    That said, it’s still a big fat slow IDE. For a while now I’ve been using neovim my modernized Linux toolkit and for the most part, I’m happier with it then I was with IntelliJ and Goland and the rest. Happier enough to not having a licence for JetBrains any more.

    And recently I’ve looked into Zed. Zed looks pretty neat so far, but it’s still under development. Once things stabilise there, I might commit to it and switch full time to Zed. It’s got a few nice things that I miss from IntelliJ, but it’s way, way more responsive.


    Back on topic: I wanted to say I don’t mind paying for IDEs, if they’re good tools. But this is more of an ideological challenge and I’m always trying to keep myself from overreacting. So while I don’t agree with you in general (“don’t trust paid IDEs”), I might agree with you specifically (“don’t fall for JetBrains’ lure and Microsoft-like tactics”).








  • One thing to add that I haven’t seen is that for big projects, there’s often nobody that could understand it all. People either get their individual components it they understand how stuff interacts, it’s very rarely expected that new people in the project, even if very experienced, can just understand everything at once.

    What you said that maintainers know every single fob is very frequently not the case at all! But since they get the big picture, they know in which part to look, and with their experience, they’ll know what to look for in that part, it may seem to you like magic. It’s not, it’s just experience.

    Don’t get discouraged though!

    Getting into big open source projects as a junior -level can be difficult, but often isn’t that hard - a lot of projects often need help and will take anything they can get. And if your experience already partially aligns with what you’re getting into, even better. If you reach out and be upfront about it, you’ll usually get pointed in some way.

    Now, you seem to only have worked on your own, with smaller code bases. That means, you don’t have a problem of code organisation. So you can’t understand a solution if you don’t know what the problem is.

    So how would you go about it?

    My suggestion is to maybe get the. 10,000ft overview. Also, understand the project workflow. Projects usually have specific ways of doing things - how to build, test, run things. Try to figure out how to build and run the software on your own. If you make it, that’s a great step!

    Then dig into one specific component/module/part. After a bit of study, you may be able to understand that component and find a simple thing that you can change about it. If you get this far you’re golden, you’re doing more then a majority of users that software.

    Now if you’re interested, you can dig more, or reach out to devs, saying what your experience is and how far you got, and ask them if you can help. And take it from there.




  • I wanted to suggest something like this. Code-freeze wise, you can have a “minor” and “major” problems, major problems block the feature, minor ones let it go (but you now have a tech debt, and make sure that THIS process to fixing up found issues is higher-prio then new features). Of course, you decide what is minor and what major. E.g. maybe a typo in the UI is acceptable, maybe not.

    As for throwing features over the wall - I would actually suggest just changing the perspective - make QA involved earlier. The feature is not ready and not frozen unless it’s been looked at by QA. Then when a thing is frozen, it’s really ready. (Of course you’ll still have regressions etc but that’s another topic.)


  • I think it is a bit more than that.

    You point out two things:

    • the “fuck it” algorithm
    • the hidden DNS request.

    So, now, obviously if you wrote the “fuck it”, then well, you fix it. If you found the DNS library problem - find a better lib or something.

    But if you take the stance “fuck it, there’s always something”, you don’t even have a chance of finding out. If you had a test suite running 10 seconds, and suddenly it’s up by 10 more, you would notice. If you had tests running for 10 minutes, you would not.

    If you had a webapp or something that always opened “fast”, then suddenly it gets doubly slower, you’ll notice it. But if you already started slow, you won’t notice (or care, or both), when it gets even worse.

    I think that’s the point of the article. If we all dug in and fixed a little bit, eventually we’d have fast apps or tests or whatever. If you accept that things suck, you’ll make it tripply worse. It is a conscious effort to be fast.