From 3f3288aa2053902f829c2cbe6d58eca263818a27 Mon Sep 17 00:00:00 2001 From: LinZhihao-723 Date: Wed, 12 Jun 2024 04:56:20 -0400 Subject: [PATCH 1/6] Update docstring --- clp_ffi_py/ir/query_builder.py | 32 +++++++++++++++++++++++++++++++- clp_ffi_py/wildcard_query.py | 6 ++++++ 2 files changed, 37 insertions(+), 1 deletion(-) diff --git a/clp_ffi_py/ir/query_builder.py b/clp_ffi_py/ir/query_builder.py index 5b216bda..450e8ba4 100644 --- a/clp_ffi_py/ir/query_builder.py +++ b/clp_ffi_py/ir/query_builder.py @@ -116,7 +116,37 @@ def add_wildcard_query( self, wildcard_query: Union[str, WildcardQuery], case_sensitive: bool = False ) -> QueryBuilder: """ - This method is the implementation of `add_wildcard_query`. + This is an overloaded method. The supported signatures are listed below: + + .. method:: add_wildcard_query(wildcard_query: str, case_sensitive: \ + bool = False) -> QueryBuilder + :noindex: + + Constructs and adds a + :class:`~clp_ffi_py.wildcard_query.WildcardQuery` to the wildcard + query list. + + .. deprecated:: 0.0.12 + The wildcard query must be explicitly created and passed as a + parameter to this function. QueryBuilder should only accept + instances of `clp_ffi_py.wildcard_query.WildcardQuery`. + + :param str wildcard_query: The wildcard query string to add. + :param bool case_sensitive: Whether to perform case-sensitive + matching. + :returns: self. + :rtype: :class:`~clp_ffi_py.ir.query_builder.QueryBuilder` + + .. method:: add_wildcard_query(wildcard_query: WildcardQuery) -> \ + QueryBuilder + :noindex: + + Adds the given wildcard query to the wildcard query list. + + :param WildcardQuery wildcard_query: The wildcard query object to + add. + :returns: self. + :rtype: :class:`~clp_ffi_py.ir.query_builder.QueryBuilder` """ if isinstance(wildcard_query, WildcardQuery): self._wildcard_queries.append(wildcard_query) diff --git a/clp_ffi_py/wildcard_query.py b/clp_ffi_py/wildcard_query.py index f6737bce..2ac2ae4e 100644 --- a/clp_ffi_py/wildcard_query.py +++ b/clp_ffi_py/wildcard_query.py @@ -92,6 +92,12 @@ class FullStringWildcardQuery(WildcardQuery): """ def __init__(self, full_string_wildcard_query: str, case_sensitive: bool = False): + """ + Initializes a full-string wildcard query using the given parameters. + + :param full_string_wildcard_query: Wildcard query string. + :param case_sensitive: Case sensitive indicator. + """ with warnings.catch_warnings(): warnings.simplefilter("ignore", DeprecationWarning) super().__init__(full_string_wildcard_query, case_sensitive) From adfecc5444afb9ab32fcd17f6b10ca4b74e0fe26 Mon Sep 17 00:00:00 2001 From: LinZhihao-723 Date: Wed, 12 Jun 2024 18:41:40 -0400 Subject: [PATCH 2/6] Doc string refactoring --- clp_ffi_py/ir/query_builder.py | 39 ++------------------ clp_ffi_py/wildcard_query.py | 8 ++-- docs/src/api/clp_ffi_py.ir.query_builder.rst | 38 +++++++++++++++++-- 3 files changed, 42 insertions(+), 43 deletions(-) diff --git a/clp_ffi_py/ir/query_builder.py b/clp_ffi_py/ir/query_builder.py index 450e8ba4..413b47da 100644 --- a/clp_ffi_py/ir/query_builder.py +++ b/clp_ffi_py/ir/query_builder.py @@ -9,9 +9,9 @@ from clp_ffi_py.ir.native import Query from clp_ffi_py.wildcard_query import FullStringWildcardQuery, WildcardQuery -_add_wildcard_query_deprecation_warning_message: str = "The wildcard query must be explicitly " -"created and passed as a parameter to this function. QueryBuilder should only accept instances of " -"`clp_ffi_py.wildcard_query.WildcardQuery`." +_add_wildcard_query_deprecation_warning_message: str = "Instead, use :meth:`add_wildcard_query`" +" with either a :class:`~clp_ffi_py.wildcard_query.FullStringWildcardQuery` or " +" :class:`~clp_ffi_py.wildcard_query.SubstringWildcardQuery`." class QueryBuilderException(Exception): @@ -115,39 +115,6 @@ class of :class:`~clp_ffi_py.wildcard_query.WildcardQuery`. def add_wildcard_query( self, wildcard_query: Union[str, WildcardQuery], case_sensitive: bool = False ) -> QueryBuilder: - """ - This is an overloaded method. The supported signatures are listed below: - - .. method:: add_wildcard_query(wildcard_query: str, case_sensitive: \ - bool = False) -> QueryBuilder - :noindex: - - Constructs and adds a - :class:`~clp_ffi_py.wildcard_query.WildcardQuery` to the wildcard - query list. - - .. deprecated:: 0.0.12 - The wildcard query must be explicitly created and passed as a - parameter to this function. QueryBuilder should only accept - instances of `clp_ffi_py.wildcard_query.WildcardQuery`. - - :param str wildcard_query: The wildcard query string to add. - :param bool case_sensitive: Whether to perform case-sensitive - matching. - :returns: self. - :rtype: :class:`~clp_ffi_py.ir.query_builder.QueryBuilder` - - .. method:: add_wildcard_query(wildcard_query: WildcardQuery) -> \ - QueryBuilder - :noindex: - - Adds the given wildcard query to the wildcard query list. - - :param WildcardQuery wildcard_query: The wildcard query object to - add. - :returns: self. - :rtype: :class:`~clp_ffi_py.ir.query_builder.QueryBuilder` - """ if isinstance(wildcard_query, WildcardQuery): self._wildcard_queries.append(wildcard_query) return self diff --git a/clp_ffi_py/wildcard_query.py b/clp_ffi_py/wildcard_query.py index 2ac2ae4e..3596d16f 100644 --- a/clp_ffi_py/wildcard_query.py +++ b/clp_ffi_py/wildcard_query.py @@ -19,10 +19,10 @@ class WildcardQuery: @deprecated( version="0.0.12", - reason="`clp_ffi_py.wildcard_query.WildcardQuery` is supposed to be an abstract class and" - " should not be used directly. To create a wildcard query, please explicit instantiate" - " `clp_ffi_py.wildcard_query.SubstringWildcardQuery` or" - " `clp_ffi_py.wildcard_query.FullStringWildcardQuery`.", + reason=":class:`~clp_ffi_py.wildcard_query.WildcardQuery` is supposed to be an abstract" + " class and should not be used directly. To create a wildcard query, please explicit" + " instantiate :class:`~clp_ffi_py.wildcard_query.SubstringWildcardQuery` or" + " :class:`~clp_ffi_py.wildcard_query.FullStringWildcardQuery`.", ) def __init__(self, wildcard_query: str, case_sensitive: bool = False): """ diff --git a/docs/src/api/clp_ffi_py.ir.query_builder.rst b/docs/src/api/clp_ffi_py.ir.query_builder.rst index b949a602..999be5d6 100644 --- a/docs/src/api/clp_ffi_py.ir.query_builder.rst +++ b/docs/src/api/clp_ffi_py.ir.query_builder.rst @@ -2,6 +2,38 @@ clp\_ffi\_py.ir.query\_builder module ===================================== .. automodule:: clp_ffi_py.ir.query_builder - :members: - :undoc-members: - :show-inheritance: + :members: + :undoc-members: + :show-inheritance: + :exclude-members: QueryBuilder + + .. autoclass:: QueryBuilder + :members: + :undoc-members: + :show-inheritance: + :exclude-members: __init__, __new__, add_wildcard_query + + .. method:: add_wildcard_query(wildcard_query: WildcardQuery) -> QueryBuilder + + Adds the given wildcard query to the wildcard query list. + + :param WildcardQuery wildcard_query: The wildcard query object to add. + :returns: self. + :rtype: QueryBuilder + + .. method:: add_wildcard_query(wildcard_query: str, case_sensitive: bool = False) \ + -> QueryBuilder + :no-index: + + Constructs and adds a :class:`~clp_ffi_py.wildcard_query.WildcardQuery` to the wildcard + query list. + + .. deprecated:: 0.0.12 + Instead, use :meth:`add_wildcard_query` with either a + :class:`~clp_ffi_py.wildcard_query.FullStringWildcardQuery` or + :class:`~clp_ffi_py.wildcard_query.SubstringWildcardQuery`. + + :param str wildcard_query: The wildcard query string to add. + :param bool case_sensitive: Whether to perform case-sensitive matching. + :returns: self. + :rtype: QueryBuilder From adf9df10bb563764bf800c57e4494f9d025e9d4e Mon Sep 17 00:00:00 2001 From: LinZhihao-723 Date: Wed, 12 Jun 2024 20:01:20 -0400 Subject: [PATCH 3/6] Apply code review commentds --- clp_ffi_py/wildcard_query.py | 44 ++++++++++++++++++------------------ 1 file changed, 22 insertions(+), 22 deletions(-) diff --git a/clp_ffi_py/wildcard_query.py b/clp_ffi_py/wildcard_query.py index 3596d16f..1298ef2d 100644 --- a/clp_ffi_py/wildcard_query.py +++ b/clp_ffi_py/wildcard_query.py @@ -5,31 +5,32 @@ class WildcardQuery: """ - This class defines an abstract wildcard query. It includes a wildcard string - and a boolean value to indicate if the match is case-sensitive. + An abstract class defining a wildcard query. Users should instantiate a + wildcard query through :class:`SubstringWildcardQuery` or + :class:`FullStringWildcardQuery`. - A wildcard string may contain the following types of supported wildcards: + A wildcard string may contain the following types of wildcards: 1. '*': match 0 or more characters. 2. '?': match any single character. Each wildcard can be escaped using a preceding '\\\\' (a single backslash). - Other characters which are escaped are treated as normal characters. + Other characters that are escaped are treated as normal characters. """ @deprecated( version="0.0.12", - reason=":class:`~clp_ffi_py.wildcard_query.WildcardQuery` is supposed to be an abstract" - " class and should not be used directly. To create a wildcard query, please explicit" - " instantiate :class:`~clp_ffi_py.wildcard_query.SubstringWildcardQuery` or" - " :class:`~clp_ffi_py.wildcard_query.FullStringWildcardQuery`.", + reason=":class:`WildcardQuery` will soon be made abstract and should" + " not be used directly. To create a wildcard query, use" + " :class:`SubstringWildcardQuery` or :class:`FullStringWildcardQuery`" + " instead." ) def __init__(self, wildcard_query: str, case_sensitive: bool = False): """ Initializes a wildcard query using the given parameters. :param wildcard_query: Wildcard query string. - :param case_sensitive: Case sensitive indicator. + :param case_sensitive: Whether to perform case-sensitive matching. """ self._wildcard_query: str = wildcard_query self._case_sensitive: bool = case_sensitive @@ -60,12 +61,8 @@ def case_sensitive(self) -> bool: class SubstringWildcardQuery(WildcardQuery): """ - This class defines a substring wildcard query. - - It is derived from - :class:`~clp_ffi_py.WildcardQuery`, adding both a prefix and a postfix - wildcard ("*") to the input wildcard string. This allows the query to match - any substring within a log message. + This class is derived from :class:`WildcardQuery` by adding both a prefix + and a postfix wildcard ("*") to the input wildcard string. """ def __init__(self, substring_wildcard_query: str, case_sensitive: bool = False): @@ -73,7 +70,7 @@ def __init__(self, substring_wildcard_query: str, case_sensitive: bool = False): Initializes a substring wildcard query using the given parameters. :param substring_wildcard_query: Wildcard query string. - :param case_sensitive: Case sensitive indicator. + :param case_sensitive: Whether to perform case-sensitive matching. """ substring_wildcard_query = "*" + substring_wildcard_query + "*" with warnings.catch_warnings(): @@ -83,12 +80,15 @@ def __init__(self, substring_wildcard_query: str, case_sensitive: bool = False): class FullStringWildcardQuery(WildcardQuery): """ - This class defines a full string wildcard query. + A wildcard query where the query must match the entirety of the log event's + message, in contrast with :class:`SubstringWildcardQuery` where the query + only needs to match a substring. + + This class is derived from :class:`WildcardQuery` as a more explicit + interface for full-string matches. - It is derived from - :class:`~clp_ffi_py.WildcardQuery`, and uses the input wildcard string - directly to create the query. This ensures that the query matches only the - entire log message. + Users can create a match that's anchored to only one end of the message by + adding a prefix OR postfix wildcard ("*"). """ def __init__(self, full_string_wildcard_query: str, case_sensitive: bool = False): @@ -96,7 +96,7 @@ def __init__(self, full_string_wildcard_query: str, case_sensitive: bool = False Initializes a full-string wildcard query using the given parameters. :param full_string_wildcard_query: Wildcard query string. - :param case_sensitive: Case sensitive indicator. + :param case_sensitive: Whether to perform case-sensitive matching. """ with warnings.catch_warnings(): warnings.simplefilter("ignore", DeprecationWarning) From 02971b0419050170917661760ca3881fc3a9ffd0 Mon Sep 17 00:00:00 2001 From: LinZhihao-723 Date: Wed, 12 Jun 2024 20:01:54 -0400 Subject: [PATCH 4/6] Linter --- clp_ffi_py/wildcard_query.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/clp_ffi_py/wildcard_query.py b/clp_ffi_py/wildcard_query.py index 1298ef2d..63170224 100644 --- a/clp_ffi_py/wildcard_query.py +++ b/clp_ffi_py/wildcard_query.py @@ -23,7 +23,7 @@ class WildcardQuery: reason=":class:`WildcardQuery` will soon be made abstract and should" " not be used directly. To create a wildcard query, use" " :class:`SubstringWildcardQuery` or :class:`FullStringWildcardQuery`" - " instead." + " instead.", ) def __init__(self, wildcard_query: str, case_sensitive: bool = False): """ From d03f511f149aa12951477a5f2d64c9264b590cd3 Mon Sep 17 00:00:00 2001 From: LinZhihao-723 Date: Wed, 12 Jun 2024 20:30:37 -0400 Subject: [PATCH 5/6] Add missing class description --- clp_ffi_py/wildcard_query.py | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/clp_ffi_py/wildcard_query.py b/clp_ffi_py/wildcard_query.py index 63170224..13eb3d4d 100644 --- a/clp_ffi_py/wildcard_query.py +++ b/clp_ffi_py/wildcard_query.py @@ -61,6 +61,10 @@ def case_sensitive(self) -> bool: class SubstringWildcardQuery(WildcardQuery): """ + A wildcard query that can match a substring in a log event's message, in + contrast with :class:`FullStringWildcardQuery` where the needs to match the + entire message. + This class is derived from :class:`WildcardQuery` by adding both a prefix and a postfix wildcard ("*") to the input wildcard string. """ From 3a32d3744e1f9dd9fbadfb09ecbe5c3e918300f5 Mon Sep 17 00:00:00 2001 From: Kirk Rodrigues <2454684+kirkrodrigues@users.noreply.github.com> Date: Wed, 12 Jun 2024 22:18:58 -0400 Subject: [PATCH 6/6] Minor fixes. --- clp_ffi_py/wildcard_query.py | 4 ++-- docs/src/api/clp_ffi_py.ir.query_builder.rst | 5 +++-- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/clp_ffi_py/wildcard_query.py b/clp_ffi_py/wildcard_query.py index 13eb3d4d..64c34772 100644 --- a/clp_ffi_py/wildcard_query.py +++ b/clp_ffi_py/wildcard_query.py @@ -62,8 +62,8 @@ def case_sensitive(self) -> bool: class SubstringWildcardQuery(WildcardQuery): """ A wildcard query that can match a substring in a log event's message, in - contrast with :class:`FullStringWildcardQuery` where the needs to match the - entire message. + contrast with :class:`FullStringWildcardQuery` where the query needs to + match the entire message. This class is derived from :class:`WildcardQuery` by adding both a prefix and a postfix wildcard ("*") to the input wildcard string. diff --git a/docs/src/api/clp_ffi_py.ir.query_builder.rst b/docs/src/api/clp_ffi_py.ir.query_builder.rst index 999be5d6..85ab2632 100644 --- a/docs/src/api/clp_ffi_py.ir.query_builder.rst +++ b/docs/src/api/clp_ffi_py.ir.query_builder.rst @@ -29,9 +29,10 @@ clp\_ffi\_py.ir.query\_builder module query list. .. deprecated:: 0.0.12 - Instead, use :meth:`add_wildcard_query` with either a + Use :meth:`add_wildcard_query` with either a :class:`~clp_ffi_py.wildcard_query.FullStringWildcardQuery` or - :class:`~clp_ffi_py.wildcard_query.SubstringWildcardQuery`. + :class:`~clp_ffi_py.wildcard_query.SubstringWildcardQuery` + instead. :param str wildcard_query: The wildcard query string to add. :param bool case_sensitive: Whether to perform case-sensitive matching.