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

Implement switch -h, --help to CLI #238

Open
wants to merge 11 commits into
base: master
Choose a base branch
from

Conversation

nappex
Copy link
Collaborator

@nappex nappex commented Aug 16, 2024

Fix #205

Copy link
Owner

@Glutexo Glutexo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Tests? 🤔

@nappex
Copy link
Collaborator Author

nappex commented Aug 16, 2024

Tests? 🤔

thanks for reminding 😮‍💨

lib/cli.ex Outdated Show resolved Hide resolved
test/onigumo_cli_test.exs Outdated Show resolved Hide resolved
test/onigumo_cli_test.exs Outdated Show resolved Hide resolved
@nappex nappex force-pushed the implement-help-option branch from 02713e6 to 05c7649 Compare August 25, 2024 15:38
@nappex nappex force-pushed the implement-help-option branch from 05c7649 to 79dad90 Compare August 25, 2024 15:45
lib/cli.ex Outdated Show resolved Hide resolved
test/onigumo_cli_test.exs Outdated Show resolved Hide resolved
test/onigumo_cli_test.exs Outdated Show resolved Hide resolved
test/onigumo_cli_test.exs Outdated Show resolved Hide resolved
test/onigumo_cli_test.exs Outdated Show resolved Hide resolved
test/onigumo_cli_test.exs Outdated Show resolved Hide resolved
test/onigumo_cli_test.exs Outdated Show resolved Hide resolved
Copy link
Owner

@Glutexo Glutexo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think I found an error. If a value is provided for the -h switch, MatchError is raised.

$ ./onigumo -h value
** (MatchError) no match of right hand side value: :error
    (onigumo 0.1.0) lib/cli.ex:16: Onigumo.CLI.main/1
    (elixir 1.17.2) lib/kernel/cli.ex:136: anonymous fn/3 in Kernel.CLI.exec_fun/2

Copy link
Owner

@Glutexo Glutexo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Update: the error I found is not a problem of this pull request. Its happens when an invalid component (a positional argument) is passed. It is a known issue #179.

Copy link
Owner

@Glutexo Glutexo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Unfortunately, a combination of -h/--help and a positional argument doesn’t work as expected. See my inline comment.

lib/cli.ex Outdated
@@ -30,6 +33,7 @@ defmodule Onigumo.CLI do
COMPONENT\tOnigumo component to run, available: #{components}

OPTIONS:
-h, --help\t\tprint this help
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Capitalized, this sentence would be more consistent.

Suggested change
-h, --help\t\tprint this help
-h, --help\t\tPrint this help

@@ -39,6 +44,12 @@ defmodule OnigumoCLITest do
end
end

for switches <- @invalid_switch_combinations do
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There is one more user story of providing both a positional argument and the help switch. If ran in the ./onigumo downloader -h order, the -h switch is ignored.

This case is not tested and because it doesn’t work correctly, the test would fail. The expected result is a help message to be printed because of an invalid argument combination. The actual result is that the downloader is run.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

that should be already tested but it is strange that github does not mark as as outdated. I suppose it because the line of code you mark is not changed but in text is mentioned case of test which is not added in your changes.

@Glutexo
Copy link
Owner

Glutexo commented Aug 25, 2024

My observation of onigumo downloader -h not printing the help message is not a matter of this pull request. It is a bug in the code preventing switches from being parsed if a component is provided. onigumo downloader --anything would behave identically.

The question is whether to add a test case for the combination of the help switch and the component. Because of the existing bug, the test would fail and essentially make this pull request blocked. We can keep this test for the fix and by that let this pull request go through.

@Glutexo
Copy link
Owner

Glutexo commented Aug 25, 2024

In my previous comment, I was wrong! 😮 It’s only the -h/--help switch that is ignored. An invalid switch like -x or --invalid still causes a help message to be printed.

$ ./onigumo downloader -h
$ ./onigumo downloader -x
Usage: onigumo [OPTION]... [COMPONENT]

Simple program that retrieves HTTP web content as structured data.

COMPONENT	Onigumo component to run, available: downloader

OPTIONS:
-h, --help		print this help
-C, --working-dir <dir>	Change working dir to <dir> before running

@Glutexo
Copy link
Owner

Glutexo commented Aug 28, 2024

To make it clearer:

  • On master, onigumo downloader -h prints a help message, which is correct: it’s an invalid argument combination.
  • On implement-help-option, the Downloader is run, which is incorrect: the -h option is ignored.

@Glutexo
Copy link
Owner

Glutexo commented Aug 28, 2024

I found the reason, why the behavior changed:

  • On master, neither the --help switch nor the -h alias were defined in strict or aliases respectively. Because of that, --help/-h ended up in the invalid section of the result, not matching the empty list in {parsed_switches, [component], []} and proceeding to _ printing a help message.
  • On implement-help-option, however, the help switches are defined and because of that :help is not put in invalid. [] of invalid switches is then properly matched by {parsed_switches, [component], []} and the help switch ends up unparsed in parsed_switches.

This pull request then does introduce the bug in the sense that in didn’t exist because there was no help option. At the same time, it only reveals an existing issue of unscalable pattern matching of the OptionParser.parse/2 output.

This can be still resolved tactically by using my code suggestion still being purely based on pattern-matching, probably in a separate pull request unblocking this one. The strategic solution is however to replace the pattern matching by something scalable.

@Glutexo Glutexo mentioned this pull request Nov 9, 2024
@nappex
Copy link
Collaborator Author

nappex commented Dec 17, 2024

--help must be used as only one cli argument to run correctly, we do not want behaviour as "rule them all" by help switch as proposed in PR #244.
If someone use --help with other argument or switch, then it could evoke to user it should output help for certain argument resp. switch. We do not want to implement this feature currently, maybe later. So --help should be used only for general help message for whole Onigumo not for its individual commands.

@Glutexo Glutexo mentioned this pull request Jan 4, 2025
@Glutexo
Copy link
Owner

Glutexo commented Jan 4, 2025

I think #256 would make this much easier to implement.

{:ok, module} <- Map.fetch(@components, String.to_atom(component)) do
working_dir = Keyword.get(switches, :working_dir, File.cwd!())
module.main(working_dir)
with {[help: true], [], []} <- parsed do
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I am afraid this is not the right use case for with. It only collects a single value and the else part only contains a single branch. It’s just a pompous if/else. case might be more appropriate here. See #256.

case parsed:
  [help: true], [], []} ->
    usage_message()

  {switches, [component], []} ->{_, _, [_ | _]} ->
    usage_message()

  {_, argv, _} when length(argv) != 1usage_message()
end

working_dir = Keyword.get(switches, :working_dir, File.cwd!())
module.main(working_dir)
else
{_, _, [_ | _]} -> usage_message()
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Unlike the other two patterns in this else clause, this one catches a case when any invalid switch is passed. It belongs more to the level where the help switch and the component run are matched.

case parsed do
  {[help: true], [], []} ->{switches, [component], []} ->{_, _, [_ | _]} →
    …
end

module.main(working_dir)
else
{_, _, [_ | _]} -> usage_message()
{_, argv, _} when length(argv) != 1 -> usage_message()
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This pattern is related to the component run, so it can belong here.

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

Successfully merging this pull request may close these issues.

Implement option --help, -h
2 participants