Handling the great code forge fragmentation

(alexselimov.com)

44 points | by mooreds 4 days ago ago

31 comments

  • bluehatbrit a day ago ago

    I don't think we're anywhere close to the downfall of GitHub. It'll be a very slow decay.

    The fact is, lots of people are very happy using AI tools, and most of those hook straight into GitHub. If AI is driving all this new code, it's only going to make moving away from GitHub more painful.

    Businesses I've spoken to hate the idea of moving their code forge. Migrations like that suck and they're expensive. There isn't a meaningful differentiator between the other managed options, so the goal would just be to stand still. Unless GitHub's stability spirals fast I don't see a big wave of businesses leaving.

    I say all this as someone who's been moving their code over to their own Forgejo instance. I'm all for more competition and fragmentation in this area, I just don't think it's happening soon.

    • jamesfinlayson 17 hours ago ago

      > Businesses I've spoken to hate the idea of moving their code forge. Migrations like that suck and they're expensive. There isn't a meaningful differentiator between the other managed options, so the goal would just be to stand still. Unless GitHub's stability spirals fast I don't see a big wave of businesses leaving.

      Yep, been through a somewhat pointless GitHub to GitLab migration because, at the time, GitLab was cheaper. Now GitHub is cheaper again and the migration was a big annoying and expensive project.

    • nativeit 20 hours ago ago

      I’m prob not the “average” user in this context (meaning that I am not a SWE or professional developer, but rather a code-curious sysadmin and consultant with too many hobbies), and I consistently use GitHub Copilot to write and push code to a self-hosted Forgejo…unless it’s a productive fork for contributing, or simply something I don’t want to take up space on my own server, anyway. I agree it’s likely to be a slow decay. GitHub is problematic, but it doesn’t summon the sort of white-hot resentment that pushed people to abandon other platforms en masse.

      I am concerned that it will be much more difficult to discover FOSS projects with whatever the new regimes are, similar to how Discord has walled off a great deal of the discussion forums and collaborative groups.

    • 0xc133 21 hours ago ago

      > It'll be a very slow decay

      Two ways. Gradually and then suddenly.

    • NitpickLawyer a day ago ago

      > and most of those hook straight into GitHub. If AI is driving all this new code, it's only going to make moving away from GitHub more painful.

      Anecdotal, but we've had success with gitea and having agents use "tea" (gh cli alternative) as a skill. If the cli tool you're asking it to use is similar enough it will use it instead of gh without any (major) issues.

    • duped a day ago ago

      I think this is true of github as a forge but it faces the threat of unbundling. Off the top of my head

      - Code repository

      - Project wiki

      - Project roadmap/planning

      - Static site hosting

      - Issue tracking

      - Internal and external contributions (PRs)

      - Code review

      - Cross platform CI pipelines/runners

      - Release hosting

      Of these key things, what is Github good at and how much can you improve by providing an alternative that's faster/cheaper/more robust?

      Of these I think the only thing Github stays competitive at is "code repository." Everything else kinda sucks and/or is expensive and flaky.

      Just as an example, there's that hilarious "just give me an EXE" Reddit post from a few years back. It's fun to laugh it given the state/purpose of Github but you can also look at that as a lost market for Github. Why can't you provide a nice landing page with downloads/installers in a very clean landing page for your project on GitHub? It could even be a premium feature if it means paying for storage/bandwidth.

      And don't get me started on actions. Absolute trash tier product that they should be ashamed at the state of.

  • woodrowbarlow a day ago ago

    forge "fragmentation" is a good thing. git was meant to be decentralized from the start. re-centralizing on a single provider would just repeat the github saga all over again.

    • ahartmetz a day ago ago

      Yeah, it's like lamenting the great food supply fragmentation.

      • antonvs a day ago ago

        But Soylent Green is widely available, cheap, and consistent!

    • selfhoster1312 a day ago ago

      I upvoted because i agree with the message. Although, it would be much better if we could just have a single identity over those providers, just like we had with mailing lists.

  • spankalee a day ago ago

    It's a huge miss for this article to not talk about atproto, Tangled, and how protocols can solve the fragmentation issues - both between different services and by allowing projects to run their own host while being connected to the network.

    https://tangled.org/

    With the atproto approach you don't have to worry about reserving usernames specifically for one forge or another - usernames are atproto handles, your Bluesky handle, custom domain, etc.

    I'm not sure if Tangled itself is the right incarnation of these ideas, but a protocol for PRs, issues, forks, and activity is the right direction for the industry.

    • embedding-shape a day ago ago

      It doesn't even seem to mention federation over/with git and/or ForgeFed (https://forgefed.org/), both efforts predate both atproto and Tangled, and seems like a bigger miss considering the article is literally about git forges.

    • selfhoster1312 a day ago ago

      I think it's great people are working on it, but why reinvent the wheel? Radicle and Forgejo/Forgefed were already under way before starting Tangled. What would be a selling point that would justify breaking compat with existing solutions ? (to be fair, forgefed is largely unimplemented so far)

      • spankalee a day ago ago

        atproto apparently has some real advantages over ActivityPub in terms of data portability. Similar to Bluesky vs Mastodon, with Mastodon you're fairly strongly coupled to your server, you' can't just move your data and retain all your connections. atproto makes that possible, and that could be really important if you want to say move from a shared forge to a self-hosted one or vice versa.

        atproto apps also tend to separate the PDS form the app view, so you can easily use the same data with different front ends.

        And, atproto's identity model is much better. Rather than being tied to a server like the data, it's DID-based and you can use it with multiple PDSes.

        • account42 7 hours ago ago

          atproto as it is today is effectively centralized.

          • spankalee 2 hours ago ago

            That really isn't true. I know people who run their own PDSes, and who've moved their accounts from Bluesky's to their own and back. You can't do that kind of thing with Mastodon. Blacksky also runs their own PDS, relay, and app view.

            And that's just the Bluesky-like apps. Other non-microblog atproto apps use their own PDS, or store data on yours.

  • account42 7 hours ago ago

    > I hope to someday be a 10x bathroom tile developer with a git contribution heatmap being a solid color.

    But why? Those are there to manufacture engagement on GitHub, it doesn't have any inherent value to track that.

    > Get your username locked in NOW

    Instead use the opportunity to move to your own domain.

  • ncruces 21 hours ago ago

    From the point of view of "small open source project" I honestly have no idea what I would move to.

    I happen to make, I think, $5/month in donations (thank you). According to GitHub's numbers, they offer me about $25/month in the product everyone likes to hate: Actions.

    I could certainly cut costs if I had to (half the cost, certainly not half the value, is mac runners), but my projects are definitely in a better shape for having this.

    So: where do I get a better deal?

    • nativeit 20 hours ago ago

      I have found Forgejo’s actions to be functional for my own purposes, although rather incomplete compared with GitHub. That said, porting an action from GitHub to Forgejo was fairly easy the one time I was forced to do so.

      • ncruces 10 hours ago ago

        Actions, as I get use them for free really seem irreplaceable.

        See, I only have one project where this actually matters (and help maintain another), but: I get to test on mac and Windows, both ARM and x64, for free.

        Then, with a one line import, I can use Linux+QEMU to test a bunch of other architectures.

        Adding a couple other deps, I can have VMs to test: FreeBSD, OpenBSD, NetBSD, illumos, Solaris… the list goes on.

        And thanks to other providers I now also get RISC-V, IBM Z and Power runners for free.

        So, yeah, for the other projects, I could have CI on a self-hosted Forgejo instance. I could also run tests on my dev machine before commiting and get 95% or the same benefit.

        The value in CI is that it can run tests that are inconvenient to run locally.

  • a day ago ago
    [deleted]
  • skydhash a day ago ago

    That looks like a whole load of work. The thing thay is not defined is why I should do it.

    Also forge are already fragmented. I use OpenBSD and the software in ports comes from all over the web. You got the forges, web links,… As far as collaboration go, you can always send an email to the person. Up to them to accept it. If I care that much, I will publish a blog post or share it via the community’s channel.

    Those articles look like linkedin-style post to work on your brand or for some internet points.

    • embedding-shape a day ago ago

      I think these articles are meant for people who entered the developer ecosystem after GitHub became ubiquitous, because those developers basically only ever known GitHub, and some even see GitHub and Git as synonyms.

      The rest of us who started developing before GitHub, or been around communities that self-host their infrastructure, we're already used with everything being spread all over the place, this place accepts patches via email, this one wants a URL to a pastebin containing the patch, others use GitLab, some the public service, others self-hosted, and so on.

      I don't think this sort of article is for us, but for the former mentioned usergroup.

      • ChickeNES a day ago ago

        > this place accepts patches via email, this one wants a URL to a pastebin containing the patch

        I for one would never contribute to a project that requires one of the above. I know some will shoot back with "but Linux!", but that's the exception that proves the rule.

        • SoftTalker a day ago ago

          And projects that want emailed patches might consider it a good filter for the sorts of contributors they want.

        • account42 7 hours ago ago

          And maybe those projects don't want your spend time on your contributions if sending an email is already too much effort for you.

        • embedding-shape a day ago ago

          I think that's exactly why they keep their existing workflows :)

        • skydhash 21 hours ago ago

          > I for one would never contribute to a project that requires one of the above.

          They’re not exactly begging for your contribution, are they? It’s very much voluntary. They’re just stating how to communicate with them.

    • ChickeNES a day ago ago

      > The thing thay is not defined is why I should do it.

      Most of the reasons seem to boil down to "X bad", where X is some combination of Github, Microsoft, America, and AI

  • thangalin a day ago ago

    [dead]