Skip to content

Commit

Permalink
Bug 1702765 - Plumb ColorScheme through nsXPLookAndFeel. r=mstange
Browse files Browse the repository at this point in the history
After this patch, there are two remaining pieces to fix bug 1700294:

 * macOS nsLookAndFeel needs to return the right colors for light / dark
   appearance.

 * We need to return ColorScheme::Dark for the right documents in
   ColorSchemeForDocument.

Both of those should be straight-forward.

Differential Revision: https://phabricator.services.mozilla.com/D110680
  • Loading branch information
emilio committed Apr 2, 2021
1 parent c55201c commit 300c5cf
Show file tree
Hide file tree
Showing 17 changed files with 55 additions and 35 deletions.
6 changes: 4 additions & 2 deletions widget/LookAndFeelTypes.ipdlh
Original file line number Diff line number Diff line change
Expand Up @@ -34,13 +34,15 @@ namespace widget {
struct LookAndFeelTables {
int32_t[] ints;
float[] floats;
nscolor[] colors;
LookAndFeelFont[] fonts;
nscolor[] lightColors;
nscolor[] darkColors;

uint8_t[] intMap;
uint8_t[] floatMap;
uint8_t[] colorMap;
uint8_t[] fontMap;
uint8_t[] lightColorMap;
uint8_t[] darkColorMap;

uint16_t passwordChar;
bool passwordEcho;
Expand Down
17 changes: 13 additions & 4 deletions widget/RemoteLookAndFeel.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -106,9 +106,14 @@ void AddToMap(nsTArray<Item>& aItems, nsTArray<UInt>& aMap, Id aId,

} // namespace

nsresult RemoteLookAndFeel::NativeGetColor(ColorID aID, nscolor& aResult) {
nsresult RemoteLookAndFeel::NativeGetColor(ColorID aID, ColorScheme aScheme,
nscolor& aResult) {
const nscolor* result;
MOZ_TRY_VAR(result, MapLookup(mTables.colors(), mTables.colorMap(), aID));
const bool dark = aScheme == ColorScheme::Dark;
MOZ_TRY_VAR(
result,
MapLookup(dark ? mTables.darkColors() : mTables.lightColors(),
dark ? mTables.darkColorMap() : mTables.lightColorMap(), aID));
aResult = *result;
return NS_OK;
}
Expand Down Expand Up @@ -149,6 +154,7 @@ static bool AddIDsToMap(nsXPLookAndFeel* aImpl, FullLookAndFeel* aLf,
using FontID = LookAndFeel::FontID;
using FloatID = LookAndFeel::FloatID;
using ColorID = LookAndFeel::ColorID;
using ColorScheme = LookAndFeel::ColorScheme;

bool anyFromOtherTheme = false;
for (auto id : MakeEnumeratedRange(IntID::End)) {
Expand All @@ -168,8 +174,11 @@ static bool AddIDsToMap(nsXPLookAndFeel* aImpl, FullLookAndFeel* aLf,
continue;
}
nscolor theColor;
nsresult rv = aImpl->NativeGetColor(id, theColor);
AddToMap(aLf->tables().colors(), aLf->tables().colorMap(), id,
nsresult rv = aImpl->NativeGetColor(id, ColorScheme::Light, theColor);
AddToMap(aLf->tables().lightColors(), aLf->tables().lightColorMap(), id,
NS_SUCCEEDED(rv) ? Some(theColor) : Nothing{});
rv = aImpl->NativeGetColor(id, ColorScheme::Dark, theColor);
AddToMap(aLf->tables().darkColors(), aLf->tables().darkColorMap(), id,
NS_SUCCEEDED(rv) ? Some(theColor) : Nothing{});
}

Expand Down
6 changes: 3 additions & 3 deletions widget/RemoteLookAndFeel.h
Original file line number Diff line number Diff line change
Expand Up @@ -25,9 +25,9 @@ class RemoteLookAndFeel final : public nsXPLookAndFeel {

void NativeInit() override {}

nsresult NativeGetInt(IntID aID, int32_t& aResult) override;
nsresult NativeGetFloat(FloatID aID, float& aResult) override;
nsresult NativeGetColor(ColorID aID, nscolor& aResult) override;
nsresult NativeGetInt(IntID, int32_t& aResult) override;
nsresult NativeGetFloat(FloatID, float& aResult) override;
nsresult NativeGetColor(ColorID, ColorScheme, nscolor& aResult) override;
bool NativeGetFont(FontID aID, nsString& aFontName,
gfxFontStyle& aFontStyle) override;

Expand Down
3 changes: 2 additions & 1 deletion widget/android/nsLookAndFeel.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,8 @@ void nsLookAndFeel::RefreshImpl() {
mSystemUsesDarkThemeCached = false;
}

nsresult nsLookAndFeel::NativeGetColor(ColorID aID, nscolor& aColor) {
nsresult nsLookAndFeel::NativeGetColor(ColorID aID, ColorScheme,
nscolor& aColor) {
nsresult rv = NS_OK;

EnsureInitSystemColors();
Expand Down
6 changes: 3 additions & 3 deletions widget/android/nsLookAndFeel.h
Original file line number Diff line number Diff line change
Expand Up @@ -15,9 +15,9 @@ class nsLookAndFeel final : public nsXPLookAndFeel {

void NativeInit() final;
virtual void RefreshImpl() override;
nsresult NativeGetInt(IntID aID, int32_t& aResult) override;
nsresult NativeGetFloat(FloatID aID, float& aResult) override;
nsresult NativeGetColor(ColorID aID, nscolor& aResult) override;
nsresult NativeGetInt(IntID, int32_t& aResult) override;
nsresult NativeGetFloat(FloatID, float& aResult) override;
nsresult NativeGetColor(ColorID, ColorScheme, nscolor& aResult) override;
bool NativeGetFont(FontID aID, nsString& aName,
gfxFontStyle& aStyle) override;
virtual bool GetEchoPasswordImpl() override;
Expand Down
6 changes: 3 additions & 3 deletions widget/cocoa/nsLookAndFeel.h
Original file line number Diff line number Diff line change
Expand Up @@ -14,9 +14,9 @@ class nsLookAndFeel final : public nsXPLookAndFeel {

void NativeInit() final;
virtual void RefreshImpl() override;
nsresult NativeGetColor(ColorID aID, nscolor& aResult) override;
nsresult NativeGetInt(IntID aID, int32_t& aResult) override;
nsresult NativeGetFloat(FloatID aID, float& aResult) override;
nsresult NativeGetColor(ColorID, ColorScheme, nscolor& aResult) override;
nsresult NativeGetInt(IntID, int32_t& aResult) override;
nsresult NativeGetFloat(FloatID, float& aResult) override;
bool NativeGetFont(FontID aID, nsString& aFontName,
gfxFontStyle& aFontStyle) override;

Expand Down
2 changes: 1 addition & 1 deletion widget/cocoa/nsLookAndFeel.mm
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@ static nscolor GetColorFromNSColorWithAlpha(NSColor* aColor, float alpha) {
return resultColor;
}

nsresult nsLookAndFeel::NativeGetColor(ColorID aID, nscolor& aColor) {
nsresult nsLookAndFeel::NativeGetColor(ColorID aID, ColorScheme, nscolor& aColor) {
EnsureInit();

nsresult res = NS_OK;
Expand Down
3 changes: 2 additions & 1 deletion widget/gtk/nsLookAndFeel.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -300,7 +300,8 @@ static bool IsSelectionColorBackground(LookAndFeel::ColorID aID) {
}
}

nsresult nsLookAndFeel::NativeGetColor(ColorID aID, nscolor& aColor) {
nsresult nsLookAndFeel::NativeGetColor(ColorID aID, ColorScheme,
nscolor& aColor) {
EnsureInit();

nsresult res = NS_OK;
Expand Down
2 changes: 1 addition & 1 deletion widget/gtk/nsLookAndFeel.h
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ class nsLookAndFeel final : public nsXPLookAndFeel {
void RefreshImpl() override;
nsresult NativeGetInt(IntID aID, int32_t& aResult) override;
nsresult NativeGetFloat(FloatID aID, float& aResult) override;
nsresult NativeGetColor(ColorID aID, nscolor& aResult) override;
nsresult NativeGetColor(ColorID, ColorScheme, nscolor& aResult) override;
bool NativeGetFont(FontID aID, nsString& aFontName,
gfxFontStyle& aFontStyle) override;

Expand Down
3 changes: 2 additions & 1 deletion widget/headless/HeadlessLookAndFeel.h
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,8 @@ class HeadlessLookAndFeel : public nsXPLookAndFeel {
void NativeInit() final{};
virtual nsresult NativeGetInt(IntID aID, int32_t& aResult) override;
virtual nsresult NativeGetFloat(FloatID aID, float& aResult) override;
virtual nsresult NativeGetColor(ColorID aID, nscolor& aResult) override;
virtual nsresult NativeGetColor(ColorID, ColorScheme,
nscolor& aResult) override;
virtual bool NativeGetFont(FontID aID, nsString& aFontName,
gfxFontStyle& aFontStyle) override;

Expand Down
3 changes: 2 additions & 1 deletion widget/headless/HeadlessLookAndFeelGTK.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,8 @@ HeadlessLookAndFeel::HeadlessLookAndFeel() {}

HeadlessLookAndFeel::~HeadlessLookAndFeel() = default;

nsresult HeadlessLookAndFeel::NativeGetColor(ColorID aID, nscolor& aColor) {
nsresult HeadlessLookAndFeel::NativeGetColor(ColorID aID, ColorScheme,
nscolor& aColor) {
// For headless mode, we use GetStandinForNativeColor for everything we can,
// and hardcoded values for everything else.

Expand Down
18 changes: 11 additions & 7 deletions widget/nsXPLookAndFeel.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,8 @@ class EnumeratedCache {
}
};

static EnumeratedCache<ColorID, Maybe<nscolor>, ColorID::End> sColorCache;
static EnumeratedCache<ColorID, Maybe<nscolor>, ColorID::End> sLightColorCache;
static EnumeratedCache<ColorID, Maybe<nscolor>, ColorID::End> sDarkColorCache;
static EnumeratedCache<FloatID, Maybe<float>, FloatID::End> sFloatCache;
static EnumeratedCache<IntID, Maybe<int32_t>, IntID::End> sIntCache;
static EnumeratedCache<FontID, widget::LookAndFeelFont, FontID::End> sFontCache;
Expand Down Expand Up @@ -680,7 +681,9 @@ nsresult nsXPLookAndFeel::GetColorValue(ColorID aID, ColorScheme aScheme,
return NS_OK;
}

if (const auto* cached = sColorCache.Get(aID)) {
auto& cache =
aScheme == ColorScheme::Light ? sLightColorCache : sDarkColorCache;
if (const auto* cached = cache.Get(aID)) {
if (cached->isNothing()) {
return NS_ERROR_FAILURE;
}
Expand All @@ -689,11 +692,11 @@ nsresult nsXPLookAndFeel::GetColorValue(ColorID aID, ColorScheme aScheme,
}

if (NS_SUCCEEDED(GetColorFromPref(aID, aResult))) {
sColorCache.Insert(aID, Some(aResult));
cache.Insert(aID, Some(aResult));
return NS_OK;
}

if (NS_SUCCEEDED(NativeGetColor(aID, aResult))) {
if (NS_SUCCEEDED(NativeGetColor(aID, aScheme, aResult))) {
if (gfxPlatform::GetCMSMode() == CMSMode::All &&
!IsSpecialColor(aID, aResult)) {
qcms_transform* transform = gfxPlatform::GetCMSInverseRGBTransform();
Expand All @@ -710,11 +713,11 @@ nsresult nsXPLookAndFeel::GetColorValue(ColorID aID, ColorScheme aScheme,

// NOTE: Servo holds a lock and the main thread is paused, so writing to the
// global cache here is fine.
sColorCache.Insert(aID, Some(aResult));
cache.Insert(aID, Some(aResult));
return NS_OK;
}

sColorCache.Insert(aID, Nothing());
cache.Insert(aID, Nothing());
return NS_ERROR_FAILURE;
}

Expand Down Expand Up @@ -832,7 +835,8 @@ bool nsXPLookAndFeel::GetFontValue(FontID aID, nsString& aName,

void nsXPLookAndFeel::RefreshImpl() {
// Wipe out our caches.
sColorCache.Clear();
sLightColorCache.Clear();
sDarkColorCache.Clear();
sFontCache.Clear();
sFloatCache.Clear();
sIntCache.Clear();
Expand Down
2 changes: 1 addition & 1 deletion widget/nsXPLookAndFeel.h
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ class nsXPLookAndFeel : public mozilla::LookAndFeel {

virtual nsresult NativeGetInt(IntID aID, int32_t& aResult) = 0;
virtual nsresult NativeGetFloat(FloatID aID, float& aResult) = 0;
virtual nsresult NativeGetColor(ColorID aID, nscolor& aResult) = 0;
virtual nsresult NativeGetColor(ColorID, ColorScheme, nscolor& aResult) = 0;
virtual bool NativeGetFont(FontID aID, nsString& aName,
gfxFontStyle& aStyle) = 0;

Expand Down
2 changes: 1 addition & 1 deletion widget/uikit/nsLookAndFeel.h
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ class nsLookAndFeel final : public nsXPLookAndFeel {
virtual void RefreshImpl();
nsresult NativeGetImpl(IntID aID, int32_t& aResult) override;
nsresult NativeGetFloat(FloatID aID, float& aResult) override;
nsresult NativeGetColor(const ColorID aID, nscolor& aResult) override;
nsresult NativeGetColor(ColorID, ColorScheme, nscolor& aResult) override;
bool NativeGetFont(FontID aID, nsString& aFontName,
gfxFontStyle& aFontStyle) override;
virtual char16_t GetPasswordCharacterImpl() {
Expand Down
2 changes: 1 addition & 1 deletion widget/uikit/nsLookAndFeel.mm
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ static nscolor GetColorFromUIColor(UIColor* aColor) {
mInitialized = false;
}

nsresult nsLookAndFeel::NativeGetColor(const ColorID aID, nscolor& aResult) {
nsresult nsLookAndFeel::NativeGetColor(ColorID, ColorScheme, nscolor& aResult) {
EnsureInit();

nsresult res = NS_OK;
Expand Down
3 changes: 2 additions & 1 deletion widget/windows/nsLookAndFeel.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -124,7 +124,8 @@ void nsLookAndFeel::RefreshImpl() {
mInitialized = false;
}

nsresult nsLookAndFeel::NativeGetColor(ColorID aID, nscolor& aColor) {
nsresult nsLookAndFeel::NativeGetColor(ColorID aID, ColorScheme,
nscolor& aColor) {
EnsureInit();

nsresult res = NS_OK;
Expand Down
6 changes: 3 additions & 3 deletions widget/windows/nsLookAndFeel.h
Original file line number Diff line number Diff line change
Expand Up @@ -52,9 +52,9 @@ class nsLookAndFeel final : public nsXPLookAndFeel {

void NativeInit() final;
void RefreshImpl() override;
nsresult NativeGetInt(IntID aID, int32_t& aResult) override;
nsresult NativeGetFloat(FloatID aID, float& aResult) override;
nsresult NativeGetColor(ColorID aID, nscolor& aResult) override;
nsresult NativeGetInt(IntID, int32_t& aResult) override;
nsresult NativeGetFloat(FloatID, float& aResult) override;
nsresult NativeGetColor(ColorID, ColorScheme, nscolor& aResult) override;
bool NativeGetFont(FontID aID, nsString& aFontName,
gfxFontStyle& aFontStyle) override;
char16_t GetPasswordCharacterImpl() override;
Expand Down

0 comments on commit 300c5cf

Please sign in to comment.