1 # -*- coding: utf-8 -*-
3 # gPodder - A media aggregator and podcast client
4 # Copyright (c) 2005-2012 Thomas Perl and the gPodder Team
6 # gPodder is free software; you can redistribute it and/or modify
7 # it under the terms of the GNU General Public License as published by
8 # the Free Software Foundation; either version 3 of the License, or
9 # (at your option) any later version.
11 # gPodder is distributed in the hope that it will be useful,
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 # GNU General Public License for more details.
16 # You should have received a copy of the GNU General Public License
17 # along with this program. If not, see <http://www.gnu.org/licenses/>.
20 # This metadata block gets parsed by setup.py - use single quotes only
21 __tagline__
= 'Media aggregator and podcast client'
22 __author__
= 'Thomas Perl <thp@gpodder.org>'
24 __date__
= '2012-04-29'
25 __relname__
= 'The Preachification of Convincing John'
26 __copyright__
= '© 2005-2012 Thomas Perl and the gPodder Team'
27 __license__
= 'GNU General Public License, version 3 or later'
28 __url__
= 'http://gpodder.org/'
30 __version_info__
= tuple(int(x
) for x
in __version__
.split('.'))
38 # Check if real hard dependencies are available
43 Error: Module "feedparser" (python-feedparser) not found.
44 The feedparser module can be downloaded from
45 http://code.google.com/p/feedparser/
54 Error: Module "mygpoclient" (python-mygpoclient) not found.
55 The mygpoclient module can be downloaded from
56 http://thp.io/2010/mygpoclient/
65 Error: Module "sqlite3" not found.
66 Build Python with SQLite 3 support or get it from
67 http://code.google.com/p/pysqlite/
73 # The User-Agent string for downloads
74 user_agent
= 'gPodder/%s (+%s)' % (__version__
, __url__
)
76 # Are we running in GUI, Maemo or console mode?
79 self
.fremantle
= False
80 self
.harmattan
= False
88 # D-Bus specific interface names
89 dbus_bus_name
= 'org.gpodder'
90 dbus_gui_object_path
= '/gui'
91 dbus_podcasts_object_path
= '/podcasts'
92 dbus_interface
= 'org.gpodder.interface'
93 dbus_podcasts
= 'org.gpodder.podcasts'
94 dbus_session_bus
= None
96 # Set "win32" to True if we are on Windows
97 win32
= (platform
.system() == 'Windows')
98 # Set "osx" to True if we are on Mac OS X
99 osx
= (platform
.system() == 'Darwin')
101 # i18n setup (will result in "gettext" to be available)
102 # Use _ = gpodder.gettext in modules to enable string translations
103 textdomain
= 'gpodder'
104 locale_dir
= gettext
.bindtextdomain(textdomain
)
105 t
= gettext
.translation(textdomain
, locale_dir
, fallback
=True)
110 ngettext
= t
.ungettext
111 except AttributeError:
114 ngettext
= t
.ngettext
118 # Workaround for bug 650
119 from gtk
.glade
import bindtextdomain
120 bindtextdomain(textdomain
, locale_dir
)
123 # Ignore for QML UI or missing glade module
127 # Set up textdomain for gtk.Builder (this accesses the C library functions)
128 if hasattr(locale
, 'bindtextdomain'):
129 locale
.bindtextdomain(textdomain
, locale_dir
)
133 # Set up socket timeouts to fix bug 174
136 socket
.setdefaulttimeout(SOCKET_TIMEOUT
)
140 # Variables reserved for GUI-specific use (will be set accordingly)
145 user_extensions
= None
147 # Episode states used in the database
148 STATE_NORMAL
, STATE_DOWNLOADED
, STATE_DELETED
= range(3)
150 # Paths (gPodder's home folder, config, db, download and data prefix)
157 # Function to set a new gPodder home folder
158 def set_home(new_home
):
159 global home
, config_file
, database_file
, downloads
160 home
= os
.path
.abspath(new_home
)
162 config_file
= os
.path
.join(home
, 'Settings.json')
163 database_file
= os
.path
.join(home
, 'Database')
164 downloads
= os
.path
.join(home
, 'Downloads')
166 # Default locations for configuration and data files
167 default_home
= os
.path
.expanduser(os
.path
.join('~', 'gPodder'))
168 set_home(os
.environ
.get('GPODDER_HOME', default_home
))
170 if home
!= default_home
:
171 print >>sys
.stderr
, 'Storing data in', home
, '(GPODDER_HOME is set)'
173 # Plugins to load by default
175 'gpodder.plugins.soundcloud',
176 'gpodder.plugins.xspf',
180 """Load (non-essential) plugin modules
182 This loads a default set of plugins, but you can use
183 the environment variable "GPODDER_PLUGINS" to modify
184 the list of plugins."""
185 PLUGINS
= os
.environ
.get('GPODDER_PLUGINS', None)
187 PLUGINS
= DEFAULT_PLUGINS
189 PLUGINS
= PLUGINS
.split()
190 for plugin
in PLUGINS
:
194 print >>sys
.stderr
, 'Cannot load plugin: %s (%s)' % (plugin
, e
)
197 def detect_platform():
201 etc_issue
= open('/etc/issue').read()
205 ui
.fremantle
= ('Maemo 5' in etc_issue
)
206 ui
.harmattan
= ('MeeGo 1.2 Harmattan' in etc_issue
)
208 if (ui
.fremantle
or ui
.harmattan
) and 'GPODDER_HOME' not in os
.environ
:
209 new_home
= os
.path
.expanduser(os
.path
.join('~', 'MyDocs', 'gPodder'))
210 set_home(os
.path
.expanduser(new_home
))