/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* vim: set ts=8 sts=2 et sw=2 tw=80: */ /* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
// This file was shamelessly copied from mozilla/xpinstall/wizard/unix/src2
class nsINIParser { public:
nsINIParser() {}
~nsINIParser() = default;
/** * Initialize the INIParser with a nsIFile. If this method fails, no * other methods should be called. This method reads and parses the file, * the class does not hold a file handle open. An instance must only be * initialized once.
*/
nsresult Init(nsIFile* aFile);
nsresult InitFromString(const nsCString& aStr);
/** * Enumerate the sections within the INI file. * * The callback takes the section name as an argument, and can can return * false to stop enumeration.
*/
nsresult GetSections(std::function<bool(constchar*)>&& aCallback);
/** * Enumerate the strings within a section. If the section does not exist, this * function will silently return. * * The callback takes the key and value strings as arguments, and can return * false to stop enumeration.
*/
nsresult GetStrings( constchar* aSection,
std::function<bool(constchar*, constchar*)>&& aCallback);
/** * Get the value of the specified key in the specified section * of the INI file represented by this instance. * * @param aSection section name * @param aKey key name * @param aResult the value found * @throws NS_ERROR_FAILURE if the specified section/key could not be * found.
*/
nsresult GetString(constchar* aSection, constchar* aKey,
nsACString& aResult);
/** * Alternate signature of GetString that uses a pre-allocated buffer * instead of a nsACString (for use in the standalone glue before * the glue is initialized). * * @throws NS_ERROR_LOSS_OF_SIGNIFICANT_DATA if the aResult buffer is not * large enough for the data. aResult will be filled with as * much data as possible. * * @see GetString [1]
*/
nsresult GetString(constchar* aSection, constchar* aKey, char* aResult,
uint32_t aResultLen);
/** * Sets the value of the specified key in the specified section. The section * is created if it does not already exist. * * @oaram aSection section name * @param aKey key name * @param aValue the value to set
*/
nsresult SetString(constchar* aSection, constchar* aKey, constchar* aValue);
/** * Deletes the value of the specified key in the specified section. * * @param aSection section name * @param aKey key name * * @throws NS_ERROR_FAILURE if the string was not set.
*/
nsresult DeleteString(constchar* aSection, constchar* aKey);
/** * Deletes the specified section. * * @param aSection section name * * @throws NS_ERROR_FAILURE if the section did not exist.
*/
nsresult DeleteSection(constchar* aSection);
/** * Renames the specified section. * * @param aSection section name * @param aNewName new section name * * @throws NS_ERROR_FAILURE if the section did not exist. * @throws NS_ERROR_ILLEGAL_VALUE if the new section name already exists.
*/
nsresult RenameSection(constchar* aSection, constchar* aNewName);
/** * Writes the ini data to disk. * @param aFile the file to write to * @throws NS_ERROR_FAILURE on failure.
*/
nsresult WriteToFile(nsIFile* aFile);