#!/usr/bin/python # LADITools - Linux Audio Desktop Integration Tools # wmladi - Window maker dockapp for jackdbus # Copyright (C) 2007-2010, Marc-Olivier Barre # Copyright (C) 2007-2009, Nedko Arnaudov # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . import sys import os from wmdocklib import wmoo, pywmhelpers import time try: import imp imp.find_module('laditools') except ImportError: # Running from the build tree? sys.path.insert(0, os.path.join(sys.path[0], os.pardir)) import laditools import pygtk pygtk.require('2.0') import gtk import gobject # Default configuration autostart_default = 0 debug = False class wmladi (wmoo.Application, laditools.manager): def __init__ (self): # Handle the configuration self.global_config = laditools.config () self.param_dict = self.global_config.get_config_section ('wmladi') if self.param_dict != None: if 'autostart' not in self.param_dict: self.param_dict['autostart'] = str (autostart_default) else: self.param_dict = {} self.param_dict['autostart'] = str (autostart_default) autostart = self.param_dict['autostart'] wmoo.Application.__init__ ( self, #background = os.path.dirname(sys.argv[0]) + os.sep + "wmjackctl.xpm", margin = 2, debug = False) laditools.manager.__init__(self, self.global_config.get_config_section ('ladimenu'), int(autostart)) self.addCallback (self.on_button_release, 'buttonrelease', area=(0,0,64,64)) self.lines = [] for i in range (6): self.lines.append ("") self.clear () self.started = False def set_starting_status (self): self.set_line (0, "JACK") self.set_line (1, "Starting") self.clear_line (2) self.clear_line (3) self.clear_line (4) self.clear_line (5) def on_button_release (self, event): if event['button'] == 3: self.menu_activate () def set_line (self, line, text): self.lines[line] = text while len (self.lines[line]) < 9: self.lines[line] += ' ' def clear_line (self, line): self.set_line (line, "") def clear (self): for i in range (6): self.clear_line (i) def update (self): try: if self.jack_is_started(): self.started = True line0 = "JACK" if self.jack_is_realtime(): line0 += " RT" else: line0 += " " if self.a2j_is_available(): try: if self.a2j_is_started(): line0 += ' A' else: line0 += ' a' except: pass self.set_line(0, line0) self.set_line(1, "started") self.set_line(2, "%.3f %%" % self.jack_get_load()) xruns = self.jack_get_xruns() if xruns == 0: self.set_line(3, "no xruns") elif xruns == 1: self.set_line(3, "1 xrun") elif xruns > 999: self.set_line(3, "lot xruns") else: self.set_line(3, "%s xruns" % xruns) rate = self.jack_get_sample_rate() if rate % 1000.0 == 0: self.set_line(4, "%.0f Khz" % (rate / 1000.0)) else: self.set_line(4, "%.1f Khz" % (rate / 1000.0)) self.set_line(5, "%.1f ms" % self.jack_get_latency()) else: self.set_line(0, "JACK") self.set_line(1, "stopped") if self.started: self.clear_line(2) self.clear_line(3) self.clear_line(4) self.clear_line(5) self.started = False self.clear_diagnose_text() except Exception as e: self.set_diagnose_text(repr(e)) if debug: print(repr (e)) self.set_line(0, "JACK") self.set_line(1, "is sick") self.clear_line(2) self.clear_line(3) self.clear_line(4) self.clear_line(5) self.clear_jack_proxies() self.put_lines (self.lines) wmoo.Application.update (self) # Take a look at the processes we've started so we don't get any zombies for i in self.proc_list: i.poll () def put_lines (self, lines): x = 3 y = 2 for line in lines: self.putString (x, y, line) y += 9 def do_dockapp (self): """this is called from event loop. events are examined and if a callback has been registered, it is called, passing it the event as argument. """ event = pywmhelpers.getEvent () while not event is None: if event['type'] == 'destroynotify': sys.exit (0) for evtype, key, area, callback in self._events: if evtype is not None and evtype != event['type']: continue if key is not None and key != event['button']: continue if area is not None: if not area[0] <= event['x'] <= area[2]: continue if not area[1] <= event['y'] <= area[3]: continue callback (event) event = pywmhelpers.getEvent () self.redraw () #print "tick" return True def run_sleep (self): self.go = True while self.go: while gtk.events_pending (): gtk.main_iteration () self.do_dockapp () while gtk.events_pending (): gtk.main_iteration () time.sleep (self._sleep) def run_gtk (self): #print self._sleep gobject.timeout_add (int(self._sleep * 1000), self.do_dockapp) gtk.main () def run (self): self.run_gtk () self.global_config.set_config_section ('wmladi', self.param_dict) self.global_config.set_config_section ('ladimenu', self.menu_array) self.global_config.save () wmladi ().run ()