-
-
Notifications
You must be signed in to change notification settings - Fork 32.7k
gh-133390: Extend completion for .commands in sqlite3
#135432
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
base: main
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Only commands with a dot at the line beginning is considered dot commands. text
is the non-whitespace chars under wherever the cursor is at. This means using text.startswith()
enables dot command completion for not only actual dot commands but also any inline word that starts with dot:
sqlite> SELECT .<tab>
.help
.quit
.version
sqlite> SELECT .
Using readline.get_line_buffer()
instead is more reasonable. This returns the whole current line and can be used to avoid completion for dot-started inline word:
origline = readline.get_line_buffer()
if origline.startswith("."):
...
sqlite3 identifiers cannot start with |
I actually also made a local change to add dot commands completion. This is the idea on my local branch, just sharing it for discussion:
COMMANDS = ("quit", "help", "version")
def _complete(text, state):
global _completion_matches
if state == 0:
import readline
origline = readline.get_line_buffer()
if origline.startswith("."):
if origline == text:
text_lstrip = text.lstrip(".")
_completion_matches = [f".{cmd}" for cmd in COMMANDS
if cmd.startswith(text_lstrip)]
elif origline.removeprefix(".").lstrip(" ") == text:
_completion_matches = [cmd for cmd in COMMANDS
if cmd.startswith(text)]
else:
_completion_matches.clear()
else:
text_upper = text.upper()
_completion_matches = [c for c in SQLITE_KEYWORDS if c.startswith(text_upper)]
try:
return _completion_matches[state] + " "
except IndexError:
return None |
@tanloong @encukou