1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
/* 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_widget_HeadlessLookAndFeel_h
#define mozilla_widget_HeadlessLookAndFeel_h
#include "nsXPLookAndFeel.h"
#include "nsLookAndFeel.h"
namespace mozilla {
namespace widget {
#if defined(MOZ_WIDGET_GTK)
// Our nsLookAndFeel for Gtk relies on APIs that aren't available in headless
// mode, so for processes that are unable to connect to a display server, we use
// an implementation with hardcoded values.
//
// HeadlessLookAndFeel is used:
//
// * in the parent process, when full headless mode (MOZ_HEADLESS=1) is
// enabled
//
// The result of this is that when headless content mode is enabled, content
// processes use values derived from the parent's nsLookAndFeel (i.e., values
// derived from Gtk APIs) while still refraining from making any display server
// connections.
class HeadlessLookAndFeel : public nsXPLookAndFeel {
public:
explicit HeadlessLookAndFeel();
virtual ~HeadlessLookAndFeel();
void NativeInit() final{};
nsresult NativeGetInt(IntID, int32_t& aResult) override;
nsresult NativeGetFloat(FloatID, float& aResult) override;
nsresult NativeGetColor(ColorID, ColorScheme, nscolor& aResult) override;
bool NativeGetFont(FontID, nsString& aFontName, gfxFontStyle&) override;
char16_t GetPasswordCharacterImpl() override;
};
#else
// When possible, we simply reuse the platform's existing nsLookAndFeel
// implementation in headless mode.
typedef nsLookAndFeel HeadlessLookAndFeel;
#endif
} // namespace widget
} // namespace mozilla
#endif
|