pvl/syslog/tail.py
author Tero Marttila <terom@paivola.fi>
Sun, 13 Jan 2013 01:50:25 +0200
changeset 114 2e88e1d8e604
parent 73 ef01c4639689
child 122 f742c866c765
permissions -rw-r--r--
pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
31
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
     1
"""
114
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
     2
    Iterate over input lines in filesystem files. 
31
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
     3
"""
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
     4
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
     5
import os
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
     6
49
30c615bf7751 pvl.syslog.tail: split Tail vs TailFile
Tero Marttila <terom@fixme.fi>
parents: 46
diff changeset
     7
import logging; log = logging.getLogger('pvl.syslog.tail')
31
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
     8
49
30c615bf7751 pvl.syslog.tail: split Tail vs TailFile
Tero Marttila <terom@fixme.fi>
parents: 46
diff changeset
     9
class Tail (object) :
31
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    10
    """
114
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    11
        Follow a file on the filesystem, reading lines until EOF, and re-opening if replaced.
31
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    12
114
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    13
        Never blocks, no fileno() to poll. Just poll(timeout=POLL).
49
30c615bf7751 pvl.syslog.tail: split Tail vs TailFile
Tero Marttila <terom@fixme.fi>
parents: 46
diff changeset
    14
114
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    15
        Not writable.
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    16
    """
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    17
    
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    18
    POLL = 2.0 
49
30c615bf7751 pvl.syslog.tail: split Tail vs TailFile
Tero Marttila <terom@fixme.fi>
parents: 46
diff changeset
    19
114
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    20
    def __init__ (self, path, skip=None, **opts) :
59
caed0ed82709 pvl.syslog.tail: re-implement seek=True
Tero Marttila <terom@fixme.fi>
parents: 53
diff changeset
    21
        log.debug("%s", path)
caed0ed82709 pvl.syslog.tail: re-implement seek=True
Tero Marttila <terom@fixme.fi>
parents: 53
diff changeset
    22
49
30c615bf7751 pvl.syslog.tail: split Tail vs TailFile
Tero Marttila <terom@fixme.fi>
parents: 46
diff changeset
    23
        self.path = path
114
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    24
        self.reopen()
59
caed0ed82709 pvl.syslog.tail: re-implement seek=True
Tero Marttila <terom@fixme.fi>
parents: 53
diff changeset
    25
114
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    26
        if skip :
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    27
            self.skip()
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    28
   
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    29
    def open (self) :
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    30
        log.debug("%s", self)
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    31
        return open(self.path, 'r')
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    32
53
685fd90bc610 pvl.syslog.tail: bugfix, log.debug readline
Tero Marttila <terom@fixme.fi>
parents: 49
diff changeset
    33
    def stat (self) :
31
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    34
        """
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    35
            Return a key identifying the file at our path.
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    36
        """
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    37
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    38
        st = os.stat(self.path)
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    39
53
685fd90bc610 pvl.syslog.tail: bugfix, log.debug readline
Tero Marttila <terom@fixme.fi>
parents: 49
diff changeset
    40
        stat = st.st_dev, st.st_ino
685fd90bc610 pvl.syslog.tail: bugfix, log.debug readline
Tero Marttila <terom@fixme.fi>
parents: 49
diff changeset
    41
685fd90bc610 pvl.syslog.tail: bugfix, log.debug readline
Tero Marttila <terom@fixme.fi>
parents: 49
diff changeset
    42
        log.debug("%s: %s", self, stat)
685fd90bc610 pvl.syslog.tail: bugfix, log.debug readline
Tero Marttila <terom@fixme.fi>
parents: 49
diff changeset
    43
685fd90bc610 pvl.syslog.tail: bugfix, log.debug readline
Tero Marttila <terom@fixme.fi>
parents: 49
diff changeset
    44
        return stat
114
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    45
 
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    46
    def reopen (self) :
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    47
        """
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    48
            Re-initialize our file state from path.
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    49
        """
31
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    50
114
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    51
        # XXX: use fstat for "atomic" open+stat?
49
30c615bf7751 pvl.syslog.tail: split Tail vs TailFile
Tero Marttila <terom@fixme.fi>
parents: 46
diff changeset
    52
        self.file = self.open()
30c615bf7751 pvl.syslog.tail: split Tail vs TailFile
Tero Marttila <terom@fixme.fi>
parents: 46
diff changeset
    53
        self._stat = self.stat()
31
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    54
49
30c615bf7751 pvl.syslog.tail: split Tail vs TailFile
Tero Marttila <terom@fixme.fi>
parents: 46
diff changeset
    55
    def changed (self) :
31
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    56
        """
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    57
            Has the underlying file changed?
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    58
        """
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    59
49
30c615bf7751 pvl.syslog.tail: split Tail vs TailFile
Tero Marttila <terom@fixme.fi>
parents: 46
diff changeset
    60
        return self.stat() != self._stat
31
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    61
114
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    62
    def raedline (self) :
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    63
        """
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    64
            Reads any available line from file.
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    65
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    66
            Returns None if at EOF.
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    67
        """
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    68
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    69
    def readline (self) :
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    70
        """
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    71
            Reads a line from the file, without trailing \n.
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    72
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    73
            Returns None on EOF.
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    74
        """
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    75
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    76
        line = self.file.readline()
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    77
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    78
        if not line :
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    79
            line = None
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    80
        else : 
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    81
            line = line.rstrip('\r\n')
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    82
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    83
        log.debug("%s", line)
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    84
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    85
        return line
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    86
31
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    87
    def readlines (self, eof_mark=False) :
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    88
        """
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    89
            Reads any available lines from the file.
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    90
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    91
            Reopens the file on EOF if the underlying file changed.
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    92
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    93
                eof_mark:   yields a special None line when this happens.
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    94
        """
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    95
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
    96
        while True :
114
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    97
            line = self.readline()
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    98
            
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
    99
            if line :
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   100
                yield line
31
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   101
114
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   102
            elif self.changed() :
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   103
                log.debug("EOF: reopen")
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   104
                self.reopen()
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   105
                
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   106
                if eof_mark :
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   107
                    yield None # special token
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   108
                
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   109
                # keep going
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   110
                continue
31
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   111
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   112
            else :
114
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   113
                log.debug("EOF: wait")
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   114
                break
31
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   115
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   116
    __iter__ = readlines
3e6d0feb115c pvl.syslog: import from pvl-collectd
Tero Marttila <terom@paivola.fi>
parents:
diff changeset
   117
114
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   118
    def skip (self) :
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   119
        """
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   120
            Skip any available lines.
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   121
        """
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   122
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   123
        for line in self.readlines() :
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   124
            pass
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   125
2e88e1d8e604 pvl.syslog.tail: split into pvl.syslog.file/tail, clarify line/None/EOFError behaviour
Tero Marttila <terom@paivola.fi>
parents: 73
diff changeset
   126
53
685fd90bc610 pvl.syslog.tail: bugfix, log.debug readline
Tero Marttila <terom@fixme.fi>
parents: 49
diff changeset
   127
    def __str__ (self) :
685fd90bc610 pvl.syslog.tail: bugfix, log.debug readline
Tero Marttila <terom@fixme.fi>
parents: 49
diff changeset
   128
        return self.path
685fd90bc610 pvl.syslog.tail: bugfix, log.debug readline
Tero Marttila <terom@fixme.fi>
parents: 49
diff changeset
   129