In ~/src Mostly because I'm too lazy to type "source".
Linux
From Wikipedia, the free encyclopedia
Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).
Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.
Rules
- Posts must be relevant to operating systems running the Linux kernel. GNU/Linux or otherwise.
- No misinformation
- No NSFW content
- No hate speech, bigotry, etc
Related Communities
Community icon by Alpár-Etele Méder, licensed under CC BY 3.0
Putting one directly under the home directory feels like a psychopathic move, so I stay by XDG and put them under a subdirectory of xdg-documents
~/git, for projects I cloned from the web because I don't know how to code :(
~/src
I NEED TO LEARN HOW TO GIT.
Don't worry, the basics are really easy to ~~git~~ get down, you can read any beginner guide to start trying it out, for example this one on baeldung seems pretty alright by a quick skim, or, if you prefer a more playful approach, definitely check out ohmygit.
If you want to try a git hoster as well, make a GitHub profile if you want to go where most everyone is, so you can also easily contribute to others' projects, otherwise, if you care about staying on a free platform, make an account on Codeberg, fewer people, but all great like-minded free software supporters
..or make one on both, ngl
Thanks. I do have a codeberg, a Gitlab and a github account (all I have here are my blacklist and white lists). If my kids allow me, I'll start swimming on this waters this weekend. I've only seen how you guys basically hold repose of pretty much anything and automate workflows and configurations so easily, it's amazing.
~/.projects
Similar, but I’m not ashamed of having my projects on display, so it’s just ~/projects
for me.
${HOME}/repos
~/workspace/git
That way I can also keep other stuff in the same "workspace" directory and keep everything else clean
I have a Code, simulations, ECAD, and FreeCAD folder in the workspace folder where projects or 1-offs are stored and when I want to bring them to git, I copy them over, play around in the project folders again, then copy changes over when I am ready to commit.
I could better use branching and checking out in git, but large mechanical assemblies work badly on git.
~/src/${reponame}
~/code/$LANGUAGE/$REPONAME
~/git
I used to use ~/dev
but for years now I use ~/Workspace
becaue Eclipse made me do it
~/code
for everything I want to change/look at the source code.
~/.local/src
for stuff I want to install locally from source.
~/dev/
, with project/org subdirectories
Admittedly, that irks me slightly just because of the shared name with the devices folder in root, but do what works for you.
I actually have my whole home directory like that for that reason haha
bin - executables
dev - development, git projects
doc - documents
etc - symlinks to all the local user configs
med - pictures, music, videos
mnt - usb/sd mountpoints
nfs - nfs mountpoints
smb - smb mountpoints
src - external source code
tmp - desktop
This is pure insanity. Chaos.
~/src/
Simple, effective, doesn't make my home folder any more of a mess than I already left it as.
C:\repos
or ~/repos
All over the place...
~/dev
/dev/null
~/repo for code I write and ~/src for code I didnt.
~/Projects
XDG Documents folder
For a project called "Potato Peeler", I'll put it into a structure like this:
~/Projects/Tools/Potato-Peeler/potato-peeler/
Tools/
is just a rough category. Other categories are, for example, Games/
and Music/
, because I also do gamedev and composing occasionally.
Then the capitalized Potato-Peeler/
folder, that's for me to drop in all kinds of project-related files, which I don't want to check into the repo.
And the lower-case potato-peeler/
folder is the repo then. Seeing other people's structures, maybe I'll rename that folder to repo/
, and if I have multiple relevant repos for the Project, then make it repo-something
.
I also have a folder like ~/Projects/Tools/zzz/
where I'll move dormant projects. The "zzz" sorts nicely to the bottom of the list.
Same, but by language, e.g. Development/Python
.
What if a project uses multiple languages?
Symlink each individual file, obviously.
Me waiting for tagging filesystems to become the standard
Thinking of the projects I work on, I don't understand the value in categorizing by language, rather than theme (~/Development/Web/
, ~/Development/Games/
) or just the project folders right there.
Yeah, everyone has to find their own way of organising, I guess. For me, there are too many different little projects that it would get messy throwing them all in one folder. And they’re so varied that I couldn’t think of one single “theme” or topic for most of them. Nothing I would remember a week later anyways.
Like others, I have a folder in my home directory called "Code." Most operating systems encourage you to organize digital files by category (documents, photos, music, videos). Anything that doesn't fit into those categories gets its own new directory. This is especially important for me, as all my folders except Code are synced to NextCloud.
~/git/vendor/<gitUser>/<repo>
and
~/git/<myName>/<forge>/<user>/<repo>
Examples:
~/git/vendor/EnigmaCurry/d.rymcg.tech
~/git/mike/forgejo/mikew/myproject
~/git/mike/github/johndoe/otherProject
Most of my code and some non-code is under ~/src
, but I have repos scattered all around for other things.
Any naming convention is fine as long as it's meaningful to you. But it's a good idea to keep your own repos separate from the random ones you clone from the internet.
~/repos
~/git/AUR|dev|whatever/$(git clone)
is where mine usually reside.
~/source
~/Projects/$TOPIC_OR_LANGUAGE/$PROJECT_NAME
ie.
~/Projects/Web/passport.ink
for a web dev project~/Projects/Minecraft/synthetic_ascension
for a Minecraft mod~/Projects/C++/journalpp
for a C++ library
~/projects
for things I made
~/git
for things other people made
I tend to follow this structure:
Projects
├── personal
│ └── project-name
│ ├── code
│ ├── designs
│ └── wiki
└── work
└── project-name
├── code
├── designs
└── wiki
~/gits
Documentation is usually a doc
folder inside the repo or just a README.md
for small projects.