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 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99
|
# Miro - an RSS based video player application
# Copyright (C) 2005, 2006, 2007, 2008, 2009, 2010, 2011
# Participatory Culture Foundation
#
# 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 2 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, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
#
# In addition, as a special exception, the copyright holders give
# permission to link the code of portions of this program with the OpenSSL
# library.
#
# You must obey the GNU General Public License in all respects for all of
# the code used other than OpenSSL. If you modify file(s) with this
# exception, you may extend this exception to your version of the file(s),
# but you are not obligated to do so. If you do not wish to do so, delete
# this exception statement from your version. If you delete this exception
# statement from all source files in the program, then also delete it here.
"""
Holds functions that associate Miro with certain protocols
"""
import gconf
from miro.plat.config import gconf_lock
def associate_protocols(command):
_associate_protocol("magnet", command, False)
def disassociate_protocols(command):
_disassociate_protocol("magnet", command)
def _associate_protocol(name, command, overwrite_existing=False):
url_handlers_key = "/desktop/gnome/url-handlers/" + name + "/"
if not _is_associated(name) or overwrite_existing:
gconf_lock.acquire()
try:
gconf_client = gconf.client_get_default()
if gconf_client.set_string(url_handlers_key + "command", command):
gconf_client.set_bool(url_handlers_key + "needs_terminal", False)
gconf_client.set_bool(url_handlers_key + "enabled", True)
success = True
else:
success = False
finally:
gconf_lock.release()
else:
success = True
return success
def _disassociate_protocol(name, command):
url_handlers_key = "/desktop/gnome/url-handlers/" + name + "/"
if _is_associated(name, command):
gconf_lock.acquire()
try:
gconf_client = gconf.client_get_default()
if gconf_client.set_bool(url_handlers_key + "enabled", False):
success = True
else:
success = False
finally:
gconf_lock.release()
else:
success = True
return success
def _is_associated(protocol, command=None):
""" Checks whether a protocol currently is
associated with the given command, or,
if none is given, whether the protocol
is associated with anything at all.
"""
url_handlers_key = "/desktop/gnome/url-handlers/" + protocol + "/"
gconf_lock.acquire()
try:
gconf_client = gconf.client_get_default()
key = gconf_client.get(url_handlers_key + "command")
if key is None:
associated = False
else:
enabled = gconf_client.get(url_handlers_key + "enabled")
if command:
associated = key.get_string() == command and enabled.get_bool()
else:
associated = key.get_string() != "" and enabled.get_bool()
finally:
gconf_lock.release()
return associated
|