diff options
author | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
---|---|---|
committer | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
commit | ad18d877ddd2a44d98fa12ccd3dbbcf4d0ac4299 (patch) | |
tree | 10027f336435511475e392454359edea8e25895d /widget/nsBaseScreen.cpp | |
parent | 15477ed9af4859dacb069040b5d4de600803d3bc (diff) | |
download | aura-central-ad18d877ddd2a44d98fa12ccd3dbbcf4d0ac4299.tar.gz |
Add m-esr52 at 52.6.0
Diffstat (limited to 'widget/nsBaseScreen.cpp')
-rw-r--r-- | widget/nsBaseScreen.cpp | 90 |
1 files changed, 90 insertions, 0 deletions
diff --git a/widget/nsBaseScreen.cpp b/widget/nsBaseScreen.cpp new file mode 100644 index 000000000..da523853a --- /dev/null +++ b/widget/nsBaseScreen.cpp @@ -0,0 +1,90 @@ +/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- + * vim: sw=2 ts=8 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/. */ + +#define MOZ_FATAL_ASSERTIONS_FOR_THREAD_SAFETY + +#include "nsBaseScreen.h" + +NS_IMPL_ISUPPORTS(nsBaseScreen, nsIScreen) + +nsBaseScreen::nsBaseScreen() +{ + for (uint32_t i = 0; i < nsIScreen::BRIGHTNESS_LEVELS; i++) + mBrightnessLocks[i] = 0; +} + +nsBaseScreen::~nsBaseScreen() { } + +NS_IMETHODIMP +nsBaseScreen::GetRectDisplayPix(int32_t *outLeft, int32_t *outTop, + int32_t *outWidth, int32_t *outHeight) +{ + return GetRect(outLeft, outTop, outWidth, outHeight); +} + +NS_IMETHODIMP +nsBaseScreen::GetAvailRectDisplayPix(int32_t *outLeft, int32_t *outTop, + int32_t *outWidth, int32_t *outHeight) +{ + return GetAvailRect(outLeft, outTop, outWidth, outHeight); +} + +NS_IMETHODIMP +nsBaseScreen::LockMinimumBrightness(uint32_t aBrightness) +{ + MOZ_ASSERT(aBrightness < nsIScreen::BRIGHTNESS_LEVELS, + "Invalid brightness level to lock"); + mBrightnessLocks[aBrightness]++; + MOZ_ASSERT(mBrightnessLocks[aBrightness] > 0, + "Overflow after locking brightness level"); + + CheckMinimumBrightness(); + + return NS_OK; +} + +NS_IMETHODIMP +nsBaseScreen::UnlockMinimumBrightness(uint32_t aBrightness) +{ + MOZ_ASSERT(aBrightness < nsIScreen::BRIGHTNESS_LEVELS, + "Invalid brightness level to lock"); + MOZ_ASSERT(mBrightnessLocks[aBrightness] > 0, + "Unlocking a brightness level with no corresponding lock"); + mBrightnessLocks[aBrightness]--; + + CheckMinimumBrightness(); + + return NS_OK; +} + +void +nsBaseScreen::CheckMinimumBrightness() +{ + uint32_t brightness = nsIScreen::BRIGHTNESS_LEVELS; + for (int32_t i = nsIScreen::BRIGHTNESS_LEVELS - 1; i >=0; i--) { + if (mBrightnessLocks[i] > 0) { + brightness = i; + break; + } + } + + ApplyMinimumBrightness(brightness); +} + +NS_IMETHODIMP +nsBaseScreen::GetContentsScaleFactor(double* aContentsScaleFactor) +{ + *aContentsScaleFactor = 1.0; + return NS_OK; +} + +NS_IMETHODIMP +nsBaseScreen::GetDefaultCSSScaleFactor(double* aScaleFactor) +{ + *aScaleFactor = 1.0; + return NS_OK; +} |