Uptime   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 23
Duplicated Lines 0 %

Importance

Changes 3
Bugs 2 Features 1
Metric Value
c 3
b 2
f 1
dl 0
loc 23
rs 10
wmc 4

3 Methods

Rating   Name   Duplication   Size   Complexity  
A post_init() 0 15 2
A handle() 0 2 1
A _uptime() 0 3 1
1
import time
2
from datetime import datetime, timedelta
3
from event import Event
4
try:
5
  from basemodule import BaseModule
6
except ImportError:
7
  from modules.basemodule import BaseModule
8
class Uptime(BaseModule):
9
  def post_init(self):
10
    uptime_event = Event("__.uptime__")
11
    uptime_event.define(msg_definition="^\.uptime")
12
    uptime_event.subscribe(self)
13
14
    # register ourself to our new custom event
15
    self.bot.register_event(uptime_event, self)
16
17
    starttime = time.time()
18
    localtime = time.localtime()
19
20
    if 'uptime' not in self.bot.mem_store:
21
      self.bot.mem_store['uptime'] = dict()
22
      self.bot.mem_store['uptime']['localtime'] = localtime
23
      self.bot.mem_store['uptime']['starttime'] = starttime 
24
    
25
  def handle(self, event):
26
    self._uptime(event.channel)
27
28
  def _uptime(self, channel):
29
    #print timedelta(seconds=time.time() - self.starttime)
30
    self.say(channel,"I've been up " +str(timedelta(seconds=time.time() - self.bot.mem_store['uptime']['starttime'])).split(".")[0] + ", since "+time.strftime("%a, %d %b %Y %H:%M:%S -0800", self.bot.mem_store['uptime']['localtime']))
31