Bug 1683226 - part 14: Get rid of ComplexTextInputPanel r=m_kato
It's used only for a placeholder of composition string in plugins. Depends on D100387 Differential Revision: https://phabricator.services.mozilla.com/D100388
This commit is contained in:
@@ -72,10 +72,6 @@ static NS_DEFINE_CID(kAppShellCID, NS_APPSHELL_CID);
|
|||||||
# include "mozilla/widget/WinMessages.h"
|
# include "mozilla/widget/WinMessages.h"
|
||||||
#endif // #ifdef XP_WIN
|
#endif // #ifdef XP_WIN
|
||||||
|
|
||||||
#ifdef XP_MACOSX
|
|
||||||
# include "ComplexTextInputPanel.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef MOZ_WIDGET_GTK
|
#ifdef MOZ_WIDGET_GTK
|
||||||
# include <gdk/gdk.h>
|
# include <gdk/gdk.h>
|
||||||
# include <gtk/gtk.h>
|
# include <gtk/gtk.h>
|
||||||
|
|||||||
@@ -3318,8 +3318,6 @@ pref("font.size.monospace.x-math", 13);
|
|||||||
// See bug 404131, topmost <panel> element wins to Dashboard on MacOSX.
|
// See bug 404131, topmost <panel> element wins to Dashboard on MacOSX.
|
||||||
pref("ui.panel.default_level_parent", false);
|
pref("ui.panel.default_level_parent", false);
|
||||||
|
|
||||||
pref("ui.plugin.cancel_composition_at_input_source_changed", false);
|
|
||||||
|
|
||||||
// Macbook touchpad two finger pixel scrolling
|
// Macbook touchpad two finger pixel scrolling
|
||||||
pref("mousewheel.enable_pixel_scrolling", true);
|
pref("mousewheel.enable_pixel_scrolling", true);
|
||||||
|
|
||||||
|
|||||||
@@ -1,49 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2009 Apple Inc. All Rights Reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions
|
|
||||||
* are met:
|
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer.
|
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
|
|
||||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
|
||||||
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
|
|
||||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
|
||||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
||||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
|
||||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
|
||||||
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*
|
|
||||||
* Modified by Josh Aas of Mozilla Corporation.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef ComplexTextInputPanel_h_
|
|
||||||
#define ComplexTextInputPanel_h_
|
|
||||||
|
|
||||||
#include "nsString.h"
|
|
||||||
#include "npapi.h"
|
|
||||||
|
|
||||||
class ComplexTextInputPanel {
|
|
||||||
public:
|
|
||||||
static ComplexTextInputPanel* GetSharedComplexTextInputPanel();
|
|
||||||
virtual void PlacePanel(
|
|
||||||
int32_t x,
|
|
||||||
int32_t y) = 0; // Bottom left coordinate of plugin in screen coords
|
|
||||||
virtual void InterpretKeyEvent(void* aEvent, nsAString& aOutText) = 0;
|
|
||||||
virtual bool IsInComposition() = 0;
|
|
||||||
virtual void* GetInputContext() = 0;
|
|
||||||
virtual void CancelComposition() = 0;
|
|
||||||
|
|
||||||
protected:
|
|
||||||
virtual ~ComplexTextInputPanel(){};
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif // ComplexTextInputPanel_h_
|
|
||||||
@@ -1,238 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2009 Apple Inc. All Rights Reserved.
|
|
||||||
*
|
|
||||||
* Redistribution and use in source and binary forms, with or without
|
|
||||||
* modification, are permitted provided that the following conditions
|
|
||||||
* are met:
|
|
||||||
* 1. Redistributions of source code must retain the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer.
|
|
||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
|
||||||
* documentation and/or other materials provided with the distribution.
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
|
|
||||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
|
||||||
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
|
|
||||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
|
||||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
||||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
|
||||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
|
|
||||||
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*
|
|
||||||
* Modified by Josh Aas of Mozilla Corporation.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#import "ComplexTextInputPanel.h"
|
|
||||||
|
|
||||||
#import <Cocoa/Cocoa.h>
|
|
||||||
|
|
||||||
#include <algorithm>
|
|
||||||
#include "mozilla/Preferences.h"
|
|
||||||
#include "nsChildView.h"
|
|
||||||
|
|
||||||
using namespace mozilla;
|
|
||||||
|
|
||||||
extern "C" OSStatus TSMProcessRawKeyEvent(EventRef anEvent);
|
|
||||||
|
|
||||||
#define kInputWindowHeight 20
|
|
||||||
|
|
||||||
@interface ComplexTextInputPanelImpl : NSPanel {
|
|
||||||
NSTextView* mInputTextView;
|
|
||||||
}
|
|
||||||
|
|
||||||
+ (ComplexTextInputPanelImpl*)sharedComplexTextInputPanelImpl;
|
|
||||||
|
|
||||||
- (NSTextInputContext*)inputContext;
|
|
||||||
- (void)interpretKeyEvent:(NSEvent*)event string:(NSString**)string;
|
|
||||||
- (void)cancelComposition;
|
|
||||||
- (BOOL)inComposition;
|
|
||||||
|
|
||||||
// This places the text input panel fully onscreen and below the lower left
|
|
||||||
// corner of the focused plugin.
|
|
||||||
- (void)adjustTo:(NSPoint)point;
|
|
||||||
|
|
||||||
@end
|
|
||||||
|
|
||||||
@implementation ComplexTextInputPanelImpl
|
|
||||||
|
|
||||||
+ (ComplexTextInputPanelImpl*)sharedComplexTextInputPanelImpl {
|
|
||||||
static ComplexTextInputPanelImpl* sComplexTextInputPanelImpl;
|
|
||||||
if (!sComplexTextInputPanelImpl)
|
|
||||||
sComplexTextInputPanelImpl = [[ComplexTextInputPanelImpl alloc] init];
|
|
||||||
return sComplexTextInputPanelImpl;
|
|
||||||
}
|
|
||||||
|
|
||||||
- (id)init {
|
|
||||||
// In the original Apple code the style mask is given by a function which is not open source.
|
|
||||||
// What could possibly be worth hiding in that function, I do not know.
|
|
||||||
// Courtesy of gdb: stylemask: 011000011111, 0x61f
|
|
||||||
self = [super initWithContentRect:NSZeroRect
|
|
||||||
styleMask:0x61f
|
|
||||||
backing:NSBackingStoreBuffered
|
|
||||||
defer:YES];
|
|
||||||
if (!self) return nil;
|
|
||||||
|
|
||||||
// Set the frame size.
|
|
||||||
NSRect visibleFrame = [[NSScreen mainScreen] visibleFrame];
|
|
||||||
NSRect frame = NSMakeRect(visibleFrame.origin.x, visibleFrame.origin.y, visibleFrame.size.width,
|
|
||||||
kInputWindowHeight);
|
|
||||||
|
|
||||||
[self setFrame:frame display:NO];
|
|
||||||
|
|
||||||
mInputTextView = [[NSTextView alloc] initWithFrame:[self.contentView frame]];
|
|
||||||
mInputTextView.autoresizingMask = NSViewWidthSizable | NSViewHeightSizable | NSViewMaxXMargin |
|
|
||||||
NSViewMinXMargin | NSViewMaxYMargin | NSViewMinYMargin;
|
|
||||||
|
|
||||||
NSScrollView* scrollView = [[NSScrollView alloc] initWithFrame:[self.contentView frame]];
|
|
||||||
scrollView.documentView = mInputTextView;
|
|
||||||
self.contentView = scrollView;
|
|
||||||
[scrollView release];
|
|
||||||
|
|
||||||
[self setFloatingPanel:YES];
|
|
||||||
|
|
||||||
[[NSNotificationCenter defaultCenter]
|
|
||||||
addObserver:self
|
|
||||||
selector:@selector(keyboardInputSourceChanged:)
|
|
||||||
name:NSTextInputContextKeyboardSelectionDidChangeNotification
|
|
||||||
object:nil];
|
|
||||||
|
|
||||||
return self;
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)dealloc {
|
|
||||||
[[NSNotificationCenter defaultCenter] removeObserver:self];
|
|
||||||
|
|
||||||
[mInputTextView release];
|
|
||||||
|
|
||||||
[super dealloc];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)keyboardInputSourceChanged:(NSNotification*)notification {
|
|
||||||
static int8_t sDoCancel = -1;
|
|
||||||
if (!sDoCancel || ![self inComposition]) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (sDoCancel < 0) {
|
|
||||||
bool cancelComposition = false;
|
|
||||||
static const char* kPrefName = "ui.plugin.cancel_composition_at_input_source_changed";
|
|
||||||
nsresult rv = Preferences::GetBool(kPrefName, &cancelComposition);
|
|
||||||
NS_ENSURE_SUCCESS(rv, );
|
|
||||||
sDoCancel = cancelComposition ? 1 : 0;
|
|
||||||
}
|
|
||||||
if (sDoCancel) {
|
|
||||||
[self cancelComposition];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)interpretKeyEvent:(NSEvent*)event string:(NSString**)string {
|
|
||||||
*string = nil;
|
|
||||||
|
|
||||||
if (![[mInputTextView inputContext] handleEvent:event]) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ([mInputTextView hasMarkedText]) {
|
|
||||||
// Don't show the input method window for dead keys
|
|
||||||
if ([[event characters] length] > 0) {
|
|
||||||
[self orderFront:nil];
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
} else {
|
|
||||||
[self orderOut:nil];
|
|
||||||
|
|
||||||
NSString* text = [[mInputTextView textStorage] string];
|
|
||||||
if ([text length] > 0) {
|
|
||||||
*string = [[text copy] autorelease];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
[mInputTextView setString:@""];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (NSTextInputContext*)inputContext {
|
|
||||||
return [mInputTextView inputContext];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)cancelComposition {
|
|
||||||
[mInputTextView setString:@""];
|
|
||||||
[self orderOut:nil];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (BOOL)inComposition {
|
|
||||||
return [mInputTextView hasMarkedText];
|
|
||||||
}
|
|
||||||
|
|
||||||
- (void)adjustTo:(NSPoint)point {
|
|
||||||
NSRect selfRect = [self frame];
|
|
||||||
NSRect rect = NSMakeRect(point.x, point.y - selfRect.size.height, 500, selfRect.size.height);
|
|
||||||
|
|
||||||
// Adjust to screen.
|
|
||||||
NSRect screenRect = [[NSScreen mainScreen] visibleFrame];
|
|
||||||
if (rect.origin.x < screenRect.origin.x) {
|
|
||||||
rect.origin.x = screenRect.origin.x;
|
|
||||||
}
|
|
||||||
if (rect.origin.y < screenRect.origin.y) {
|
|
||||||
rect.origin.y = screenRect.origin.y;
|
|
||||||
}
|
|
||||||
CGFloat xMostOfScreen = screenRect.origin.x + screenRect.size.width;
|
|
||||||
CGFloat yMostOfScreen = screenRect.origin.y + screenRect.size.height;
|
|
||||||
CGFloat xMost = rect.origin.x + rect.size.width;
|
|
||||||
CGFloat yMost = rect.origin.y + rect.size.height;
|
|
||||||
if (xMostOfScreen < xMost) {
|
|
||||||
rect.origin.x -= xMost - xMostOfScreen;
|
|
||||||
}
|
|
||||||
if (yMostOfScreen < yMost) {
|
|
||||||
rect.origin.y -= yMost - yMostOfScreen;
|
|
||||||
}
|
|
||||||
|
|
||||||
[self setFrame:rect display:[self isVisible]];
|
|
||||||
}
|
|
||||||
|
|
||||||
@end
|
|
||||||
|
|
||||||
class ComplexTextInputPanelPrivate : public ComplexTextInputPanel {
|
|
||||||
public:
|
|
||||||
ComplexTextInputPanelPrivate();
|
|
||||||
|
|
||||||
virtual void InterpretKeyEvent(void* aEvent, nsAString& aOutText);
|
|
||||||
virtual bool IsInComposition();
|
|
||||||
virtual void PlacePanel(int32_t x, int32_t y);
|
|
||||||
virtual void* GetInputContext() { return [mPanel inputContext]; }
|
|
||||||
virtual void CancelComposition() { [mPanel cancelComposition]; }
|
|
||||||
|
|
||||||
private:
|
|
||||||
~ComplexTextInputPanelPrivate();
|
|
||||||
ComplexTextInputPanelImpl* mPanel;
|
|
||||||
};
|
|
||||||
|
|
||||||
ComplexTextInputPanelPrivate::ComplexTextInputPanelPrivate() {
|
|
||||||
mPanel = [[ComplexTextInputPanelImpl alloc] init];
|
|
||||||
}
|
|
||||||
|
|
||||||
ComplexTextInputPanelPrivate::~ComplexTextInputPanelPrivate() { [mPanel release]; }
|
|
||||||
|
|
||||||
ComplexTextInputPanel* ComplexTextInputPanel::GetSharedComplexTextInputPanel() {
|
|
||||||
static ComplexTextInputPanelPrivate* sComplexTextInputPanelPrivate;
|
|
||||||
if (!sComplexTextInputPanelPrivate) {
|
|
||||||
sComplexTextInputPanelPrivate = new ComplexTextInputPanelPrivate();
|
|
||||||
}
|
|
||||||
return sComplexTextInputPanelPrivate;
|
|
||||||
}
|
|
||||||
|
|
||||||
void ComplexTextInputPanelPrivate::InterpretKeyEvent(void* aEvent, nsAString& aOutText) {
|
|
||||||
NSString* textString = nil;
|
|
||||||
[mPanel interpretKeyEvent:(NSEvent*)aEvent string:&textString];
|
|
||||||
|
|
||||||
if (textString) {
|
|
||||||
nsCocoaUtils::GetStringForNSString(textString, aOutText);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
bool ComplexTextInputPanelPrivate::IsInComposition() { return !![mPanel inComposition]; }
|
|
||||||
|
|
||||||
void ComplexTextInputPanelPrivate::PlacePanel(int32_t x, int32_t y) {
|
|
||||||
[mPanel adjustTo:NSMakePoint(x, y)];
|
|
||||||
}
|
|
||||||
@@ -20,6 +20,8 @@
|
|||||||
#import <IOKit/IOKitLib.h>
|
#import <IOKit/IOKitLib.h>
|
||||||
#import <Cocoa/Cocoa.h>
|
#import <Cocoa/Cocoa.h>
|
||||||
|
|
||||||
|
#include "jsapi.h"
|
||||||
|
|
||||||
#define NS_CRASHREPORTER_CONTRACTID "@mozilla.org/toolkit/crash-reporter;1"
|
#define NS_CRASHREPORTER_CONTRACTID "@mozilla.org/toolkit/crash-reporter;1"
|
||||||
|
|
||||||
using namespace mozilla;
|
using namespace mozilla;
|
||||||
|
|||||||
@@ -25,7 +25,6 @@
|
|||||||
#include "nsCocoaUtils.h"
|
#include "nsCocoaUtils.h"
|
||||||
#include "WidgetUtils.h"
|
#include "WidgetUtils.h"
|
||||||
#include "nsPrintfCString.h"
|
#include "nsPrintfCString.h"
|
||||||
#include "ComplexTextInputPanel.h"
|
|
||||||
|
|
||||||
using namespace mozilla;
|
using namespace mozilla;
|
||||||
using namespace mozilla::widget;
|
using namespace mozilla::widget;
|
||||||
@@ -1751,30 +1750,6 @@ bool TextInputHandler::HandleKeyDownEvent(NSEvent* aNativeEvent, uint32_t aUniqu
|
|||||||
KeyEventState* currentKeyEvent = PushKeyEvent(aNativeEvent, aUniqueId);
|
KeyEventState* currentKeyEvent = PushKeyEvent(aNativeEvent, aUniqueId);
|
||||||
AutoKeyEventStateCleaner remover(this);
|
AutoKeyEventStateCleaner remover(this);
|
||||||
|
|
||||||
ComplexTextInputPanel* ctiPanel = ComplexTextInputPanel::GetSharedComplexTextInputPanel();
|
|
||||||
if (ctiPanel && ctiPanel->IsInComposition()) {
|
|
||||||
nsAutoString committed;
|
|
||||||
ctiPanel->InterpretKeyEvent(aNativeEvent, committed);
|
|
||||||
if (!committed.IsEmpty()) {
|
|
||||||
nsresult rv = mDispatcher->BeginNativeInputTransaction();
|
|
||||||
if (NS_WARN_IF(NS_FAILED(rv))) {
|
|
||||||
MOZ_LOG(gLog, LogLevel::Error,
|
|
||||||
("%p IMEInputHandler::HandleKeyDownEvent, "
|
|
||||||
"FAILED, due to BeginNativeInputTransaction() failure "
|
|
||||||
"at dispatching keydown for ComplexTextInputPanel",
|
|
||||||
this));
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
WidgetKeyboardEvent imeEvent(true, eKeyDown, widget);
|
|
||||||
currentKeyEvent->InitKeyEvent(this, imeEvent, false);
|
|
||||||
imeEvent.mPluginTextEventString.Assign(committed);
|
|
||||||
nsEventStatus status = nsEventStatus_eIgnore;
|
|
||||||
mDispatcher->DispatchKeyboardEvent(eKeyDown, imeEvent, status, currentKeyEvent);
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
RefPtr<TextInputHandler> kungFuDeathGrip(this);
|
RefPtr<TextInputHandler> kungFuDeathGrip(this);
|
||||||
|
|
||||||
// When we're already in a composition, we need always to mark the eKeyDown
|
// When we're already in a composition, we need always to mark the eKeyDown
|
||||||
|
|||||||
@@ -31,7 +31,6 @@ EXPORTS += [
|
|||||||
]
|
]
|
||||||
|
|
||||||
UNIFIED_SOURCES += [
|
UNIFIED_SOURCES += [
|
||||||
"ComplexTextInputPanel.mm",
|
|
||||||
"GfxInfo.mm",
|
"GfxInfo.mm",
|
||||||
"IconLoaderHelperCocoa.mm",
|
"IconLoaderHelperCocoa.mm",
|
||||||
"NativeKeyBindings.mm",
|
"NativeKeyBindings.mm",
|
||||||
|
|||||||
@@ -5,6 +5,8 @@
|
|||||||
|
|
||||||
#include "nsPrintSettingsServiceX.h"
|
#include "nsPrintSettingsServiceX.h"
|
||||||
|
|
||||||
|
#include "mozilla/Debug.h"
|
||||||
|
#include "mozilla/Unused.h"
|
||||||
#include "nsCOMPtr.h"
|
#include "nsCOMPtr.h"
|
||||||
#include "nsQueryObject.h"
|
#include "nsQueryObject.h"
|
||||||
#include "nsPrintSettingsX.h"
|
#include "nsPrintSettingsX.h"
|
||||||
@@ -51,7 +53,7 @@ nsPrintSettingsServiceX::DeserializeToPrintSettings(const PrintData& data,
|
|||||||
|
|
||||||
nsresult nsPrintSettingsServiceX::ReadPrefs(nsIPrintSettings* aPS, const nsAString& aPrinterName,
|
nsresult nsPrintSettingsServiceX::ReadPrefs(nsIPrintSettings* aPS, const nsAString& aPrinterName,
|
||||||
uint32_t aFlags) {
|
uint32_t aFlags) {
|
||||||
DebugOnly<nsresult> rv = nsPrintSettingsService::ReadPrefs(aPS, aPrinterName, aFlags);
|
mozilla::DebugOnly<nsresult> rv = nsPrintSettingsService::ReadPrefs(aPS, aPrinterName, aFlags);
|
||||||
NS_ASSERTION(NS_SUCCEEDED(rv), "nsPrintSettingsService::ReadPrefs() failed");
|
NS_ASSERTION(NS_SUCCEEDED(rv), "nsPrintSettingsService::ReadPrefs() failed");
|
||||||
|
|
||||||
RefPtr<nsPrintSettingsX> printSettingsX(do_QueryObject(aPS));
|
RefPtr<nsPrintSettingsX> printSettingsX(do_QueryObject(aPS));
|
||||||
@@ -61,7 +63,7 @@ nsresult nsPrintSettingsServiceX::ReadPrefs(nsIPrintSettings* aPS, const nsAStri
|
|||||||
|
|
||||||
// ReadPageFormatFromPrefs may fail (e.g. prefs are missing/broken) but we can
|
// ReadPageFormatFromPrefs may fail (e.g. prefs are missing/broken) but we can
|
||||||
// safely ignore that and just leave existing/default values in the settings.
|
// safely ignore that and just leave existing/default values in the settings.
|
||||||
Unused << printSettingsX->ReadPageFormatFromPrefs();
|
mozilla::Unused << printSettingsX->ReadPageFormatFromPrefs();
|
||||||
|
|
||||||
return NS_OK;
|
return NS_OK;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,6 +5,7 @@
|
|||||||
#include "nsPrinterListCUPS.h"
|
#include "nsPrinterListCUPS.h"
|
||||||
|
|
||||||
#include "mozilla/IntegerRange.h"
|
#include "mozilla/IntegerRange.h"
|
||||||
|
#include "mozilla/Maybe.h"
|
||||||
#include "nsCUPSShim.h"
|
#include "nsCUPSShim.h"
|
||||||
#include "nsPrinterCUPS.h"
|
#include "nsPrinterCUPS.h"
|
||||||
#include "nsString.h"
|
#include "nsString.h"
|
||||||
@@ -110,9 +111,9 @@ RefPtr<nsIPrinter> nsPrinterListCUPS::CreatePrinter(PrinterInfo aInfo) const {
|
|||||||
static_cast<cups_dest_t*>(aInfo.mCupsHandle));
|
static_cast<cups_dest_t*>(aInfo.mCupsHandle));
|
||||||
}
|
}
|
||||||
|
|
||||||
Maybe<PrinterInfo> nsPrinterListCUPS::PrinterByName(
|
mozilla::Maybe<PrinterInfo> nsPrinterListCUPS::PrinterByName(
|
||||||
nsString aPrinterName) const {
|
nsString aPrinterName) const {
|
||||||
Maybe<PrinterInfo> rv;
|
mozilla::Maybe<PrinterInfo> rv;
|
||||||
if (!CupsShim().InitOkay()) {
|
if (!CupsShim().InitOkay()) {
|
||||||
return rv;
|
return rv;
|
||||||
}
|
}
|
||||||
@@ -160,9 +161,9 @@ Maybe<PrinterInfo> nsPrinterListCUPS::PrinterByName(
|
|||||||
return rv;
|
return rv;
|
||||||
}
|
}
|
||||||
|
|
||||||
Maybe<PrinterInfo> nsPrinterListCUPS::PrinterBySystemName(
|
mozilla::Maybe<PrinterInfo> nsPrinterListCUPS::PrinterBySystemName(
|
||||||
nsString aPrinterName) const {
|
nsString aPrinterName) const {
|
||||||
Maybe<PrinterInfo> rv;
|
mozilla::Maybe<PrinterInfo> rv;
|
||||||
if (!CupsShim().InitOkay()) {
|
if (!CupsShim().InitOkay()) {
|
||||||
return rv;
|
return rv;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,14 +9,20 @@
|
|||||||
#include "nsPrinterListBase.h"
|
#include "nsPrinterListBase.h"
|
||||||
#include "nsStringFwd.h"
|
#include "nsStringFwd.h"
|
||||||
|
|
||||||
|
namespace mozilla {
|
||||||
|
template <typename T>
|
||||||
|
class Maybe;
|
||||||
|
} // namespace mozilla
|
||||||
|
|
||||||
class nsPrinterListCUPS final : public nsPrinterListBase {
|
class nsPrinterListCUPS final : public nsPrinterListBase {
|
||||||
NS_IMETHOD InitPrintSettingsFromPrinter(const nsAString&,
|
NS_IMETHOD InitPrintSettingsFromPrinter(const nsAString&,
|
||||||
nsIPrintSettings*) final;
|
nsIPrintSettings*) final;
|
||||||
|
|
||||||
nsTArray<PrinterInfo> Printers() const final;
|
nsTArray<PrinterInfo> Printers() const final;
|
||||||
RefPtr<nsIPrinter> CreatePrinter(PrinterInfo) const final;
|
RefPtr<nsIPrinter> CreatePrinter(PrinterInfo) const final;
|
||||||
Maybe<PrinterInfo> PrinterByName(nsString aPrinterName) const final;
|
mozilla::Maybe<PrinterInfo> PrinterByName(nsString aPrinterName) const final;
|
||||||
Maybe<PrinterInfo> PrinterBySystemName(nsString aPrinterName) const final;
|
mozilla::Maybe<PrinterInfo> PrinterBySystemName(
|
||||||
|
nsString aPrinterName) const final;
|
||||||
nsresult SystemDefaultPrinterName(nsAString&) const final;
|
nsresult SystemDefaultPrinterName(nsAString&) const final;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|||||||
Reference in New Issue
Block a user