Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Starting tracker with single-comma delimited description doesn't work (with hamster 3.0.2) #334

Closed
rhertzog opened this issue Aug 28, 2020 · 12 comments

Comments

@rhertzog
Copy link
Contributor

rhertzog commented Aug 28, 2020

With hamster 3.0.2, if you type Activity@Category, task description in the shell extension, nothing happens. To get it to actually start, you need to type Activity@Category,, task description. This is likely related to the breaking change made in hamster that now requires two commas to separate descriptions:
projecthamster/hamster@42d3c05

I think we should revisit that decision as it doesn't seem like a good decision to me. In particular when typing Activity@Category, #tag just works.

But if we don't, then we somehow need to fix the shell extension. Something needs to happen when the user inputs something... either it creates an activity with some unexpected values, or it displays an error. But just dropping the user's input is wrong.

@matthijskooijman
Copy link
Member

If we want to fix this in hamster, we should probably discuss it there, I created projecthamster/hamster#657 for that.

@ederag
Copy link

ederag commented Dec 11, 2020

@rhertzog This change was not done lightly.

But you are right that the extension should follow, see my recommendations:
getting-things-gnome/gtg#465 (comment)

@rhertzog
Copy link
Contributor Author

@ederag I see that you have thought hard to support quite some corner case but I believe it's not the good trade off that you picked.

@ederag
Copy link

ederag commented Dec 13, 2020

@rhertzog
I'm not surprised that it might seem so at first sight, but no,
the main starting point for the parser overhaul was much deeper.

No time to dive into my notes, but it was needed.
Main points: readable code, simple rules, no fragile heuristics.
The infrastructure is rock solid (not a bug about it surfaced in 9 months), thanks to this approach.

The "corner cases" came as a bonus.

@mwilck
Copy link
Contributor

mwilck commented Dec 14, 2020

I can just repeat what I said before: the current rules of the "permissive parser" are overly complex. Too much complexity causes confusion, and the "double comma" ist just one particularly weird example for that.

It has all been done with good intentions, trying to satisfy user requests. Yet I believe it was misguided. Simplicity is key, the syntax rules have to be so simple that they can be understood at a single glance. IMO for the shell command line, they should match what command line users are used to (and that means: no whitespace in activity and category names). But I'm digressing and probably overdoing it.

The dilemma we have now is that in a way, the ship has sailed - 3.x has been out in the field with these parsing rules for almost a year. If we revert this now, we'll make some happy, and others who've come to like the new rules will be upset. We have no metrics to judge how far this adoption has gone yet, and what the final thumbs-up/down relation will be. But we need to choose one. Going for some compromise with yet new rules would confuse people even more.

My personal vote, no surprise here, is to revert this change.

@hedayat
Copy link
Member

hedayat commented Dec 14, 2020

I'd suggest all discussion about reverting the change happen in projecthamster/hamster#657, so that everything is in the same place.

I'd suggest this issue is either fixed for the current released version, or is suspended until projecthamster/hamster#657 is resolved.

@ederag
Copy link

ederag commented Dec 26, 2020

Agreed, the technical discussion should go to projecthamster/hamster#657,
but here are a few comments relevant to this thread only (IMO):

  1. > you have thought hard to support quite some corner case
    Funny how some people like @rhertzog want their own features so bad, and call others "corner cases" 🤣,
  2. The v3 rules are summarized here. So any reader can see what @mwilck called "complexity" above 🤣.
    Obviously the change from single to double comma is annoying for some existing users (which does not make me laugh at all),
    but v3 rules actually removed many other sources of confusion,
  3. The main motivation was not to "satisfy user requests" (@mwilck never believes me, :sigh:),
    but to get an interface as clean, user-friendly, and robust as the infrastructure.
    Unfortunately this effort was stopped; but the parser is solid.

the ship has sailed - 3.x has been out in the field with these parsing rules for almost a year. If we revert this now, we'll make some happy, and others who've come to like the new rules will be upset.

True.
For instance GTG migrated a while ago: getting-things-gnome/gtg#465
Note that if you want to support v2 as well, you'll need to know which version you are talking to,
so there's a new Version dbus method in hamster v3.

@rhertzog
Copy link
Contributor Author

3. The main motivation was not to "satisfy user requests" (@mwilck never believes me, :sigh:),
    but to get an interface as clean, user-friendly, and robust as the infrastructure.

Clearly we don't have the same definition of user-friendly. And if instead of laughing at my code, you'd have taken the time to read it, you would see that my changes actually make the parser more robust while not introducing the needless complexity of the required double-comma.

the ship has sailed - 3.x has been out in the field with these parsing rules for almost a year. If we revert this now, we'll make some happy, and others who've come to like the new rules will be upset.

True.

This is not true. If anyone uses double-comma, it will continue to work as usual with a single-comma as delimiter. We can even add some tests to ensure we properly strip the extra comma.

@ederag
Copy link

ederag commented Dec 27, 2020

instead of laughing at my code

I did not.

And I also disagree with the remainder (you're missing the point).
But go ahead, you've been warned.

@matthijskooijman
Copy link
Member

This was fixed with merging projecthamster/hamster#663, so I think this issue can be closed.

@DirkHoffmann
Copy link
Member

This was fixed with merging projecthamster/hamster#663, so I think this issue can be closed.

Go for closing then. If this is an error, we can reopen it on request. (ping @rhertzog)

@ederag
Copy link

ederag commented Nov 20, 2023

I'm astonished that you chose to break the v3 parser,
which was perfectly robust.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

6 participants