Do you have a story to share?

  • rudyharrelson@kbin.social
    link
    fedilink
    arrow-up
    78
    ·
    9 months ago

    A couple of years ago, I was modding a fresh install of Skyrim and thought, “I can use git branches to make it easy to switch between different mod combinations rather than uninstalling/reinstalling mods when something breaks or when I want to change things up.” Worked well!

    I had branches that were mostly vanilla with enhancements, and then branches that had all kinds of ridiculous mods. If I wanted to switch to playing a ridiculous build of Skyrim, I’d just close the game, checkout the branch I wanted, and start the game.

    • folkrav@lemmy.ca
      link
      fedilink
      arrow-up
      3
      ·
      9 months ago

      Interesting! Didn’t slow up too much with all the binary files? I guess you weren’t swapping around sets of 300 content mods either lol

      • rudyharrelson@kbin.social
        link
        fedilink
        arrow-up
        1
        ·
        9 months ago

        It’s been a couple of years, but I don’t recall it being particularly slow switching between branches. I had a pretty beefy rig to begin with, which probably helped.

    • Deebster@programming.dev
      link
      fedilink
      English
      arrow-up
      2
      ·
      9 months ago

      I wish all rules, Ts&Cs, contracts, etc came like this. It might make it less unfeasible to follow what’s changed when something forces you to agree to the new version of the terms.

  • RonSijm@programming.dev
    link
    fedilink
    arrow-up
    20
    ·
    9 months ago

    I use it to backup my save games. Not sure if that’s conventional.

    For example, I’d MKLink %appdata%/Local/Pal/Save/ to a folder in my save repo, and commit that every once in a while.

    • 7heo@lemmy.ml
      link
      fedilink
      arrow-up
      8
      ·
      edit-2
      9 months ago

      Fun story, in 2012 I got the idea of making a git based “cloud” save system with branching, to explore multiple story paths in games.

      I implemented the FileSystemWatcher (the equivalent to Linux’s inotify) component in C# on Windows, was able to detect when games were saved, and commit that to git, and stopped there.

      Feel free to implement that, I’d love to save on implementation time 😇

  • Ephera@lemmy.ml
    link
    fedilink
    arrow-up
    18
    ·
    9 months ago

    I wanted to automate the setup of my desktop environment, but didn’t know what got changed in the individual config files when I tweaked a setting in the UI.

    So, I did a git init in ~/.config/, added all files to an initial commit, and then made the change in the UI. Afterwards, a git diff showed the exact changes I wanted.

  • cafuneandchill@lemmy.world
    link
    fedilink
    arrow-up
    8
    ·
    edit-2
    9 months ago

    I used it once for version controlling my master’s when I was writing it. I wrote it in Markdown with Pandoc syntax, so it worked. I eventually gave up and just used LibreOffice, though, since it was a hassle

      • mumblerfish@lemmy.world
        link
        fedilink
        arrow-up
        2
        ·
        9 months ago

        I worked with LaTeX a lot, but none of my collaborators used git. They just dump the files in dropbox. Still nice to use git just for yourself so you can view changes easily.

      • cafuneandchill@lemmy.world
        link
        fedilink
        arrow-up
        2
        ·
        edit-2
        9 months ago

        Both lol. The reason is that I had to render it to DOCX each time for my PI to review it, because she was an old retrograde woman. Therefore, rendering the document, committing changes and reading Git and Pandoc documentation took time – the time that I could’ve used to write the actual thing

  • atomkarinca@lemmygrad.ml
    link
    fedilink
    arrow-up
    4
    ·
    9 months ago

    ifc-git.

    ifc is an iso standard for 3d construction projects, which includes all aspects of a building data. because ifc is in human-readable form, versions of the same project can be diffed, hence ifc git.

    this is a really underappreciated project.

  • Corbin@programming.dev
    link
    fedilink
    English
    arrow-up
    4
    ·
    9 months ago

    I’ve put ASTs directly into git repositories by encoding each leaf as a blob and each tree as a tree. Since git objects are content-addressed, this gives deduplication of ASTs for free, including CSE for sufficiently-pure ASTs.

  • xcjs@programming.dev
    link
    fedilink
    arrow-up
    3
    ·
    9 months ago

    I tried to take hourly snapshots of an already-large Minecraft world using Git, but after a few years of snapshots, the repository became corrupted.

    One of the issues was that regardless of any player-based changes that occurred, the spawn regions were always different as they were always loaded in memory.

  • Swordgeek@lemmy.ca
    link
    fedilink
    arrow-up
    3
    ·
    9 months ago

    Not very clever or rare, but extremely useful. On my persistent Unix/Linux boxes, I “git branch /etc” as soon as it comes up. Then all of my admin config gets committed whenever it’s changed.

    • metiulekm@sh.itjust.works
      link
      fedilink
      English
      arrow-up
      3
      ·
      9 months ago

      Have you tried etckeeper? I haven’t, but it’s supposed to be an improvement over just using git in this usecase.

  • madeindjs@programming.dev
    link
    fedilink
    English
    arrow-up
    2
    ·
    9 months ago

    I just discovered from So You Think You Know Git - FOSDEM 2024 that you can use Git to generate columns:

    seq 1 24 | git column --mode=column --padding=5
    

    Will render:

    1      3      5      7      9      11     13     15     17     19     21     23
    2      4      6      8      10     12     14     16     18     20     22     24
    

    It can be useful to list files / permissions in a directory in multiples columns

    ls -lah | git column --mode=column --padding=5
    

    (Ok, it’s useless)