-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[FEATURE][DOC] Add (minimal) CLI (#102)
- Loading branch information
1 parent
0306d35
commit c72e673
Showing
13 changed files
with
369 additions
and
29 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
Command Line Interface | ||
====================== | ||
|
||
Symmetria also provides a simple command line interface to find all what you need just with a line. | ||
|
||
.. code-block:: text | ||
$ symmetria 132 | ||
+------------------------------------------------------+ | ||
| Permutation(1, 3, 2) | | ||
+------------------------------------------------------+ | ||
| order | 2 | | ||
+---------------------------+--------------------------+ | ||
| degree | 3 | | ||
+---------------------------+--------------------------+ | ||
| is derangement | False | | ||
+---------------------------+--------------------------+ | ||
| inverse | (1, 3, 2) | | ||
+---------------------------+--------------------------+ | ||
| parity | -1 (odd) | | ||
+---------------------------+--------------------------+ | ||
| cycle notation | (1)(2 3) | | ||
+---------------------------+--------------------------+ | ||
| cycle type | (1, 2) | | ||
+---------------------------+--------------------------+ | ||
| inversions | [(2, 3)] | | ||
+---------------------------+--------------------------+ | ||
| ascents | [1] | | ||
+---------------------------+--------------------------+ | ||
| descents | [2] | | ||
+---------------------------+--------------------------+ | ||
| excedencees | [2] | | ||
+---------------------------+--------------------------+ | ||
| records | [1, 2] | | ||
+---------------------------+--------------------------+ | ||
Check it out. | ||
|
||
.. code-block:: text | ||
$ symmetria --help | ||
Symmetria, an intuitive framework for working with the symmetric group and its elements. | ||
Usage: symmetria <ARGUMENT> [OPTIONS] | ||
Options: | ||
-h, --help Print help | ||
-v, --version Print version | ||
Argument (optional): | ||
permutation A permutation you want to learn more about. | ||
The permutation must be given in its one-line format, i.e., | ||
for the permutation Permutation(2, 3, 1), write 231. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,27 +1,7 @@ | ||
import sys | ||
|
||
from symmetria.elements.cycle import Cycle | ||
from symmetria.generators.api import generate | ||
from symmetria.elements.permutation import Permutation | ||
from symmetria.elements.cycle_decomposition import CycleDecomposition | ||
|
||
__version__ = "0.1.1" | ||
__all__ = ["__version__", "generate", "Permutation", "Cycle", "CycleDecomposition"] | ||
|
||
|
||
def _log_version() -> None: | ||
"""Private method which take a command line argument and log the version of `symmetria`.""" | ||
if len(sys.argv) == 0 or len(sys.argv) == 1: | ||
raise Exception("No command provided.") | ||
elif len(sys.argv) == 2: | ||
if sys.argv[1] == "--version": | ||
print(f"v{__version__}") | ||
else: | ||
raise ValueError(f"command not found: {sys.argv[1]}") | ||
|
||
else: | ||
raise ValueError(f"Expected 1 command, but got {len(sys.argv) -1}") | ||
|
||
|
||
if __name__ == "__main__": | ||
_log_version() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
from symmetria.cli.cli import run_command_line_interface | ||
|
||
|
||
def main() -> None: | ||
"""Entry point for the command line interface.""" | ||
run_command_line_interface() | ||
|
||
|
||
if __name__ == "__main__": | ||
main() |
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
import sys | ||
|
||
from symmetria import Permutation, __version__ | ||
|
||
|
||
class _Style: | ||
"""Class to define the output messages style.""" | ||
|
||
YELLOW: str = "\033[33m" | ||
RED: str = "\033[31m" | ||
END: str = "\033[0m" | ||
BOLD: str = "\033[1m" | ||
UNDERLINE: str = "\033[4m" | ||
|
||
|
||
def _execute_error_message(message: str, exit_code: int) -> None: | ||
"""Print an error message in case of wrong given commands.""" | ||
sys.stderr.write( | ||
f"{_Style.RED}{_Style.BOLD}Error:{_Style.END} {message}. \n " | ||
f"For more information, try `{_Style.YELLOW}--help{_Style.END}`, or `{_Style.YELLOW}-h{_Style.END}`. \n" | ||
) | ||
sys.exit(exit_code) | ||
|
||
|
||
def _execute_help_command() -> None: | ||
"""Execute the `--help`, or `-h`, command.""" | ||
sys.stdout.write( | ||
"Symmetria, an intuitive framework for working with the symmetric group and its elements.\n" | ||
"\n" | ||
f"{_Style.UNDERLINE}Usage:{_Style.END} symmetria <ARGUMENT> [OPTIONS] \n" | ||
"\n" | ||
f"{_Style.UNDERLINE}Options:{_Style.END} \n" | ||
" -h, --help Print help \n" | ||
" -v, --version Print version \n" | ||
"\n" | ||
f"{_Style.UNDERLINE}Argument (optional):{_Style.END} \n" | ||
" permutation A permutation you want to learn more about. \n" | ||
" The permutation must be given in its one-line format, i.e., \n" | ||
" for the permutation Permutation(2, 3, 1), write 231. \n" | ||
) | ||
sys.exit(0) | ||
|
||
|
||
def _execute_permutation_command(permutation: str) -> None: | ||
"""Execute the command when a permutation is given.""" | ||
permutation = _parse_permutation(permutation=permutation) | ||
sys.stdout.write(permutation.describe() + "\n") | ||
sys.exit(0) | ||
|
||
|
||
def _execute_version_command() -> None: | ||
"""Execute the `--version`, or `-v`, command.""" | ||
sys.stdout.write(f"{_Style.BOLD}v{_Style.END}{__version__}" + "\n") | ||
sys.exit(0) | ||
|
||
|
||
def _parse_permutation(permutation: str) -> Permutation: | ||
"""Convert the provided string into a `Permutation` object.""" | ||
return Permutation(*[int(d) for d in permutation]) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
import sys | ||
|
||
from symmetria.cli._commands import ( | ||
_Style, | ||
_execute_help_command, | ||
_execute_error_message, | ||
_execute_version_command, | ||
_execute_permutation_command, | ||
) | ||
|
||
|
||
def run_command_line_interface() -> None: | ||
"""Run and manage the command line interface.""" | ||
commands = sys.argv[1:] | ||
|
||
# case where no commands are provided | ||
if len(commands) == 0: | ||
_execute_error_message( | ||
message="no command provided", | ||
exit_code=1, | ||
) | ||
|
||
# case where one command is provided | ||
elif len(commands) == 1: | ||
command = commands[0] | ||
if _is_a_flag(command=command): | ||
if command in {"-h", "--help"}: | ||
_execute_help_command() | ||
elif command in {"-v", "--version"}: | ||
_execute_version_command() | ||
_execute_error_message( | ||
message=f"unexpected argument `{_Style.YELLOW}{command}{_Style.END}` found", | ||
exit_code=1, | ||
) | ||
elif _is_a_permutation(command=command): | ||
_execute_permutation_command(permutation=command) | ||
_execute_error_message( | ||
message=f"unexpected argument `{_Style.YELLOW}{command}{_Style.END}` found", | ||
exit_code=1, | ||
) | ||
|
||
# otherwise | ||
_execute_error_message( | ||
message=f"Expected 1 command, but got {_Style.YELLOW}{len(sys.argv) - 1}{_Style.END} commands", | ||
exit_code=1, | ||
) | ||
|
||
|
||
def _is_a_flag(command: str) -> bool: | ||
"""Check if an argument has to be interpreted as a flag.""" | ||
return command.startswith(("-", "--")) | ||
|
||
|
||
def _is_a_permutation(command: str) -> bool: | ||
"""Check if an argument has to be interpreted as a permutation.""" | ||
return command.isdigit() |
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
from symmetria import Permutation | ||
|
||
TEST_IS_A_FLAG = [ | ||
("", False), | ||
("not-a-flag", False), | ||
("-flag", True), | ||
("--flag", True), | ||
("-_still a flag", True), | ||
("-_still-dr-dre", True), | ||
] | ||
TEST_IS_PERMUTATION = [ | ||
("", False), | ||
("asd", False), | ||
("12 34", False), | ||
("123-hello", False), | ||
("hello-world", False), | ||
("123,456", False), | ||
("13245", True), | ||
("1", True), | ||
("23451", True), | ||
] | ||
TEST_PARSE_PERMUTATION = [ | ||
("123", Permutation(1, 2, 3)), | ||
("2341", Permutation(2, 3, 4, 1)), | ||
("2143", Permutation(2, 1, 4, 3)), | ||
] |
Oops, something went wrong.