-
-
Notifications
You must be signed in to change notification settings - Fork 4.3k
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
CLIENT-SPECIFICATION: drop the special "all" platform #7561
Conversation
This comment was marked as outdated.
This comment was marked as outdated.
CLIENT-SPECIFICATION.md
Outdated
@@ -38,7 +38,8 @@ Option | Required? | Meaning | |||
`-v`, `--version` | Yes | Shows the current version of the client, and the version of this specification that it implements. | |||
`-p`, `--platform` | Yes | Specifies the platform to be used to perform the action (either listing or searching) as an argument. If this option is specified, the selected platform MUST be checked first instead of the current platform as described below. | |||
`-u`, `--update` | Conditional | Updates the offline cache of pages. MUST be implemented if cache is supported. | |||
`-l`, `--list` | No | Lists all the pages in the current platform to the standard output. If the special platform `all` is specified a list of all pages in all platforms MUST be displayed. | |||
`-l`, `--list` | No | Lists all the pages in the current platform to the standard output. It is RECOMMENDED that the pages are sorted alphanumerically. | |||
`--list-all` | No | Lists all the pages in all platforms to the standard output. It is RECOMMENDED that the pages are sorted alphanumerically. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Simply specifying sorting alphabetical ordering isn't always though. As Jeff Attwood explains, unicode can cause an issue here. We should find some standard on unicode sorting here.
The other thing we should handle here is the case of when a page exists in multiple platforms. Perhaps we should require the platform name to be specified as well here, and explicitly state that a given page name may exist in multiple categories and that's ok and they MUST NOT
be deduplicated?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, you're right. As written in my other comment above, after some thought I'd actually tend towards not adding --list-all
to the standard at all. Same thing with --list
, we could leave it to the implementation to choose a useful output format. (Or is there any advantage in having a common output format? Should it be parseable?)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, I think that's a good point. Clients can be for many different platforms and purposes - even if we assume a command line, there's a range of possible purposes that such a client may be implemented for. Let's drop the sorting sentence here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I pushed a new version that simply removed the all
platform and doesn't specify anything else. Implementations can still implement --list-all
if they want, but if the output format isn't standardized, then a standardized command name won't bring any benefits either.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Right. Let's add support for --list-all
. What about specifying 1 command name per line on the standard output? e.g.
`--list-all` | No | Lists all the pages in all platforms to the standard output, with 1 page name per line in the format `<platform>/<pagename>`
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@sbrl did you take a look at this comment? I think adding --list-all
to the spec isn't a good idea, there are a lot of open questions and a standardized --list-all
wouldn't really give a lot of benefits while potentially limiting improvements to the output format.
My curent suggestion would be dropping the all
platform and not standardizing --list-all
. I renamed the PR to reflect the current state of the proposal. If you agree, this discussion can be marked as resolved.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Right, I think I see. Fair enough, in the interests of an unambiguous spec lets merge this PR as-is.
For future reference, if an argument or feature is not specified in the client specification, that doesn't mean to say that you (a client author) can't implement it :D
Sorry for taking so long about this! I've been having a rough time with my PhD and IRL stuff.
If a client wants to list all pages, something like a `--list-all` command is the better approach. See discussion in tldr-pages#7528 and tldr-pages#7561.
Hi all! This thread has not had any recent activity. |
Hi everyone. |
github-actions: Please re-open. |
@sbrl @waldyrious any opinions on this? (I updated the PR description to properly reflect the current state of the PR.) |
As I wasn't involved in the previous discussions, I'll let @sbrl take this one, unless there are specific aspects or open questions you'd like my thoughts on. |
As discussed in #7528 and here:
Drop the special
all
platform.