/* BEGIN_COMMON_COPYRIGHT_HEADER
 * (c)LGPL2+
 *
 * Razor - a lightweight, Qt based, desktop toolset
 * http://razor-qt.org
 *
 * Copyright: 2010-2011 Razor team
 * Authors:
 *   Alexander Sokoloff <sokoloff.a@gmail.com>
 *
 * This program or library is free software; you can redistribute it
 * and/or modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library 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
 * Lesser General Public License for more details.

 * You should have received a copy of the GNU Lesser General
 * Public License along with this library; if not, write to the
 * Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
 * Boston, MA 02110-1301 USA
 *
 * END_COMMON_COPYRIGHT_HEADER */

#include "xdgicon.h"

#include <QString>
#include <QDebug>
#include <QDir>
#include <QStringList>
#include <QFileInfo>
#include <QCache>
#include "internal/qiconloader_p.h"
#include <QCoreApplication>

/************************************************

 ************************************************/
static void qt_cleanup_icon_cache();
typedef QCache<QString, QIcon> IconCache;

namespace
{
struct QtIconCache : public IconCache
{
	QtIconCache()
	{
		qAddPostRoutine(qt_cleanup_icon_cache);
	}
};
}
Q_GLOBAL_STATIC(IconCache, qtIconCache);

static void qt_cleanup_icon_cache()
{
	qtIconCache()->clear();
}

/************************************************

 ************************************************/
XdgIcon::XdgIcon()
{
}

/************************************************

 ************************************************/
XdgIcon::~XdgIcon()
{
}

/************************************************
 Returns the name of the current icon theme.
 ************************************************/
QString XdgIcon::themeName()
{
	return QIcon::themeName();
}

/************************************************
 Sets the current icon theme to name.
 ************************************************/
void XdgIcon::setThemeName(const QString &themeName)
{
	QIcon::setThemeName(themeName);
	QtXdg::QIconLoader::instance()->updateSystemTheme();
}

/************************************************
 Returns the QIcon corresponding to name in the current icon theme. If no such icon
 is found in the current theme fallback is return instead.
 ************************************************/
QIcon XdgIcon::fromTheme(const QString &iconName, const QIcon &fallback)
{
	if (iconName.isEmpty())
		return fallback;

	bool isAbsolute = (iconName[0] == '/');

	QString name = QFileInfo(iconName).fileName();
	if (name.endsWith(".png", Qt::CaseInsensitive) ||
		name.endsWith(".svg", Qt::CaseInsensitive) ||
		name.endsWith(".xpm", Qt::CaseInsensitive))
	{
		name.truncate(name.length() - 4);
	}

	QIcon icon;

	if (qtIconCache()->contains(name))
	{
		icon = *qtIconCache()->object(name);
	}
	else
	{
		QIcon *cachedIcon;
		if (!isAbsolute)
			cachedIcon = new QIcon(new QtXdg::QIconLoaderEngineFixed(name));
		else
			cachedIcon = new QIcon(iconName);
		qtIconCache()->insert(name, cachedIcon);
		icon = *cachedIcon;
	}

	// Note the qapp check is to allow lazy loading of static icons
	// Supporting fallbacks will not work for this case.
	if (qApp && !isAbsolute && icon.availableSizes().isEmpty())
	{
		return fallback;
	}
	return icon;
}

/************************************************
 Returns the QIcon corresponding to names in the current icon theme. If no such icon
 is found in the current theme fallback is return instead.
 ************************************************/
QIcon XdgIcon::fromTheme(const QStringList &iconNames, const QIcon &fallback)
{
	foreach (QString iconName, iconNames)
	{
		QIcon icon = fromTheme(iconName);
		if (!icon.isNull())
			return icon;
	}

	return fallback;
}