Statistics
| Branch: | Tag: | Revision:

root / kamaki / cli / commands / history_cli.py @ 304c90b5

History | View | Annotate | Download (3 kB)

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
_commands = [history_cmds]
45

    
46

    
47
class _init_history(_command_init):
48
    def main(self):
49
        self.history = History(self.config.get('history', 'file'))
50

    
51

    
52
@command(history_cmds)
53
class history_show(_init_history):
54
    """Show history [containing terms...]"""
55

    
56
    def __init__(self, arguments={}):
57
        super(self.__class__, self).__init__(arguments)
58
        self.arguments['limit'] =\
59
            IntArgument('number of lines to show', '-n', default=0)
60
        self.arguments['match'] =\
61
            ValueArgument('show lines that match all given terms', '--match')
62

    
63
    def main(self):
64
        super(self.__class__, self).main()
65
        ret = self.history.get(match_terms=self.get_argument('match'),
66
            limit=self.get_argument('limit'))
67
        print(''.join(ret))
68

    
69

    
70
@command(history_cmds)
71
class history_clean(_init_history):
72
    """Clean up history"""
73

    
74
    def main(self):
75
        super(self.__class__, self).main()
76
        self.history.clean()
77

    
78
@command(history_cmds)
79
class history_recall(_init_history):
80
    """Re-call a previously called command"""
81

    
82
    def main(self, commandid):
83
        super(self.__class__, self).main()
84
        r = self.history.retrieve(commandid)
85
        print(r)