File: test.py

package info (click to toggle)
logtop 0.7-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 200 kB
  • sloc: ansic: 1,426; python: 71; makefile: 54
file content (52 lines) | stat: -rwxr-xr-x 1,363 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
#!/usr/bin/env python

import sys
import os.path as path
sys.path.append(path.realpath(__file__ + '/../../'))

from threading import Thread, Lock
import time
from logtop import logtop  # use make python-module to build it


def build_lines():
    while True:
        for i in range(10):
            yield str(i % 3)
            time.sleep(1)
        time.sleep(10)


class LogtopPrinter(Thread):
    def __init__(self):
        self.lock = Lock()
        self.logtop = logtop(10000)
        Thread.__init__(self)
        self.daemon = True

    def run(self):
        while True:
            self.lock.acquire()
            data = self.logtop.get(6)
            count = self.logtop.qte_of_elements()
            timespan = self.logtop.timespan()
            self.lock.release()
            if timespan == 0:
                timespan = 1
            print "%.2f l/s (%d lines, %.2f seconds): %s" % (count / timespan,
                                                             count,
                                                             timespan,
                                                             repr(data))
            time.sleep(1)

    def feed(self, line):
        self.lock.acquire()
        self.logtop.feed(line)
        self.lock.release()


printer = LogtopPrinter()
printer.start()

for line in build_lines():
    printer.feed(line)