Relax commandline parsing a bit

Problem 1: Entering a command of `:::save` gives an error.
Problem 2: Entering a command of `:save\n` gives an error.

Both scenarios may seem a bit silly at first, but I encountered both by
copy/pasting a command:

1. Enter `:` in qutebrowser.
2. Copy a full line from a terminal starting with `:`.
3. You will now have both of the above problems.

Solution: Trim all whitespace and `:` of a command. This is also what
Vim does, by the way.
This commit is contained in:
Martin Tournoij 2017-03-30 18:37:15 +01:00
parent 9cd2c9aa6d
commit 7f13c9a3c3
No known key found for this signature in database
GPG Key ID: A6258419189EE585
2 changed files with 14 additions and 3 deletions

View File

@ -133,7 +133,8 @@ class CommandRunner(QObject):
Yields: Yields:
ParseResult tuples. ParseResult tuples.
""" """
if not text.strip(): text = text.strip().lstrip(':').strip()
if not text:
raise cmdexc.NoSuchCommandError("No command given") raise cmdexc.NoSuchCommandError("No command given")
if aliases: if aliases:

View File

@ -538,6 +538,16 @@ Feature: Various utility commands.
When I run :message-i "Hello World" (invalid command) When I run :message-i "Hello World" (invalid command)
Then the error "message-i: no such command" should be shown Then the error "message-i: no such command" should be shown
Scenario: Multiple leading : in command
When I run :::::set-cmd-text ::::message-i "Hello World"
And I run :command-accept
Then the message "Hello World" should be shown
Scenario: Whitespace in command
When I run : : set-cmd-text : : message-i "Hello World"
And I run :command-accept
Then the message "Hello World" should be shown
# We can't run :message-i as startup command, so we use # We can't run :message-i as startup command, so we use
# :set-cmd-text # :set-cmd-text