// Copyright (c) 2011 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef CHROME_COMMON_CHROME_VERSION_INFO_H_ #define CHROME_COMMON_CHROME_VERSION_INFO_H_ #include <string> #include "base/basictypes.h" #include "base/memory/scoped_ptr.h" class FileVersionInfo; namespace chrome { // An instance of chrome::VersionInfo has information about the // current running build of Chrome. class VersionInfo { public: // The possible channels for an installation, from most fun to most stable. enum Channel { CHANNEL_UNKNOWN = 0, // Probably blue CHANNEL_CANARY, // Yellow CHANNEL_DEV, // Technicolor CHANNEL_BETA, // Rainbow CHANNEL_STABLE // Full-spectrum }; VersionInfo(); ~VersionInfo(); // In the rare case where we fail to get the version info, // is_valid() will return false. The other functions will return // the empty string in this case, so it's not harmful if you don't // check is_valid(). bool is_valid() const; // E.g. "Chrome/a.b.c.d" std::string ProductNameAndVersionForUserAgent() const; // E.g. "Chromium" or "Google Chrome". std::string Name() const; // Version number, e.g. "6.0.490.1". std::string Version() const; // The SVN revision of this release. E.g. "55800". std::string LastChange() const; // Whether this is an "official" release of the current Version(): // whether knowing Version() is enough to completely determine what // LastChange() is. bool IsOfficialBuild() const; // OS type. E.g. "Windows", "Linux", "FreeBSD", ... std::string OSType() const; // Returns a human-readable modifier for the version string. For a branded // build, this modifier is the channel ("canary", "dev", or "beta", but "" // for stable). On Windows, this may be modified with additional information // after a hyphen. For multi-user installations, it will return "canary-m", // "dev-m", "beta-m", and for a stable channel multi-user installation, "m". // In branded builds, when the channel cannot be determined, "unknown" will // be returned. In unbranded builds, the modifier is usually an empty string // (""), although on Linux, it may vary in certain distributions. // GetVersionStringModifier() is intended to be used for display purposes. // To simply test the channel, use GetChannel(). static std::string GetVersionStringModifier(); // Returns the channel for the installation. In branded builds, this will be // CHANNEL_STABLE, CHANNEL_BETA, CHANNEL_DEV, or CHANNEL_CANARY. In unbranded // builds, or in branded builds when the channel cannot be determined, this // will be CHANNEL_UNKNOWN. static Channel GetChannel(); #if defined(OS_CHROMEOS) // Sets channel before use. static void SetChannel(const std::string& channel); #endif // Returns a version string to be displayed in "About Chromium" dialog. std::string CreateVersionString() const; private: #if defined(OS_WIN) || defined(OS_MACOSX) scoped_ptr<FileVersionInfo> version_info_; #endif DISALLOW_COPY_AND_ASSIGN(VersionInfo); }; } // namespace chrome #endif // CHROME_COMMON_CHROME_VERSION_INFO_H_