Commit a41c4565 authored by Jacek Sowiński's avatar Jacek Sowiński

Properly split alias options wrapped in quotes

parent 8167470b
...@@ -38,7 +38,7 @@ class GetSubcommandTest(TopydoTest): ...@@ -38,7 +38,7 @@ class GetSubcommandTest(TopydoTest):
self.assertTrue(issubclass(real_cmd, AddCommand)) self.assertTrue(issubclass(real_cmd, AddCommand))
self.assertEqual(final_args, ["help"]) self.assertEqual(final_args, ["help"])
def test_alias(self): def test_alias01(self):
config("test/data/aliases.conf") config("test/data/aliases.conf")
args = ["foo"] args = ["foo"]
...@@ -46,6 +46,14 @@ class GetSubcommandTest(TopydoTest): ...@@ -46,6 +46,14 @@ class GetSubcommandTest(TopydoTest):
self.assertTrue(issubclass(real_cmd, DeleteCommand)) self.assertTrue(issubclass(real_cmd, DeleteCommand))
self.assertEqual(final_args, ["-f", "test"]) self.assertEqual(final_args, ["-f", "test"])
def test_alias02(self):
config("test/data/aliases.conf")
args = ["format"]
real_cmd, final_args = get_subcommand(args)
self.assertTrue(issubclass(real_cmd, ListCommand))
self.assertEqual(final_args, ["-F", "|I| x c d {(}p{)} s k", "-n", "25"])
def test_default_cmd01(self): def test_default_cmd01(self):
args = ["bar"] args = ["bar"]
real_cmd, final_args = get_subcommand(args) real_cmd, final_args = get_subcommand(args)
......
[aliases] [aliases]
foo = rm -f test foo = rm -f test
baz = FooBar baz = FooBar
format = ls -F "|I| x c d {(}p{)} s k" -n 25
...@@ -15,6 +15,7 @@ ...@@ -15,6 +15,7 @@
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
import os import os
import shlex
from six import iteritems from six import iteritems
from six.moves import configparser from six.moves import configparser
...@@ -300,7 +301,7 @@ class _Config: ...@@ -300,7 +301,7 @@ class _Config:
alias_dict = dict() alias_dict = dict()
for alias, meaning in aliases: for alias, meaning in aliases:
meaning = meaning.split() meaning = shlex.split(meaning)
real_subcommand = meaning[0] real_subcommand = meaning[0]
alias_args = meaning[1:] alias_args = meaning[1:]
alias_dict[alias] = (real_subcommand, alias_args) alias_dict[alias] = (real_subcommand, alias_args)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment