view C++/Xdg.h @ 296:5806c767aec7

Zip: fix resize if read less than requested Task: #312
author David Demelier <markand@malikania.fr>
date Thu, 13 Nov 2014 21:10:13 +0100
parents f6d9fdb5eeeb
children
line wrap: on
line source

/*
 * Xdg.h -- XDG directory specifications
 *
 * Copyright (c) 2013, 2014 David Demelier <markand@malikania.fr>
 *
 * Permission to use, copy, modify, and/or distribute this software for any
 * purpose with or without fee is hereby granted, provided that the above
 * copyright notice and this permission notice appear in all copies.
 *
 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 */

#ifndef _XDG_H_
#define _XDG_H_

#include <vector>
#include <string>

#if defined(_WIN32)
#  if defined(BUILDING_DLL)
#    define EXPORT __declspec(dllexport)
#  else
#    define EXPORT __declspec(dllimport)
#  endif
#else
#  define EXPORT
#endif

/**
 * @class Xdg
 * @brief XDG specifications
 *
 * Read and get XDG directories. This file contains exports thingies so it can
 * compiles successfully on Windows but its usage is discouraged.
 */
class EXPORT Xdg {
public:
	using List	= std::vector<std::string>;

private:
	std::string	m_configHome;
	std::string	m_dataHome;
	std::string	m_cacheHome;
	std::string	m_runtimeDir;
	List		m_configDirs;
	List		m_dataDirs;

public:
	/**
	 * Open an xdg instance and load directories.
	 *
	 * @throw std::runtime_error on failures
	 */
	Xdg();

	/**
	 * Get the config directory. ${XDG_CONFIG_HOME} or ${HOME}/.config
	 *
	 * @return the config directory
	 */
	const std::string &configHome() const noexcept;

	/**
	 * Get the data directory. ${XDG_DATA_HOME} or ${HOME}/.local/share
	 *
	 * @return the data directory
	 */
	const std::string &dataHome() const noexcept;

	/**
	 * Get the cache directory. ${XDG_CACHE_HOME} or ${HOME}/.cache
	 *
	 * @return the cache directory
	 */
	const std::string &cacheHome() const noexcept;

	/**
	 * Get the runtime directory. ${XDG_RUNTIME_DIR} must be set,
	 * if not, it throws an exception.
	 *
	 * The XDG standard says that application should handle XDG_RUNTIME_DIR by
	 * themselves.
	 *
	 * @return the runtime directory
	 * @throw std::runtime_error on error
	 */
	const std::string &runtimeDir() const;

	/**
	 * Get the standard config directories. ${XDG_CONFIG_DIRS} or { "/etc/xdg" }
	 *
	 * @return the list of config directories
	 */
	const List &configDirs() const noexcept;

	/**
	 * Get the data directories. ${XDG_DATA_DIRS} or { "/usr/local/share", "/usr/share" }
	 *
	 * @return the list of data directories
	 */
	const List &dataDirs() const noexcept;
};

#endif // !_XDG_H_