/** 
 * @file llversioninfo.h
 * @brief Routines to access the viewer version and build information
 * @author Martin Reddy
 *
 * $LicenseInfo:firstyear=2009&license=viewerlgpl$
 * Second Life Viewer Source Code
 * Copyright (C) 2010, Linden Research, Inc.
 * 
 * This 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;
 * version 2.1 of the License only.
 * 
 * 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
 * 
 * Linden Research, Inc., 945 Battery Street, San Francisco, CA  94111  USA
 * $/LicenseInfo$
 */

#ifndef LL_LLVERSIONINFO_H
#define LL_LLVERSIONINFO_H

#include <string>
#include "stdtypes.h"

///
/// This API provides version information for the viewer.  This
/// includes access to the major, minor, patch, and build integer
/// values, as well as human-readable string representations. All
/// viewer code that wants to query the current version should 
/// use this API.
///
class LLVersionInfo
{
public:
	/// return the major verion number as an integer
	static S32 getMajor();

	/// return the minor verion number as an integer
	static S32 getMinor();

	/// return the patch verion number as an integer
	static S32 getPatch();

	/// return the build number as an integer
	static S32 getBuild();

	/// return the full viewer version as a string like "2.0.0.200030"
	static const std::string &getVersion();

	/// return the viewer version as a string like "2.0.0"
	static const std::string &getShortVersion();

	/// return the viewer version and channel as a string
	/// like "Second Life Release 2.0.0.200030"
	static const std::string &getChannelAndVersion();

	/// return the channel name, e.g. "Second Life"
	static const std::string &getChannel();
	
    /// return the CMake build type
    static const std::string &getBuildConfig();

	/// reset the channel name used by the viewer.
	static void resetChannel(const std::string& channel);

    /// return the bit width of an address
    static const S32 getAddressSize() { return ADDRESS_SIZE; }

    typedef enum
    {
        TEST_VIEWER,
        PROJECT_VIEWER,
        BETA_VIEWER,
        RELEASE_VIEWER
    } ViewerMaturity;
    static ViewerMaturity getViewerMaturity();
};

#endif