Re: [RFC PATCH 0/5] Introduce -t, --table for status/add commands

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 2023-10-22 07:52, Jacob Stopak wrote:
Frankly, based on my rather broad experience, there are two primary
categories of the beginners in the world of version control software (VCS),
be it git or any other product:

1) People who are forced to use some VCS at work, and they actually don't
give a damn about it.
2) True enthusiasts who love what they do, and who love expanding their
knowledge.

For the first category, nothing helps.

Interesting categorization I didn't think of splitting users that way. I
guess for group 1 that's true, if they are shown a GUI and can run 3
commands that can do what they need, that's all they will ever use.

Coincidentally, yesterday I was demonstrated for the first time in my life the way VS Code works with git, by a member of the first category of users. It's dumbed down to the extreme, hiding pretty much all the details and git specifics, which is exactly what the first category wants. Now I understand why the VS Code is so much popular.

The second category, myself included, tends to be genuinely disgusted by such an approach that makes everything nearly sterile. But I do understand why many users simply love it that way. Maybe I digress.

For the second category, a nicely
written tutorial is all they needed to start with, aided later with the man
pages, Stack Exchange, and perhaps some textbook.

This is the exact way I learned Git and became comfortable and eventually
confident using it. Reflecting on that, I really only started to become
truly confident after understanding the core underlying concepts (maybe
this is obvious / true for anything). And it's always easy once you get it.

I agree, understanding the internals of some project or product, with many or all of its outer layers peeled back, is often the only way to really get to know it.

However, there is one main benefit of a feature like this, that none of
the other options (man pages, stack exchange, a textbook) can provide:

Since the tool (Git) has access to and knows the exact state of your local environment, it can provide instant feedback that takes into account that context. That is immeasurably more helpful than trying to figure out how to best ask Google your question, and then piecing together your problem
with a similar one some lost soul ran into 10 years ago.

True, but I still think that having git put its thoughts into tables is actually not helpful. To be precise, it actually might be helpful, but only to the first category of users, who will never reach it. I mean, never say never, but in this case I'm pretty sure it's safe to say it. Unfortunately.

Please don't get me wrong, I understand your reasoning, but again, it all comes down to the two categories described above. IMHO, the second category will likely start turning off the default hints sooner than turning the
table formatting on.  The first category will choose some GUI anyway.

The default hints are an intersting consideration. I've found them handy
for commands that I use infrequently, and also when I find myself in a
scenario that is not a part of my usual workflow.

The built-in hints are useful without doubt, and in fact I still have at least a dozen of them left enabled.

And the hint feature does show that Git has some "helper" features to
hold the user's hand at least a little bit.

IMHO, git strikes a very good balance between holding the user's hand and leaving them on their own. For the second category of users, of course.

No pain, no gain. That's the ancient mantra, but IMHO it still applies very
well to many things, and of course not to the first category mentioned
above.  Nothing applies to that category.

Somehow I do feel some sense of satisfaction at the countless times I've
I've been stuck on some menial issue only to find out it had a stupid
solution I overlooked. It's also just kind of funny in hindsight.

Regardless of a table formatting feature in Git, there is still plenty of
sweet sweet pain to be had with software dev in general.

But in the moment I always do appreciate being able to get past a
roadblock as quickly as possible. I would want a tool I design to be
known for avoiding pain rather than causing it.

I agree, software in general shouldn't cause people pain, it should make people's lives better. However, many people expect software these days to be some kind of pain killer, which it simply can't be unless dumbed down to the extreme. If you ask any doctor what results from taking pain killers for an extended period of time, they'll answer you that stronger pain killers will usually become needed.




[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux