view contrib/xchat-audacious.py @ 3598:9fd97ab30fdc trunk

make audacious be re-linked if a dependent library has been rebuilt.
author Yoshiki Yazawa <yaz@cc.rim.or.jp>
date Sun, 23 Sep 2007 01:34:10 +0900
parents 548a1db694e6
children
line wrap: on
line source

#
# X-Chat Audacious for Audacious 1.4 and later
# This uses the native Audacious D-Bus interface.
#
# To consider later:
#   - support org.freedesktop.MediaPlayer (MPRIS)?
#
# This script is in the public domain.
#   $Id: xchat-audacious.py 4574 2007-05-16 07:46:17Z deitarion $
#

__module_name__ = "xchat-audacious"
__module_version__ = "1.0.1"
__module_description__ = "Get NP information from Audacious"

from dbus import Bus, DBusException
import xchat

# connect to DBus
bus = Bus(Bus.TYPE_SESSION)

def get_aud():
	try:
		return bus.get_object('org.atheme.audacious', '/org/atheme/audacious')
	except DBusException:
		print "\x02Either Audacious is not running or you have something wrong with your D-Bus setup."
		return None

def command_np(word, word_eol, userdata):
	aud = get_aud()
	if aud:
		pos = aud.Position()

		length = aud.SongLength(pos)
		length = (length > 0) and ("%d:%02d" % (length / 60, length % 60)) or "stream"

		playSecs = aud.Time() / 1000
		xchat.command("SAY [%s | %d:%02d/%s]" % (
			aud.SongTitle(pos).encode("utf8"),
			playSecs / 60, playSecs % 60, length))
	return xchat.EAT_ALL

def makeVoidCommand(cmd):
	def callback(word, word_eol, userdata):
		getattr(get_aud(), cmd, lambda: None)()
		return xchat.EAT_ALL
	return callback

def command_send(word, word_eol, userdata):
	if len(word) < 2:
		print "You must provide a user to send the track to."
		return xchat.EAT_ALL

	aud = get_aud()
	if aud:
		xchat.command('DCC SEND %s "%s"' % (word[1], aud.SongFilename(aud.Position()).encode("utf8")))
	return xchat.EAT_ALL

xchat.hook_command("NP",    command_np,                 help="Displays current playing song.")
xchat.hook_command("NEXT",  makeVoidCommand('Advance'), help="Advances in Audacious' playlist.")
xchat.hook_command("PREV",  makeVoidCommand('Reverse'), help="Goes backwards in Audacious' playlist.")
xchat.hook_command("PAUSE", makeVoidCommand('Pause'),   help="Toggles paused status.")
xchat.hook_command("STOP",  makeVoidCommand('Stop'),    help="Stops playback.")
xchat.hook_command("PLAY",  makeVoidCommand('Play'),    help="Begins playback.")
xchat.hook_command("SENDTRACK", command_send, help="Syntax: /SENDTRACK <nick>\nSends the currently playing track to a user.")

# IRC+PP support section

# XChat is lame and does not give us a server list.
def get_servers():
	chanlist = xchat.get_list("channels")
	servlist = []

	for i in chanlist:
		if i.server not in servlist:
			servlist.append(i.server)

	return servlist

ignore_services = 0;
def ignore_service_errors_cb(word, word_eol, userdata):
	global ignore_services

	if ignore_services == 1:
		return xchat.EAT_ALL

	return xchat.EAT_NONE

#xchat.hook_print("Notice", ignore_service_errors_cb)

def unset_ignore_services(userdata=None):
	global ignore_services

	ignore_services = 0
	return 1

last_title = None

def presence_notification_dispatch(userdata=None):
	global ignore_services, last_title

	aud = get_aud()

	ignore_services = 1
	if aud:
		pos = aud.Position()

		title = aud.SongTitle(pos).encode("utf8")

		if title != last_title:
			slist = get_servers()
			for i in slist:
				ctx = xchat.find_context(i)

				ctx.command("nickserv set qproperty np %s" % (title))

			last_title = title

	return 1

#presence_notification_dispatch()
#xchat.hook_timer(3000, presence_notification_dispatch)
#xchat.hook_timer(500, unset_ignore_services)

print "xchat-audacious $Id: xchat-audacious.py 4574 2007-05-16 07:46:17Z deitarion $ loaded"