From a36a2be45f151363e7befcdf184454aef251a190 Mon Sep 17 00:00:00 2001 From: Sadra Sabouri Date: Sat, 26 Oct 2024 16:13:38 -0700 Subject: [PATCH 1/7] fix : merging error messages in `line` function. --- art/functions.py | 15 +++++---------- art/params.py | 6 ++---- 2 files changed, 7 insertions(+), 14 deletions(-) diff --git a/art/functions.py b/art/functions.py index 34ad1713..b6c27d72 100644 --- a/art/functions.py +++ b/art/functions.py @@ -15,7 +15,7 @@ from .params import DECORATION_TYPE_ERROR, TEXT_TYPE_ERROR, FONT_TYPE_ERROR, CHR_IGNORE_TYPE_ERROR, FILE_TYPE_ERROR from .params import PRINT_STATUS_TYPE_ERROR, OVERWRITE_TYPE_ERROR, SEP_TYPE_ERROR, SPACE_TYPE_ERROR from .params import DETAILED_RETURN_TYPE_ERROR, ART_TYPE_ERROR, NUMBER_TYPE_ERROR, ART_NAME_ERROR -from .params import LENGTH_TYPE_ERROR, LENGTH_RANGE_ERROR, HEIGHT_TYPE_ERROR, HEIGHT_RANGE_ERROR, CHAR_TYPE_ERROR +from .params import LENGTH_ERROR, HEIGHT_ERROR, CHAR_TYPE_ERROR from .errors import artError @@ -272,18 +272,13 @@ def line(length=15, height=1, char='#'): :type char: str :return: generated grid as str """ - if not isinstance(length, int): - raise artError(LENGTH_TYPE_ERROR) - if not isinstance(height, int): - raise artError(HEIGHT_TYPE_ERROR) + if not isinstance(length, int) or length < 1: + raise artError(LENGTH_ERROR) + if not isinstance(height, int) or height < 1: + raise artError(HEIGHT_ERROR) if not isinstance(char, str): raise artError(CHAR_TYPE_ERROR) - if length < 1: - raise artError(LENGTH_RANGE_ERROR) - if height < 1: - raise artError(HEIGHT_RANGE_ERROR) - line_str = char * length return "\n".join([line_str] * height) diff --git a/art/params.py b/art/params.py index 9cf02f5b..ef6389bd 100644 --- a/art/params.py +++ b/art/params.py @@ -32,10 +32,8 @@ FONT_ENVIRONMENT_WARNING = "[Warning] '{0}' font is not printable in this environment." FONT_OR_DECOR_ENVIRONMENT_WARNING = "[Warning] '{0}' font or '{1}' decoration is not printable in this environment." PACKAGE_LOAD_WARNING = "[Warning] There is a problem loading the package 'coverage'." -HEIGHT_TYPE_ERROR = "The 'height' type must be int." -HEIGHT_RANGE_ERROR = "The 'height' parameter should be >= 1." -LENGTH_TYPE_ERROR = "The 'length' type must be int." -LENGTH_RANGE_ERROR = "The 'length' parameter should be >= 1." +HEIGHT_ERROR = "The 'height' must be an int higher than 0." +LENGTH_ERROR = "The 'length' must be an int higher than 0." CHAR_TYPE_ERROR = "The 'char' type must be str." CLI_HELP = """ From 46160cf4bf9c75d31d6dc8a025123b48f51ebc96 Mon Sep 17 00:00:00 2001 From: Sadra Sabouri Date: Sat, 26 Oct 2024 16:21:09 -0700 Subject: [PATCH 2/7] test : tests for errors added for `lprint` and `line` function. --- art/params.py | 2 +- art/tests/test.py | 14 ++++++++++++++ 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/art/params.py b/art/params.py index ef6389bd..9ab92fc8 100644 --- a/art/params.py +++ b/art/params.py @@ -32,8 +32,8 @@ FONT_ENVIRONMENT_WARNING = "[Warning] '{0}' font is not printable in this environment." FONT_OR_DECOR_ENVIRONMENT_WARNING = "[Warning] '{0}' font or '{1}' decoration is not printable in this environment." PACKAGE_LOAD_WARNING = "[Warning] There is a problem loading the package 'coverage'." -HEIGHT_ERROR = "The 'height' must be an int higher than 0." LENGTH_ERROR = "The 'length' must be an int higher than 0." +HEIGHT_ERROR = "The 'height' must be an int higher than 0." CHAR_TYPE_ERROR = "The 'char' type must be str." CLI_HELP = """ diff --git a/art/tests/test.py b/art/tests/test.py index dc115f59..979e1dab 100644 --- a/art/tests/test.py +++ b/art/tests/test.py @@ -10,10 +10,24 @@ >>> lprint(length=15, height=2, char="*") *************** *************** +>>> lprint(length=0, height=1, char="#") +The 'length' must be an int higher than 0. >>> line(length=10, height=1, char="#") '##########' >>> line(length=15, height=2, char="*") '***************\n***************' +>>> line(length=0, height=1, char="#") +Traceback (most recent call last): + ... +art.art.artError: The 'length' must be an int higher than 0. +>>> line(length=15, height='test', char="#") +Traceback (most recent call last): + ... +art.art.artError: The 'height' must be an int higher than 0. +>>> line(length=15, height=2, char=4) +Traceback (most recent call last): + ... +art.art.artError: The 'char' type must be str. >>> tprint("\t\t2","block") .----------------. From 5375082df853f49203df204924acc09183d41ba4 Mon Sep 17 00:00:00 2001 From: Sadra Sabouri Date: Sat, 26 Oct 2024 16:28:55 -0700 Subject: [PATCH 3/7] update : README.md updated. --- README.md | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/README.md b/README.md index 0f77be63..1a37fa4b 100644 --- a/README.md +++ b/README.md @@ -343,6 +343,18 @@ Filename: test.txt * Note2 : Use `NON_ASCII_FONTS` to access all Non-ASCII fonts name list (new in `Version 4.4`) * Note3 : Use `ASCII_FONTS` to access all ASCII fonts name list (new in `Version 5.7`) +### 4. lprint + +This function prints a grid (`length` by `height`) of any given character. +```pycon +>>> lprint(length=15, height=2, char="*") +*************** +*************** +``` + +* Note1: This feature has been added since `Version 6.4`. +* Note2: The default values are `length=15`, `height=1`, `char='#'`. + ### Decoration ⚠️ Some environments don't support all decorations From 695dd99319408206bd57ac5986f68857daad3224 Mon Sep 17 00:00:00 2001 From: Sadra Sabouri Date: Mon, 28 Oct 2024 13:26:59 -0700 Subject: [PATCH 4/7] update : error messages name fixed. --- art/functions.py | 6 +++--- art/params.py | 4 ++-- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/art/functions.py b/art/functions.py index b6c27d72..154072b3 100644 --- a/art/functions.py +++ b/art/functions.py @@ -15,7 +15,7 @@ from .params import DECORATION_TYPE_ERROR, TEXT_TYPE_ERROR, FONT_TYPE_ERROR, CHR_IGNORE_TYPE_ERROR, FILE_TYPE_ERROR from .params import PRINT_STATUS_TYPE_ERROR, OVERWRITE_TYPE_ERROR, SEP_TYPE_ERROR, SPACE_TYPE_ERROR from .params import DETAILED_RETURN_TYPE_ERROR, ART_TYPE_ERROR, NUMBER_TYPE_ERROR, ART_NAME_ERROR -from .params import LENGTH_ERROR, HEIGHT_ERROR, CHAR_TYPE_ERROR +from .params import LINE_LENGTH_ERROR, LINE_HEIGHT_ERROR, CHAR_TYPE_ERROR from .errors import artError @@ -273,9 +273,9 @@ def line(length=15, height=1, char='#'): :return: generated grid as str """ if not isinstance(length, int) or length < 1: - raise artError(LENGTH_ERROR) + raise artError(LINE_LENGTH_ERROR) if not isinstance(height, int) or height < 1: - raise artError(HEIGHT_ERROR) + raise artError(LINE_HEIGHT_ERROR) if not isinstance(char, str): raise artError(CHAR_TYPE_ERROR) diff --git a/art/params.py b/art/params.py index 9ab92fc8..d4a855f2 100644 --- a/art/params.py +++ b/art/params.py @@ -32,8 +32,8 @@ FONT_ENVIRONMENT_WARNING = "[Warning] '{0}' font is not printable in this environment." FONT_OR_DECOR_ENVIRONMENT_WARNING = "[Warning] '{0}' font or '{1}' decoration is not printable in this environment." PACKAGE_LOAD_WARNING = "[Warning] There is a problem loading the package 'coverage'." -LENGTH_ERROR = "The 'length' must be an int higher than 0." -HEIGHT_ERROR = "The 'height' must be an int higher than 0." +LINE_LENGTH_ERROR = "The 'length' must be an int higher than 0." +LINE_HEIGHT_ERROR = "The 'height' must be an int higher than 0." CHAR_TYPE_ERROR = "The 'char' type must be str." CLI_HELP = """ From f7e0257773649e0f24a7b86c3fab6f3f7a5ceb31 Mon Sep 17 00:00:00 2001 From: Sadra Sabouri Date: Mon, 28 Oct 2024 13:27:21 -0700 Subject: [PATCH 5/7] update : readme updated (Sepand's comment.). --- README.md | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index 1a37fa4b..336e88bc 100644 --- a/README.md +++ b/README.md @@ -343,7 +343,9 @@ Filename: test.txt * Note2 : Use `NON_ASCII_FONTS` to access all Non-ASCII fonts name list (new in `Version 4.4`) * Note3 : Use `ASCII_FONTS` to access all ASCII fonts name list (new in `Version 5.7`) -### 4. lprint +## Line + +### 1. lprint This function prints a grid (`length` by `height`) of any given character. ```pycon @@ -355,6 +357,18 @@ This function prints a grid (`length` by `height`) of any given character. * Note1: This feature has been added since `Version 6.4`. * Note2: The default values are `length=15`, `height=1`, `char='#'`. +### 2. line + +This function return a grid (`length` by `height`) of any given character as `str` in and raise `artError` in exception. +```pycon +>>> line(length=15, height=2, char="*") +'***************\n***************' +``` + +* Note1: This feature has been added since `Version 6.4`. +* Note2: The default values are `length=15`, `height=1`, `char='#'`. + + ### Decoration ⚠️ Some environments don't support all decorations From a96f5624cc0053017c4db239759bcdbb6a6e1a49 Mon Sep 17 00:00:00 2001 From: Sadra Sabouri Date: Sun, 3 Nov 2024 23:05:51 -0800 Subject: [PATCH 6/7] fix : minor issues in readme fixed. --- README.md | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/README.md b/README.md index 336e88bc..90e7836c 100644 --- a/README.md +++ b/README.md @@ -343,9 +343,9 @@ Filename: test.txt * Note2 : Use `NON_ASCII_FONTS` to access all Non-ASCII fonts name list (new in `Version 4.4`) * Note3 : Use `ASCII_FONTS` to access all ASCII fonts name list (new in `Version 5.7`) -## Line +### Line -### 1. lprint +#### 1. lprint This function prints a grid (`length` by `height`) of any given character. ```pycon @@ -354,10 +354,10 @@ This function prints a grid (`length` by `height`) of any given character. *************** ``` -* Note1: This feature has been added since `Version 6.4`. -* Note2: The default values are `length=15`, `height=1`, `char='#'`. +* Note1: This feature has been added since `Version 6.4` +* Note2: The default values are `length=15`, `height=1`, `char='#'` -### 2. line +#### 2. line This function return a grid (`length` by `height`) of any given character as `str` in and raise `artError` in exception. ```pycon @@ -365,8 +365,8 @@ This function return a grid (`length` by `height`) of any given character as `st '***************\n***************' ``` -* Note1: This feature has been added since `Version 6.4`. -* Note2: The default values are `length=15`, `height=1`, `char='#'`. +* Note1: This feature has been added since `Version 6.4` +* Note2: The default values are `length=15`, `height=1`, `char='#'` ### Decoration From cdb9be5c68580d26be05eac683e7afec73c8b0b4 Mon Sep 17 00:00:00 2001 From: Sadra Sabouri Date: Tue, 5 Nov 2024 07:42:34 -0800 Subject: [PATCH 7/7] fix : readme fixed. --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 90e7836c..d0643c7c 100644 --- a/README.md +++ b/README.md @@ -359,7 +359,7 @@ This function prints a grid (`length` by `height`) of any given character. #### 2. line -This function return a grid (`length` by `height`) of any given character as `str` in and raise `artError` in exception. +This function returns a grid (`length` by `height`) of any given character as `str` in normal mode and raise `artError` in exception. ```pycon >>> line(length=15, height=2, char="*") '***************\n***************'