// Copyright (c) 2010 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_BROWSER_CHROMEOS_VERSION_LOADER_H_ #define CHROME_BROWSER_CHROMEOS_VERSION_LOADER_H_ #pragma once #include <string> #include "base/callback.h" #include "base/gtest_prod_util.h" #include "content/browser/cancelable_request.h" class FilePath; namespace chromeos { // ChromeOSVersionLoader loads the version of Chrome OS from the file system. // Loading is done asynchronously on the file thread. Once loaded, // ChromeOSVersionLoader callback to a method of your choice with the version // (or an empty string if the version couldn't be found). // To use ChromeOSVersionLoader do the following: // // . In your class define a member field of type chromeos::VersionLoader and // CancelableRequestConsumerBase. // . Define the callback method, something like: // void OnGetChromeOSVersion(chromeos::VersionLoader::Handle, // std::string version); // . When you want the version invoke: loader.GetVersion(&consumer, callback); // // This class also provides the ability to load the bios firmware using // loader.GetFirmware(&consumer, callback); class VersionLoader : public CancelableRequestProvider { public: VersionLoader(); enum VersionFormat { VERSION_SHORT, VERSION_SHORT_WITH_DATE, VERSION_FULL, }; // Signature typedef Callback2<Handle, std::string>::Type GetVersionCallback; typedef CancelableRequest<GetVersionCallback> GetVersionRequest; typedef Callback2<Handle, std::string>::Type GetFirmwareCallback; typedef CancelableRequest<GetFirmwareCallback> GetFirmwareRequest; // Asynchronously requests the version. // If |full_version| is true version string with extra info is extracted, // otherwise it's in short format x.x.xx.x. Handle GetVersion(CancelableRequestConsumerBase* consumer, GetVersionCallback* callback, VersionFormat format); Handle GetFirmware(CancelableRequestConsumerBase* consumer, GetFirmwareCallback* callback); // Parse the version information as a Chrome platfrom, not Chrome OS // TODO(rkc): Change this and everywhere it is used once we switch Chrome OS // over to xx.yyy.zz version numbers instead of 0.xx.yyy.zz // Refer to http://code.google.com/p/chromium-os/issues/detail?id=15789 void EnablePlatformVersions(bool enable); static const char kFullVersionPrefix[]; static const char kVersionPrefix[]; static const char kFirmwarePrefix[]; private: FRIEND_TEST_ALL_PREFIXES(VersionLoaderTest, ParseFullVersion); FRIEND_TEST_ALL_PREFIXES(VersionLoaderTest, ParseVersion); FRIEND_TEST_ALL_PREFIXES(VersionLoaderTest, ParseFirmware); // VersionLoader calls into the Backend on the file thread to load // and extract the version. class Backend : public base::RefCountedThreadSafe<Backend> { public: Backend() : parse_as_platform_(false) {} // Calls ParseVersion to get the version # and notifies request. // This is invoked on the file thread. // If |full_version| is true then extra info is passed in version string. void GetVersion(scoped_refptr<GetVersionRequest> request, VersionFormat format); // Calls ParseFirmware to get the firmware # and notifies request. // This is invoked on the file thread. void GetFirmware(scoped_refptr<GetFirmwareRequest> request); void set_parse_as_platform(bool value) { parse_as_platform_ = value; } private: friend class base::RefCountedThreadSafe<Backend>; bool parse_as_platform_; ~Backend() {} DISALLOW_COPY_AND_ASSIGN(Backend); }; // Extracts the version from the file. // |prefix| specifies what key defines version data. static std::string ParseVersion(const std::string& contents, const std::string& prefix); // Extracts the firmware from the file. static std::string ParseFirmware(const std::string& contents); scoped_refptr<Backend> backend_; DISALLOW_COPY_AND_ASSIGN(VersionLoader); }; } // namespace chromeos #endif // CHROME_BROWSER_CHROMEOS_VERSION_LOADER_H_