forked from openlp/openlp
166 lines
6.0 KiB
Python
166 lines
6.0 KiB
Python
# -*- coding: utf-8 -*-
|
|
# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
|
|
|
|
###############################################################################
|
|
# OpenLP - Open Source Lyrics Projection #
|
|
# --------------------------------------------------------------------------- #
|
|
# Copyright (c) 2008-2012 Raoul Snyman #
|
|
# Portions copyright (c) 2008-2012 Tim Bentley, Gerald Britton, Jonathan #
|
|
# Corwin, Michael Gorven, Scott Guerrieri, Matthias Hub, Meinert Jordan, #
|
|
# Armin Köhler, Joshua Miller, Stevan Pettit, Andreas Preikschat, Mattias #
|
|
# Põldaru, Christian Richter, Philip Ridout, Simon Scudder, Jeffrey Smith, #
|
|
# Maikel Stuivenberg, Martin Thompson, Jon Tibble, Frode Woldsund #
|
|
# --------------------------------------------------------------------------- #
|
|
# 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; version 2 of the License. #
|
|
# #
|
|
# 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., 59 #
|
|
# Temple Place, Suite 330, Boston, MA 02111-1307 USA #
|
|
###############################################################################
|
|
"""
|
|
Provide handling for persisting OpenLP settings. OpenLP uses QSettings to
|
|
manage settings persistence. QSettings provides a single API for saving and
|
|
retrieving settings from the application but writes to disk in an OS dependant
|
|
format.
|
|
"""
|
|
import os
|
|
|
|
from PyQt4 import QtCore
|
|
|
|
from openlp.core.utils import AppLocation
|
|
|
|
class SettingsManager(object):
|
|
"""
|
|
Class to provide helper functions for the loading and saving of application
|
|
settings.
|
|
"""
|
|
|
|
@staticmethod
|
|
def get_last_dir(section, num=None):
|
|
"""
|
|
Read the last directory used for plugin.
|
|
|
|
``section``
|
|
The section of code calling the method. This is used in the
|
|
settings key.
|
|
|
|
``num``
|
|
Defaults to *None*. A further qualifier.
|
|
"""
|
|
if num:
|
|
name = u'last directory %d' % num
|
|
else:
|
|
name = u'last directory'
|
|
last_dir = unicode(QtCore.QSettings().value(
|
|
section + u'/' + name, QtCore.QVariant(u'')).toString())
|
|
return last_dir
|
|
|
|
@staticmethod
|
|
def set_last_dir(section, directory, num=None):
|
|
"""
|
|
Save the last directory used for plugin.
|
|
|
|
``section``
|
|
The section of code calling the method. This is used in the
|
|
settings key.
|
|
|
|
``directory``
|
|
The directory being stored in the settings.
|
|
|
|
``num``
|
|
Defaults to *None*. A further qualifier.
|
|
"""
|
|
if num:
|
|
name = u'last directory %d' % num
|
|
else:
|
|
name = u'last directory'
|
|
QtCore.QSettings().setValue(
|
|
section + u'/' + name, QtCore.QVariant(directory))
|
|
|
|
@staticmethod
|
|
def set_list(section, name, list):
|
|
"""
|
|
Save a list to application settings.
|
|
|
|
``section``
|
|
The section of the settings to store this list.
|
|
|
|
``name``
|
|
The name of the list to save.
|
|
|
|
``list``
|
|
The list of values to save.
|
|
"""
|
|
settings = QtCore.QSettings()
|
|
settings.beginGroup(section)
|
|
old_count = settings.value(
|
|
u'%s count' % name, QtCore.QVariant(0)).toInt()[0]
|
|
new_count = len(list)
|
|
settings.setValue(u'%s count' % name, QtCore.QVariant(new_count))
|
|
for counter in range(new_count):
|
|
settings.setValue(
|
|
u'%s %d' % (name, counter), QtCore.QVariant(list[counter-1]))
|
|
if old_count > new_count:
|
|
# Tidy up any old list items
|
|
for counter in range(new_count, old_count):
|
|
settings.remove(u'%s %d' % (name, counter))
|
|
settings.endGroup()
|
|
|
|
@staticmethod
|
|
def load_list(section, name):
|
|
"""
|
|
Load a list from the config file.
|
|
|
|
``section``
|
|
The section of the settings to load the list from.
|
|
|
|
``name``
|
|
The name of the list.
|
|
"""
|
|
settings = QtCore.QSettings()
|
|
settings.beginGroup(section)
|
|
list_count = settings.value(
|
|
u'%s count' % name, QtCore.QVariant(0)).toInt()[0]
|
|
list = []
|
|
if list_count:
|
|
for counter in range(list_count):
|
|
item = unicode(
|
|
settings.value(u'%s %d' % (name, counter)).toString())
|
|
if item:
|
|
list.append(item)
|
|
settings.endGroup()
|
|
return list
|
|
|
|
@staticmethod
|
|
def get_files(section=None, extension=None):
|
|
"""
|
|
Get a list of files from the data files path.
|
|
|
|
``section``
|
|
Defaults to *None*. The section of code getting the files - used
|
|
to load from a section's data subdirectory.
|
|
|
|
``extension``
|
|
Defaults to *None*. The extension to search for.
|
|
"""
|
|
path = AppLocation.get_data_path()
|
|
if section:
|
|
path = os.path.join(path, section)
|
|
try:
|
|
files = os.listdir(path)
|
|
except OSError:
|
|
return []
|
|
if extension:
|
|
return [filename for filename in files
|
|
if extension == os.path.splitext(filename)[1]]
|
|
else:
|
|
# no filtering required
|
|
return files
|