137 lines
4.9 KiB
C++
137 lines
4.9 KiB
C++
/* -*- Mode: C++; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
/* vim: set sts=2 ts=8 sw=2 tw=99 et: */
|
|
/* 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/. */
|
|
#ifndef mozilla_gfx_config_gfxFeature_h
|
|
#define mozilla_gfx_config_gfxFeature_h
|
|
|
|
#include <stdint.h>
|
|
#include "gfxTelemetry.h"
|
|
#include "mozilla/Assertions.h"
|
|
#include "mozilla/Function.h"
|
|
#include "nsString.h"
|
|
|
|
namespace mozilla {
|
|
namespace gfx {
|
|
|
|
#define GFX_FEATURE_MAP(_) \
|
|
/* Name, Type, Description */ \
|
|
_(HW_COMPOSITING, Feature, "Compositing") \
|
|
_(D3D11_COMPOSITING, Feature, "Direct3D11 Compositing") \
|
|
_(D3D9_COMPOSITING, Feature, "Direct3D9 Compositing") \
|
|
_(OPENGL_COMPOSITING, Feature, "OpenGL Compositing") \
|
|
_(DIRECT2D, Feature, "Direct2D") \
|
|
_(D3D11_HW_ANGLE, Feature, "Direct3D11 hardware ANGLE") \
|
|
_(DIRECT_DRAW, Feature, "DirectDraw") \
|
|
_(GPU_PROCESS, Feature, "GPU Process") \
|
|
/* Add new entries above this comment */
|
|
|
|
enum class Feature : uint32_t {
|
|
#define MAKE_ENUM(name, type, desc) name,
|
|
GFX_FEATURE_MAP(MAKE_ENUM)
|
|
#undef MAKE_ENUM
|
|
NumValues
|
|
};
|
|
|
|
class FeatureState
|
|
{
|
|
friend class gfxConfig;
|
|
|
|
public:
|
|
bool IsEnabled() const;
|
|
FeatureStatus GetValue() const;
|
|
|
|
void EnableByDefault();
|
|
void DisableByDefault(FeatureStatus aStatus, const char* aMessage, const nsACString& aFailureId);
|
|
bool SetDefault(bool aEnable, FeatureStatus aDisableStatus, const char* aDisableMessage);
|
|
bool InitOrUpdate(bool aEnable,
|
|
FeatureStatus aDisableStatus,
|
|
const char* aMessage);
|
|
void SetDefaultFromPref(const char* aPrefName,
|
|
bool aIsEnablePref,
|
|
bool aDefaultValue);
|
|
void UserEnable(const char* aMessage);
|
|
void UserForceEnable(const char* aMessage);
|
|
void UserDisable(const char* aMessage, const nsACString& aFailureId);
|
|
void Disable(FeatureStatus aStatus, const char* aMessage, const nsACString& aFailureId);
|
|
void ForceDisable(FeatureStatus aStatus, const char* aMessage, const nsACString& aFailureId) {
|
|
SetFailed(aStatus, aMessage, aFailureId);
|
|
}
|
|
void SetFailed(FeatureStatus aStatus, const char* aMessage, const nsACString& aFailureId);
|
|
bool MaybeSetFailed(bool aEnable, FeatureStatus aStatus, const char* aMessage, const nsACString& aFailureId);
|
|
bool MaybeSetFailed(FeatureStatus aStatus, const char* aMessage, const nsACString& aFailureId);
|
|
|
|
// aType is "base", "user", "env", or "runtime".
|
|
// aMessage may be null.
|
|
typedef mozilla::function<void(const char* aType,
|
|
FeatureStatus aStatus,
|
|
const char* aMessage)> StatusIterCallback;
|
|
void ForEachStatusChange(const StatusIterCallback& aCallback) const;
|
|
|
|
const char* GetFailureMessage() const;
|
|
const nsCString& GetFailureId() const;
|
|
|
|
bool DisabledByDefault() const;
|
|
|
|
private:
|
|
void SetUser(FeatureStatus aStatus, const char* aMessage);
|
|
void SetEnvironment(FeatureStatus aStatus, const char* aMessage);
|
|
void SetRuntime(FeatureStatus aStatus, const char* aMessage);
|
|
bool IsForcedOnByUser() const;
|
|
const char* GetRuntimeMessage() const;
|
|
bool IsInitialized() const {
|
|
return mDefault.IsInitialized();
|
|
}
|
|
|
|
void AssertInitialized() const {
|
|
MOZ_ASSERT(IsInitialized());
|
|
}
|
|
|
|
// Clear all state.
|
|
void Reset();
|
|
|
|
private:
|
|
void SetFailureId(const nsACString& aFailureId);
|
|
|
|
struct Instance {
|
|
char mMessage[64];
|
|
FeatureStatus mStatus;
|
|
|
|
void Set(FeatureStatus aStatus, const char* aMessage = nullptr);
|
|
bool IsInitialized() const {
|
|
return mStatus != FeatureStatus::Unused;
|
|
}
|
|
const char* MessageOrNull() const {
|
|
return mMessage[0] != '\0' ? mMessage : nullptr;
|
|
}
|
|
const char* Message() const {
|
|
MOZ_ASSERT(MessageOrNull());
|
|
return mMessage;
|
|
}
|
|
};
|
|
|
|
// The default state is the state we decide on startup, based on the operating
|
|
// system or a base preference.
|
|
//
|
|
// The user state factors in any changes to preferences that the user made.
|
|
//
|
|
// The environment state factors in any additional decisions made, such as
|
|
// availability or blacklisting.
|
|
//
|
|
// The runtime state factors in any problems discovered at runtime.
|
|
Instance mDefault;
|
|
Instance mUser;
|
|
Instance mEnvironment;
|
|
Instance mRuntime;
|
|
|
|
// Store the first reported failureId for now but we might want to track this
|
|
// by instance later if we need a specific breakdown.
|
|
nsCString mFailureId;
|
|
};
|
|
|
|
} // namespace gfx
|
|
} // namespace mozilla
|
|
|
|
#endif // mozilla_gfx_config_gfxFeature_h
|