Statistics
| Branch: | Tag: | Revision:

root / kamaki / cli / history.py @ 75a0ea7d

History | View | Annotate | Download (2.9 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

    
37
def order_free_contains(containing, contained):
38
    superset = containing.split()
39
    for term in contained.split():
40
        if term not in superset:
41
            return False
42
    return True
43

    
44

    
45
class History(object):
46
    def __init__(self, filepath):
47
        self.filepath = filepath
48

    
49
    @classmethod
50
    def _match(self, line, match_terms):
51
        if match_terms is None:
52
            return True
53
        for term in match_terms.split():
54
            if term not in line:
55
                return False
56
        return True
57

    
58
    def get(self, match_terms=None, limit=0):
59
        f = open(self.filepath, 'r')
60
        result = ['%s.  \t%s' % (index + 1, line)\
61
            for index, line in enumerate(f.readlines())\
62
            if self._match(line, match_terms)]
63
        offset = len(result) - limit if limit and len(result) > limit else 0
64
        return result[offset:]
65

    
66
    def add(self, line):
67
        f = open(self.filepath, 'a+')
68
        f.write(line + '\n')
69
        f.close()
70

    
71
    def clean(self):
72
        f = open(self.filepath, 'w')
73
        f.close()
74

    
75
    def retrieve(self, cmd_id):
76
        """
77
        :param cmd_id: (int) the id of the command to retrieve
78

79
        :returns: (str) the stored command record without the id
80
        """
81
        with open(self.filepath) as f:
82
            for line in f.readlines():
83
                if line.startswith('%s ' % cmd_id):
84
                    return line[4:]
85
        return None