Complete UI/cli interface refactoring, minor bugs
[kamaki] / kamaki / cli / commands / history_cli.py
1 #!/usr/bin/env python
2
3 # Copyright 2012 GRNET S.A. All rights reserved.
4 #
5 # Redistribution and use in source and binary forms, with or
6 # without modification, are permitted provided that the following
7 # conditions are met:
8 #
9 #   1. Redistributions of source code must retain the above
10 #      copyright notice, this list of conditions and the following
11 #      disclaimer.
12 #
13 #   2. Redistributions in binary form must reproduce the above
14 #      copyright notice, this list of conditions and the following
15 #      disclaimer in the documentation and/or other materials
16 #      provided with the distribution.
17 #
18 # THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
19 # OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
20 # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
21 # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
22 # CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
25 # USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
26 # AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
28 # ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 # POSSIBILITY OF SUCH DAMAGE.
30 #
31 # The views and conclusions contained in the software and
32 # documentation are those of the authors and should not be
33 # interpreted as representing official policies, either expressed
34 # or implied, of GRNET S.A.
35
36 from kamaki.cli.command_tree import CommandTree
37 from kamaki.cli.argument import IntArgument, ValueArgument
38 from kamaki.cli.history import History
39 from kamaki.cli import command
40 from kamaki.cli.commands import _command_init
41
42
43 history_cmds = CommandTree('history', 'Command history')
44
45
46 class _init_history(_command_init):
47     def main(self):
48         self.history = History(self.config.get('history', 'file'))
49
50
51 @command(history_cmds)
52 class history(_init_history):
53     """Show history [containing terms...]"""
54
55     def __init__(self, arguments={}):
56         super(history, self).__init__(arguments)
57         self.arguments['limit'] =\
58             IntArgument('number of lines to show', '-n', default=0)
59         self.arguments['match'] =\
60             ValueArgument('show lines that match all given terms', '--match')
61
62     def main(self):
63         super(history, self).main()
64         ret = self.history.get(match_terms=self.get_argument('match'),
65             limit=self.get_argument('limit'))
66         print(''.join(ret))
67
68
69 @command(history_cmds)
70 class history_clean(_init_history):
71     """Clean up history"""
72
73     def main(self):
74         super(history_clean, self).main()
75         self.history.clean()