mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:18:48 +00:00
df2987f659
- bit of Bug 1219134: P2. Use LibAV/FFmpeg logic to detect invalid pts. r=edwin (34d2a7d442)
- Bug 1195018 - Support 'background_color' member in the manifest processor. r=marcosc (1451b14321)
- Bug 1240490 - Fix console prefix used by the App Manifest processor. r=marcosc (e3196b53c8)
- Bug 1086997 - Localize developer warnings issued by the manifest processor. r=baku (7659fc5dd6)
- Bug 1258899 - teach manifest processor about dir member. r=baku (00b40c51c2)
- Bug 1262739 - Remove support for splash_screens member in Manifest Processor r=mconley (bceb0d2517)
- Bug 1264813 - Remove image object's density member from Web Manifest processor. r=mconley (f34da7259e)
- Bug 1264816 - Drop background_color from Web manifest image object. r=mconley (40c55f7bf9)
- Bug 1186908 - Return manifest members to canonical form after processing. r=mconley. (59d9a12a17)
- Bug 293394 - javascript: should never execute with chrome privs. r=bz (0dcc8f146b)
- bit of Bug 1153267 - part 2 (a0c5f7fda8)
- Bug 1254320 - Remove SEC_NORMAL from dom/json/ . r=bz (cd068db51c)
- Bug 1262590 - [e10s] AppProcessChecker.cpp has DEUBG typo preventing DEBUG messages. r=mconley (f9ffab4e57)
- Bug 1263556 - Remove EmptyBlobImpl in dom/ipc/Blob.cpp, r=smaug (3f4fe63e05)
- Bug 1261072 - File::GetName() should be const, r=smaug (bccd7475f1)
- Bug 1257759 part.1 Use switch-case at the first message handling in PluginInstanceChild::PluginWindowProcInternal() r=m_kato (bc0d4c457e)
- Bug 1257759 part.2 Separate Windows' message and related definitions from nsWindowDefs.h to mozilla/widget/WinMessages.h r=jimm (f8b5cb62f8)
- Bug 1153829 - Don't use MOZ_ALWAYS_INLINE for non-inline functions. r=jimm (c0e5b26c35)
- Bug 1257759 part.3 ModifierKeyState should be available in plugin module r=jimm (aa3fc81f63)
- Bug 1257759 part.4 Rename WidgetGUIEvent::PluginEvent to NativeEventData for using this class to send native event from plugin process to content and/or chrome process r=smaug (49392203ad)
- Bug 1255968 - Part 1: Let the callback of PeekMessages() to return a boolean to be able to break out the loop. r=dvander (d7f926ee7e)
- Bug 1255968 - Part 2: Implement puppet widget's HasPendingInputEvent() for interruptible reflow to work in content process. r=bz (5a0915e650)
- Bug 1257759 part.5 PluginInstanceChild should post received native key event to chrome process if the key combination may be a shortcut key r=jimm (ad1e3ad1c0)
- Bug 1252152 - Make plugin instances destroyed while that instance is on the stack crash earlier and more usefully, r=jimm (2238cc2a79)
- Bug 1257759 part.6 Keep event order between keyboard events and IME events in a plugin process r=jimm (32cbe1b13e)
- Bug 1257759 part.7 Add new internal events which represent key events on plugin r=smaug (161725755a)
- Bug 1257759 part.8 nsXBLWindowKeyHandler should handle eKeyDownOnPlugin and eKeyUpOnPlugin events only with reserved shortcut key handlers r=smaug (aa7cd1d786)
- Bug 1257759 part.9 Implement nsWindow::OnKeyEventInPluginProcess() on Windows r=jimm (245b2709e4)
- Bug 1257759 part.10 PluginInstanceChild should consume WM_*CHAR messages which follow consumed WM_*KEYDOWN or WM_*KEYUP message r=jimm (db355e6a77)
- Bug 1261735 (part 1) - Overhaul the atom implementation. r=froydnj,erahm. (abbed483f7)
- Bug 1261735 (part 2) - Inline some {Dynamic,Static}Atom methods. r=erahm. (97b11fa656)
- Bug 1261735 (part 3) - De-virtualize nsIAtom::IsStaticAtom(). r=froydnj,erahm. (4e0465a84a)
- Bug 1257207 - Increase ATOM_HASHTABLE_INITIAL_LENGTH. r=froydnj. (fe663e9c77)
- Bug 1261735 (part 4) - Change StaticAtomEntry::mAtom to |StaticAtom*|. r=erahm. (999fff7b8c)
- Bug 1261744 - Add two missing null checks for nsStringBuffer::Alloc(). r=erahm. (dd9ef00b6a)
- Bug 1266295 - Remove unnecessary compiler version checks for gcc <= 4.8.0 in xpcom. r=froydnj (b2f17f8d1a)
- Bug 1259706: Add NS_INLINE_DECL_THREADSAFE_VIRTUAL_REFCOUNTING macro. r=froydnj (d56a5fd48b)
- just a space (1508ec768f)
- Bug 1236991 - part 1: allow forwarding label direction through nsITooltipTextProvider, r=enndeakin (8d49127ffa)
- Bug 1245649: Enable no-nested-ternary. r=mconley (43c7b99372)
- Bug 1236991 - part 2: implement a default tooltiptextprovider in toolkit, r=enndeakin (a0a378979f)
- Bug 1251032 - Send RenderFrame info down to child in BrowserFrameOpenWindow. r=kanru (aec01fcec9)
- Bug 1246327 - Remove dom.always_allow_move_resize_window preference. r=jst (d06d83d596)
- Bug 1158228 - merge github's readability code into m-c, rs=me (38da823ce7)
- Bug 1158184 - merge recent github readability changes into m-c, rs=me (3b634d63c8)
- Bug 1162917 - update readability from github repo, rs=me (29dd18a9f0)
- No bug - update readability from github repo, includes fix for bug 1230050, rs=uplift-with-r+-patches-from-github (fa04927c71)
- Bug 1265866 - update Readability to the latest version from github, rs=me (c89e4dbeac)
- bits of Bug 1158228 (950dd3d561)
- Bug 1249579 - part2 : audio competing suspend/resume methods. r=snorp, baku. (3b6ddc018d)
- Bug 1266221 P1 Get devtools http service worker testing option from top window. r=bz (e8492118f0)
- Bug 225910 - Use nsIURI's GetRef and GetHasRef in nsDocShell. r=bz (76da6473d4)
- Bug 1261471: Remove support for getting mozIDOMWindowProxy via GetInterface. r=mrbkap (04904ed142)
- Bug 1264725 - Isolate Troubleshoot.jsm (about:support) from addons with null names. r=felipe (4ebb240827)
- Bug 1227730 - Support closing libnotify alerts. r=karlt,MattN (73d8b583dc)
149 lines
5.8 KiB
JavaScript
149 lines
5.8 KiB
JavaScript
/* 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/. */
|
|
|
|
const { classes: Cc, interfaces: Ci, utils: Cu, results: Cr } = Components;
|
|
|
|
Cu.import("resource://gre/modules/XPCOMUtils.jsm");
|
|
Cu.import("resource://gre/modules/Services.jsm");
|
|
|
|
function TooltipTextProvider() {}
|
|
|
|
TooltipTextProvider.prototype = {
|
|
getNodeText(tipElement, textOut, directionOut) {
|
|
// Don't show the tooltip if the tooltip node is a document, browser, or disconnected.
|
|
if (!tipElement || !tipElement.ownerDocument ||
|
|
tipElement.localName == "browser" ||
|
|
(tipElement.ownerDocument.compareDocumentPosition(tipElement) &
|
|
tipElement.ownerDocument.DOCUMENT_POSITION_DISCONNECTED)) {
|
|
return false;
|
|
}
|
|
|
|
var defView = tipElement.ownerDocument.defaultView;
|
|
// XXX Work around bug 350679:
|
|
// "Tooltips can be fired in documents with no view".
|
|
if (!defView)
|
|
return false;
|
|
|
|
const XLinkNS = "http://www.w3.org/1999/xlink";
|
|
const XULNS = "http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul";
|
|
|
|
var titleText = null;
|
|
var XLinkTitleText = null;
|
|
var SVGTitleText = null;
|
|
var XULtooltiptextText = null;
|
|
var lookingForSVGTitle = true;
|
|
var direction = tipElement.ownerDocument.dir;
|
|
|
|
// If the element is invalid per HTML5 Forms specifications and has no title,
|
|
// show the constraint validation error message.
|
|
if ((tipElement instanceof defView.HTMLInputElement ||
|
|
tipElement instanceof defView.HTMLTextAreaElement ||
|
|
tipElement instanceof defView.HTMLSelectElement ||
|
|
tipElement instanceof defView.HTMLButtonElement) &&
|
|
!tipElement.hasAttribute('title') &&
|
|
(!tipElement.form || !tipElement.form.noValidate)) {
|
|
// If the element is barred from constraint validation or valid,
|
|
// the validation message will be the empty string.
|
|
titleText = tipElement.validationMessage || null;
|
|
}
|
|
|
|
// If the element is an <input type='file'> without a title, we should show
|
|
// the current file selection.
|
|
if (!titleText &&
|
|
tipElement instanceof defView.HTMLInputElement &&
|
|
tipElement.type == 'file' &&
|
|
!tipElement.hasAttribute('title')) {
|
|
let files = tipElement.files;
|
|
|
|
try {
|
|
var bundle =
|
|
Services.strings.createBundle("chrome://global/locale/layout/HtmlForm.properties");
|
|
if (files.length == 0) {
|
|
if (tipElement.multiple) {
|
|
titleText = bundle.GetStringFromName("NoFilesSelected");
|
|
} else {
|
|
titleText = bundle.GetStringFromName("NoFileSelected");
|
|
}
|
|
} else {
|
|
titleText = files[0].name;
|
|
// For UX and performance (jank) reasons we cap the number of
|
|
// files that we list in the tooltip to 20 plus a "and xxx more"
|
|
// line, or to 21 if exactly 21 files were picked.
|
|
const TRUNCATED_FILE_COUNT = 20;
|
|
let count = Math.min(files.length, TRUNCATED_FILE_COUNT);
|
|
for (let i = 1; i < count; ++i) {
|
|
titleText += "\n" + files[i].name;
|
|
}
|
|
if (files.length == TRUNCATED_FILE_COUNT + 1) {
|
|
titleText += "\n" + files[TRUNCATED_FILE_COUNT].name;
|
|
} else if (files.length > TRUNCATED_FILE_COUNT + 1) {
|
|
let xmoreStr = bundle.GetStringFromName("AndNMoreFiles");
|
|
let xmoreNum = files.length - TRUNCATED_FILE_COUNT;
|
|
let tmp = {};
|
|
Cu.import("resource://gre/modules/PluralForm.jsm", tmp);
|
|
let andXMoreStr = tmp.PluralForm.get(xmoreNum, xmoreStr).replace("#1", xmoreNum);
|
|
titleText += "\n" + andXMoreStr;
|
|
}
|
|
}
|
|
} catch(e) {}
|
|
}
|
|
|
|
// Check texts against null so that title="" can be used to undefine a
|
|
// title on a child element.
|
|
while (tipElement &&
|
|
(titleText == null) && (XLinkTitleText == null) &&
|
|
(SVGTitleText == null) && (XULtooltiptextText == null)) {
|
|
|
|
if (tipElement.nodeType == defView.Node.ELEMENT_NODE) {
|
|
if (tipElement.namespaceURI == XULNS)
|
|
XULtooltiptextText = tipElement.getAttribute("tooltiptext");
|
|
else if (!(tipElement instanceof defView.SVGElement))
|
|
titleText = tipElement.getAttribute("title");
|
|
|
|
if ((tipElement instanceof defView.HTMLAnchorElement ||
|
|
tipElement instanceof defView.HTMLAreaElement ||
|
|
tipElement instanceof defView.HTMLLinkElement ||
|
|
tipElement instanceof defView.SVGAElement) && tipElement.href) {
|
|
XLinkTitleText = tipElement.getAttributeNS(XLinkNS, "title");
|
|
}
|
|
if (lookingForSVGTitle &&
|
|
(!(tipElement instanceof defView.SVGElement) ||
|
|
tipElement.parentNode.nodeType == defView.Node.DOCUMENT_NODE)) {
|
|
lookingForSVGTitle = false;
|
|
}
|
|
if (lookingForSVGTitle) {
|
|
for (let childNode of tipElement.childNodes) {
|
|
if (childNode instanceof defView.SVGTitleElement) {
|
|
SVGTitleText = childNode.textContent;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
direction = defView.getComputedStyle(tipElement, "")
|
|
.getPropertyValue("direction");
|
|
}
|
|
|
|
tipElement = tipElement.parentNode;
|
|
}
|
|
|
|
return [titleText, XLinkTitleText, SVGTitleText, XULtooltiptextText].some(function (t) {
|
|
if (t && /\S/.test(t)) {
|
|
// Make CRLF and CR render one line break each.
|
|
textOut.value = t.replace(/\r\n?/g, '\n');
|
|
directionOut.value = direction;
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
});
|
|
},
|
|
|
|
classID : Components.ID("{f376627f-0bbc-47b8-887e-fc92574cc91f}"),
|
|
QueryInterface: XPCOMUtils.generateQI([Ci.nsITooltipTextProvider]),
|
|
};
|
|
|
|
this.NSGetFactory = XPCOMUtils.generateNSGetFactory([TooltipTextProvider]);
|
|
|