From 10b8554707a52faa2d9f09a4d5b340aec0fc2822 Mon Sep 17 00:00:00 2001 From: Erlend Egeberg Aasland Date: Wed, 15 Jun 2022 12:28:24 +0200 Subject: [PATCH] gh-87260: Update sqlite3 signature docs to reflect actual implementation (GH-93840) Align the docs for the following methods with the actual implementation: - sqlite3.complete_statement() - sqlite3.Connection.create_function() - sqlite3.Connection.create_aggregate() - sqlite3.Connection.set_progress_handler() (cherry picked from commit d31834688bccb41fc136f780db83ffa12bef8cbd) Co-authored-by: Erlend Egeberg Aasland --- Doc/library/sqlite3.rst | 18 +++++++++--------- ...22-06-15-12-12-49.gh-issue-87260.epyI7D.rst | 1 + 2 files changed, 10 insertions(+), 9 deletions(-) create mode 100644 Misc/NEWS.d/next/Documentation/2022-06-15-12-12-49.gh-issue-87260.epyI7D.rst diff --git a/Doc/library/sqlite3.rst b/Doc/library/sqlite3.rst index f1d0426728e7ed..959a2599b11112 100644 --- a/Doc/library/sqlite3.rst +++ b/Doc/library/sqlite3.rst @@ -308,9 +308,9 @@ Module functions and constants float, str or bytes. -.. function:: complete_statement(sql) +.. function:: complete_statement(statement) - Returns :const:`True` if the string *sql* contains one or more complete SQL + Returns :const:`True` if the string *statement* contains one or more complete SQL statements terminated by semicolons. It does not verify that the SQL is syntactically correct, only that there are no unclosed string literals and the statement is terminated by a semicolon. @@ -394,11 +394,11 @@ Connection Objects :meth:`~Cursor.executescript` on it with the given *sql_script*. Return the new cursor object. - .. method:: create_function(name, num_params, func, *, deterministic=False) + .. method:: create_function(name, narg, func, *, deterministic=False) Creates a user-defined function that you can later use from within SQL - statements under the function name *name*. *num_params* is the number of - parameters the function accepts (if *num_params* is -1, the function may + statements under the function name *name*. *narg* is the number of + parameters the function accepts (if *narg* is -1, the function may take any number of arguments), and *func* is a Python callable that is called as the SQL function. If *deterministic* is true, the created function is marked as `deterministic `_, which @@ -417,12 +417,12 @@ Connection Objects .. literalinclude:: ../includes/sqlite3/md5func.py - .. method:: create_aggregate(name, num_params, aggregate_class) + .. method:: create_aggregate(name, n_arg, aggregate_class) Creates a user-defined aggregate function. The aggregate class must implement a ``step`` method, which accepts the number - of parameters *num_params* (if *num_params* is -1, the function may take + of parameters *n_arg* (if *n_arg* is -1, the function may take any number of arguments), and a ``finalize`` method which will return the final result of the aggregate. @@ -479,7 +479,7 @@ Connection Objects one. All necessary constants are available in the :mod:`sqlite3` module. - .. method:: set_progress_handler(handler, n) + .. method:: set_progress_handler(progress_handler, n) This routine registers a callback. The callback is invoked for every *n* instructions of the SQLite virtual machine. This is useful if you want to @@ -487,7 +487,7 @@ Connection Objects a GUI. If you want to clear any previously installed progress handler, call the - method with :const:`None` for *handler*. + method with :const:`None` for *progress_handler*. Returning a non-zero value from the handler function will terminate the currently executing query and cause it to raise an :exc:`OperationalError` diff --git a/Misc/NEWS.d/next/Documentation/2022-06-15-12-12-49.gh-issue-87260.epyI7D.rst b/Misc/NEWS.d/next/Documentation/2022-06-15-12-12-49.gh-issue-87260.epyI7D.rst new file mode 100644 index 00000000000000..4c6cee86ca115f --- /dev/null +++ b/Misc/NEWS.d/next/Documentation/2022-06-15-12-12-49.gh-issue-87260.epyI7D.rst @@ -0,0 +1 @@ +Align :mod:`sqlite3` argument specs with the actual implementation.