I want to develop a game and am considering collaborating with others, potentially even making it open-source.

To make this process smoother, I need to establish an easy-to-replicate development environment—one that can be set up by non-programmers (such as artists) but is also simple for me to configure so I can focus on actual development.

I’ve explored various options (Docker, Podman, Anaconda, NixOS, VMs), but the choices are overwhelming, and I’m unsure which one is best for my needs.

I’ve had partial success with a Fedora+i3wm virtual environment (VM), creating a plug-and-play experience. However, this setup requires extra space (~3GB for the OS) and includes software already installed on the host system. It also requires users to learn i3wm and possibly use the command line, which may not be ideal for everyone.

I would appreciate any advice on how to approach this effectively.

Edit: An example of things to setup:

  • The right .Net Sdks version
  • Git
  • Git LFS
  • Format Checks
  • VScode (+ extensions)
  • Godot (+ extensions)

Final: I have read your recommendations, researched your suggestions, and looked at what other projects use (Luanti uses docker). And I have finally decided that at least for now this might be a bit overboard. I will start with a simple setup script and setup files (such as for vscode) with instructions. And if I need to in the future I will most likely use Docker.

  • catloaf@lemm.ee
    link
    fedilink
    English
    arrow-up
    40
    arrow-down
    3
    ·
    8 months ago

    You’re spending time focusing on the wrong things. Publish the code, list the dependencies to build it (preferably with a way to install them, like python’s requirements). That’s it.

    • heartbreaker@lemmy.worldOP
      link
      fedilink
      arrow-up
      14
      ·
      edit-2
      8 months ago

      I have seen other similar projects where the setup is a hassle, which is why I am looking into it.

      (changing requirements, custom scripts, extension)

      • JollyGreen_sasquatch@sh.itjust.works
        link
        fedilink
        arrow-up
        3
        ·
        8 months ago

        I do agree mostly with your point here, but I think you can limit the scope a bit more. Mainly provide a working build environment via one of the mentioned tools, since you will need it anyway for a ci/cd pipeline. You can additionally have a full development environment that you use available for people to use if they choose. It is important that it be one regularly used to keep the instructions up to date for anyone that might want to try to contribute.

        From my observations as a sys admin, people tend to prefer the tools they are familiar with, especially as you cross disciplines. A known working example is usually easy to adapt to anyone’s preferred tooling.

    • fartsparkles@lemmy.world
      link
      fedilink
      arrow-up
      6
      arrow-down
      1
      ·
      8 months ago

      Agreed. They’re also solving problems that may not even exist, building a tech stack that needs to be maintained in addition to the game itself and adding all the baggage of supporting users who have needs that aren’t catered for with that stack (for instance a specific Windows-only tool).

      The game engine should abstract most of these problems away. The rest can be solved with standards like what linter/formatter for code, art asset formats and specs, etc.

      Solve problems as they arise. Time is best spent writing the game.

  • linuxoveruser@lemmy.ml
    link
    fedilink
    arrow-up
    24
    arrow-down
    1
    ·
    8 months ago

    Nix is probably the best way to get all of those things set up without shipping a whole distro, but there will be a bit of a learning curve. If you’d like something a bit easier to set up for development (still based on Nix), I’d recommend devenv.sh.

  • unlawfulbooger@lemmy.blahaj.zone
    link
    fedilink
    arrow-up
    20
    ·
    edit-2
    8 months ago

    Artists will probably have their own setup, software and workflow that they are comfortable with. I’d recommend letting them use their own workflow, and just discussing the interface, so to speak: what file format(s) to use and such. I think GLTF is used for assets, but I’m definitely not an expert.

    As for other devs, most required tooling (e.g. Unity or Pycharm or whatever) are one-time installs that you can list somewhere. And language libraries/dependencies are a solved problem (e.g. pipenv, cargo, yarn).

    But if you really want to set this up, nix (or lix) is probably your best bet for a total devenv that is exactly reproducible, assuming that works for WSL (or no one uses windows).

    Otherwise docker/podman or devenv will probably be doable as well.

  • utopiah@lemmy.ml
    link
    fedilink
    arrow-up
    20
    arrow-down
    1
    ·
    edit-2
    8 months ago

    Well I (a developer) collaborated with an artist (3D modeler) recently and… I did not ask them to install anything.

    Instead what I did is a develop a Web drag&drop page. They’d visit it, drag&drop their model and… see if it worked (e.g. visually or running animations) as they expected. That was it.

    IMHO finding the boundaries that are important, and thus how to collaborate, is more important than a unique reproducible environment when roles are quite different.

    TL;DR: IMHO no, you don’t, instead find how to actually collaborate.

    set up by non-programmers (such as artists) […] requires users to learn i3wm and possibly use the command line

      • Telorand@reddthat.com
        link
        fedilink
        arrow-up
        20
        ·
        8 months ago

        No, I mean: why is a window manager a requirement? You’re developing a game. Your dev environment requirements should be DE/WM agnostic.

        If you intend your collaborators to be using Linux, you should look into Distrobox/podman and have your containerfile ready for deployment. Or just tell people what tools they need installed.

        Enforcing a particular DE/WM will make development harder for some people, and it will add unnecessary burden to your project.

        • heartbreaker@lemmy.worldOP
          link
          fedilink
          arrow-up
          3
          ·
          edit-2
          8 months ago

          What you are saying is correct, and why I am looking for a better way.
          It was just simpler for me to set up a complete image that can be used on a VM.

  • just_another_person@lemmy.world
    link
    fedilink
    arrow-up
    8
    arrow-down
    1
    ·
    edit-2
    8 months ago

    It really depends on what you intend to develop in, but I can say containers aren’t the way to go whatsoever.

    Every gaming SDK or IDE I’m aware of has their own version of sandboxed environments. You just start a project, clone it, then let their package management tooling do the rest.

    Maybe if you explain a bit more about your approach you could get more constructive answers.

  • Dr. Wesker@lemmy.sdf.org
    link
    fedilink
    English
    arrow-up
    8
    arrow-down
    1
    ·
    8 months ago

    VS Code has dev containers, which can be nice.

    But honestly, this is all overboard. Not sure what language you’re working in, but this is what virtual environments are for. For instance in Python, you can use a tool called Poetry.

    • Botzo@lemmy.world
      link
      fedilink
      arrow-up
      2
      arrow-down
      1
      ·
      8 months ago

      I take it a step further with distrobox to provide the tooling (like the preferred version of poetry and other cli tools). That ensures people can jump in with the right versions of tools easily, and changes to tooling can be disseminated with a commit (and container build).

      But I agree. Get started and solve these problems when they are problems.

  • mystic-macaroni@lemmy.ml
    link
    fedilink
    arrow-up
    6
    ·
    8 months ago

    Interesting idea to take “non-programmers (such as artists)” out of their normal professional workflows (e.g. adobe creative) and putting them in yours for the sake of productivity. What hardware are we talking about? Are you running a vm? That won’t work on apple silicon. (Which creative types overwhelmingly use)

    Bonus question: You “want to develop a game” and are “considering collaborating with others”? What’s the scale and where are we at with making the game? Because worrying about your team’s workflow sounds a lot like having that $10 million idea and buying a domain name before writing a line of code.

    That said, I’ve done this kind of thing before. Pick something. Anything. And write scripts to automate most of it. You will never get a 100% turn key solution, and everything has a tradeoff. Solve enough of the problem and go work on your game.

  • moonpiedumplings@programming.dev
    link
    fedilink
    English
    arrow-up
    5
    ·
    8 months ago

    Here’s my commentary on the options you listed in the image:

    Anaconda: They changed the licensing so that it’s not really fully FOSS, as the repos have restrictions on them. There are also other issues like this dark pattern of a download page.

    But, forgetting about the licensing or problematic company practices: The software itself is trash. Worst thing I’ve ever used. It’s sooooo slow to install packages when it’s doing the “solver” thing. You can use something faster like mamba or miniconda, but then you still have to deal with package availability being poor, as the anaconda repos don’t have everything, and much of what they have is often too old.

    Docker desktop: It’s proprietary. I mean you can use it, but you seem to be interested in open source stuff. Also see caveats to podman desktop below.

    Podman Desktop: Technically this will work. But podman desktop is really designed more for development of containerized applications, rather than developing in containers.

    Nix: Nix doesn’t work on Windows, so you would have to require WSL or something like that.

    Fedora VM: I recommend enlightenment as a desktop environment. Very small, but also modern and clean looking. You’ll have to configure it to be a bit more similar to windows, but it’s a lot more intuitive to use than i3.

    There are some other caveats to your environment. “The right .Net Sdks version” — however, the best extensions for C# development are proprietary and cannot be freely used in the fully FOSS versions of vscode.

    it also requires users to learn i3wm and possibly use the command line, which may not be ideal for everyone.

    Yeah, don’t do this. I agree with @utopiah@lemmy.ml, work with them, rather than forcing them to work with you. Collaboration goes both ways.

    Another recommendation I have is to just see how people in a similar circumstance do what you do. There are plenty of people who do software and game development on twitch, and you can just go on their streams and ask how they collaborate. One method I saw is using trello, a task management software, and artists would upload models there as deliverables. They already have their own workflow, which they probably work efficiently with. And it’s not really the job of an artist to integrate models and art into the game, that’s the programmers job.

  • Horse {they/them}@lemmygrad.ml
    link
    fedilink
    English
    arrow-up
    4
    ·
    edit-2
    8 months ago

    you definitely don’t want to pack an OS and WM in your dev environment
    anyone who doesn’t already use i3 will be slowed to a crawl until they memorize the keybinds, plus some people just really hate using the keyboard for 90% of navigating, and if they don’t already use fedora will need to figure out where everything is

  • dangling_cat@lemmy.blahaj.zone
    link
    fedilink
    arrow-up
    5
    arrow-down
    2
    ·
    8 months ago

    It’s a solved problem! Try https://containers.dev/

    Artists can just clone the repo and open your project with a supported editor(like VSCode). Done. You can write a config that says what base OS, install packages, and install VSCode extensions (via VSCode workspace settings).

    Many projects use this setup and it has been magical.

  • lefixxx@lemmy.world
    link
    fedilink
    arrow-up
    3
    ·
    8 months ago

    Only use a dev environment for things that need dev environment. Use whatever your coding team is already familiar with.

  • OneCardboardBox@lemmy.sdf.org
    link
    fedilink
    English
    arrow-up
    4
    arrow-down
    1
    ·
    edit-2
    8 months ago

    I set up a very straightforward Godot dev environment yesterday using toolbox which is built on top of rootless Podman.

    • Create a new fedora toolbox
    • Enter toolbox
    • Install DotNet dependencies, git, etc with dnf
    • Install Godot binary from release page
    • Turns out there were other dependencies I needed
    • Godot wanted a few Wayland libs on the container, so I installed Weston (maybe overkill)
    • Godot wanted libxrandr so I added that too
    • Godot just works ™

    The nice thing about toolbox is that it uses my native host Wayland compositor. So whatever I have running in the toolbox can be interacted normally through sway (my host WM).

    You can either distribute a container image with your given toolbox configured, or just document the setup steps.

  • Ludrol@szmer.info
    link
    fedilink
    arrow-up
    2
    ·
    8 months ago

    I was collabing on a game with an artists (godot + git) and they just used the github gui for windows and it worked great. They just made art in their program of choice and drag and drop into the folder. They clicked push button and it worked for a game jam.