mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:30:27 +00:00
aec5e5666e
- bug 1083930 - cpu spin during large h2/spdy upload r=hurley (0949388a6a)
- Bug 1241906 - Spdy deadlock on suspended channel r=hurley (f40e9677d5)
- Bug 1247205 - dont loop on http2 softerror r=dragana (2ab3cb69ef)
- Bug 1246778 - dont loop in nshttpconnection during shutdown r=dragana (0677b9d34b)
- Bug 1201037 - only send "HTTP pings" on seemingly idle connections, r=mcmanus (134198bc79)
- Bug 1174899 - discarded spdy data with fin attributed to wrong stream r=bagder (f3b801c734)
- Bug 1236170 - Make Http2Session::UncompressAndDiscard push-aware. r=mcmanus (e71634e853)
- Bug 1240025 - incorrect close state on pushed stream r=hurley (eb2832177a)
- Bug 1227931 - init Http2Stream::mReceivedData in the constructor. r=nwgh (44f1d8e897)
- Bug 241788 - net_FilterURIString should filter \r\n\t from the entire URL r=honzab (734d9b8cae)
- Bug 1259459 - h2 0 length options puts end-stream on headers r=hurley (31ac211a9b)
- Bug 1174899 - fixup log format strings for spdy/h2 r=bagder (967c9ff71e)
- Bug 1211694 - dataLength has been added twice. r=mcmanus (6773981db3)
- cleanup (26517f5de0)
- Bug 1247998 - Let nsHttpChannel::AsyncOpen* throw after nsHttpHandler has been shutdown, r=mcmanus (90bb2364be)
- Bug 1231512 - Allow nsIHttpChannel.redirectTo() work also on an open channel, r=jduell (198fb72816)
- Bug 1242472 - Properly propagate mTopWindowURI through redirects. r=francois/ckerschb (1d27a15770)
- Bug 1133873 - some spdy logs r=hurley (cd95cfed5a)
- bug 1215724 - enable brotli on spdy r=hurley (83cca72fa5)
- Bug 137852 - Add a new working HTTP authentication identity to the begining of the session cache list. r=honzab (f670349771)
- Bug 1245414, part 1 - Delete the mfbt/decimal/LICENSE* files since upstream now just uses inline comments. r=Waldo (15bb211e14)
- Bug 1245414, part 2 - Update mfbt/decimal/update.sh to reflect Blink's switch from svn to git, and the different files we now pull. r=Waldo (4dd0b5916a)
- Bug 1245414, part 3 - Overwrite mfbt/decimal/Decimal.* with vanilla upstream copies. r=Waldo (98f7ba4711)
- Bug 1245414, part 4 - Update mfbt/decimal/zero-serialization.patch. r =Waldo (055e1354a7)
- Bug 1245414, part 5 - Update mfbt/decimal/comparison-with-nan.patch. r=Waldo (583e0f3e76)
- Bug 1245414, part 6 - Update mfbt/decimal/mfbt-abi-markers.patch. r=Waldo (148b1ac08b)
- Bug 1245414, part 7 - Update mfbt/decimal/to-moz-dependencies.patch. r=Waldo (2e2a6a33d7)
- Bug 1245414, part 8 - Remove mfbt/decimal/floor-ceiling.patch now that the issue is fixed upstream. r=Waldo (84fc02c068)
- Bug 1245414, part 9 - Disable mfbt/decimal/fix-wshadow-warnings.patch. r=cpeterson (4476d04c5d)
- Bug 1245414, part 10 - Apply the Mozilla patches via mfbt/decimal/update.sh. r=Waldo (1f95ef5524)
- Bug 1247082 - Suppress rendering of nsBackdropFrame for VR content r=dholbert (0ffeae4267)
- Bug 1206545 - Initialize AccessibleCaretEventHub in nsCanvasFrame. r=roc (687d4997fb)
- Bug 591737 - Add SummaryFrame. r=bz (1b750bfeb8)
- Bug 1165893 - Fix rounding issue in nsDisplaySelectionOverlay::Paint. r=mattwoodro (9994cc983a)
- Bug 1245450 - Only setup AutoSaveRestorePerspectiveIndex for the descendants of the element with perspective. r=roc (fe8a350417)
- Bug 1243282 - Wrap items having clips with a separator. r=mattwoodrow (915737e3d0)
- Bug 1223232 - Use GetUsedBorder() instead of the computed border value when calculating CB size. r=roc (f4c05b30c7)
- Bug 1223232 - Crashtest. (394e112818)
- Bug 1230665 - Make anonymous flex/grid items non-tabbable and non-focusable. r=roc (0d3f70e672)
- Bug 1142295 - Closing descriptor when GECKO_DISPLAY_REFLOW_RULES_FILE is setted. r=erahm (664ae6ba0a)
- minor change (b914bd2602)
- Bug 1237754 part 1 - [css-grid][css-align] Make 'align/justify-content:normal' behave as 'stretch' for Grid containers. r=dholbert (09a9a09629)
- Bug 1237754 part 2 - [css-grid][css-align] Test updates to account for new default behavior for 'align/justify-content'. (5e62e837ff)
- minor of Bug 1141931 part 2 (a12f5b430e)
- Bu 974309: Fixes the IsEditable() logic for table cells. r=ehsan (2a3caa932f)
- Bug 1238137 - Telemetry pings for main thread keyboard-driven scroll input methods. r=ehsan (e9c07427f9)
- Bug 1238137 - Telemetry pings for main thread scrolling to bring the caret into view after moving it in response to keyboard input. r=ehsan (834bc12b7a)
- Bug 1246405 - Declare mTextRun earlier to avoid alignment spill on 64-bit architectures. r=roc (7ba93b72c9)
- Fixing bug 440486. Work around a Windows XP fax dialog bug. r=rstrong. (a59409acd6)
- Bug 1240911 - Prevent SerializedStructuredCloneBuffer from escaping into the heap. r=amarchesini (2c0b7c474b)
- Bug 1240985 - Hold off processing some messages during timeout (r=dvander) (10f6f6d7a2)
- Bug 1146471 - Release thread asserts for IPC (r=dvander) (f94d0ee09a)
- Bug 1240985 - Fix bug where mAwaitingSyncReply can be overwritten in Send after Cancel (r=dvander) (7b95acdca6)
- Bug 1193861: Log to the process log when launching a sandboxed process on Windows. r=billm (0ad1afd0d0)
- Bug 1233061 - add override declarations for MessagePumpForNonMainUIThreads; r=billm (94b9a5bfe9)
- Bug 1172467: Fix an IPC channel file descriptor leak from Nuwa to the child process. r=khuey (908601ed0e)
- Bug 1240985 - Check WasTransactionCanceled after timeout (and avoid timing out) (r=dvander) (33aade0a92)
- Bug 1237458 - Use MOZ_RELEASE_ASSERT for IPC assertions (r=jld) (cb0f058205)
- Bug 1247429 - Warn instead of error if shmem deallocated before IPDL sends it. r=nical (3c94d99b21)
- Bug 1175999 - Deallocate mach SharedMemory properly. r=blassey. (542649b570)
- Bug 1188186 - Fix leak of FDs in |CreateTransport|. r=bds (a40b9a0c58)
- Bg 1240607 - Force CreateWindow hooks to be detours. r=jmathies (895d1c21c4)
- Bug 1209464: Fix missing neutered window region in MessageChannel::WaitForInterruptNotify. Regression from bug 1189709; r=jimm (204256880b)
- Bug 1229825 - Make GIF deinterlacer respect the frame rect bounds. r=tn (904f6bd9b7)
- Bug 1242093 - Fix assertion in Downscaler::ClearRow. r=njn (63ffe82e99)
- Bug 1235859 - Add FrameSize to non-skia downscaler. r=edwin (e7474630e0)
- Bug 1237709: During RasterImage error-handling cleanup, set UniquePtr mAnim to null instead of using reset(), to avoid leaking. r=dholbert (b064f9c20d)
- Bug 1235605 - Use CheckedInt in Deinterlacer and make its buffer allocation fallible. r=tn (f6f3858c65)
- cleanup (f02aa9441e)
- Bug 1242778: Add MOZ_COUNT_CTOR & MOZ_COUNT_DTOR calls to track leaks of imagelib's FrameAnimator class. r=tn (b1aa366694)
- Bug 1241728. Add crashtest. (17d80a3387)
- Bug 1241729. Add crashtest. (bd6d7337d7)
- Bug 1241728. Limit the size of images that we will downscale from to 1048576 pixels. r=edwin (ad38a82aad)
- Bug 1218782 - use fallible allocations in Downscaler.cpp; r=seth (b22caa1121)
- Bug 1224979. Check if we compute usable filters for the downscaler, and if not put the downscaler in error state so it's not used. r=edwin (8fb59463ef)
- Bug 1235297 - Annotate intentional switch fallthroughs to suppress -Wimplicit-fallthrough warnings in image/decoders/. r=tn (094c37c0fe)
- Bug 1238558 (part 1) - Add Decoder::BeforeFinishInternal(). r=tnikkel. (c7922054d6)
- Bug 1238558 (part 2) - Add a test. r=tnikkel. (7e09caf47f)
- Bug 1238551 (part 2) - Add a test. r=tn. (f548a2cb97)
- Bug 1238551 (part 1) - Reject BITMAPV3INFOHEADER BMP images. r=tn. (c4c8f95cb3)
- Bug 1240629. Don't buffer image file data that we are never going to look at in the gap between the header and the pixel data for BMP files. r=njn (f580910cd3)
- Bug 1237171 - Improve a case where ICO and BMP files disagree on an image size. r=tn. (615db65802)
- Bug 1220021 (part 1) - Don't treat 0RGB ICO files as transparent. r=seth. (b97298285f)
- Bug 1220021 (part 2) - Add four reftests. r=seth. (b1e7b58a98)
- Bug 1163856 (Part 2) - Fix tests that depended on image load event timing. r=tn (4304c676a0)
- Bug 1207958 - Fix heuristic for choosing which ICO sub-image to render - r=tn (3d4db5a033)
- Bug 987625 - Conditionally define MOZ_PNG_MAX_DIMENSION. r=jrmuizel (859bae490c)
- Bug 75077 - Interpolate interlaced PNG images instead of libpng blocky display. r=seth (bc17b43fa6)
- fix side-effect of 1219405 (6536821e18)
- Bug 1245845, part 1 - Stop Moz2D Path::CopyToBuilder/TransformedCopyToBuilder implicitly converting the Path's FillRule. r=Bas (ecc552f359)
- Bug 1245845, part 2 - Remove code that is now useless from gfxContext::EnsurePath. r=Bas (2430be2837)
- Bug 1237448 - Moz2Dify two functions in gfxSurfaceDrawable. r=roc. (bb768302c5)
- Bug 1231888 (follow-up) - Simplify CurrentSurface(). r=jrmuizel. (303cea98f3)
- Bug 1247380: Only copy the background if we can succesfully get a snapshot. r=jrmuizel (13b64445e9)
- Bug 1228507 - Initialize mBlendOpacity. r=Bas (b301a2c9f4)
- Bug 1238846 (part 2) - Remove gfxContext::mOriginalDT, which is unused. r=mattwoodrow. (a5b0f948b7)
- Bug 1240819 - cleanup dead branches in gfxXlibNativeRender.cpp. r=jrmuizel (57bbec6693)
- Bug 1234950 - When advancing APZ animations, use the next vsync timestamp instead of the current one, since that is what will be composited. r=mstange (421829d459)
- Bug 1021845 - Don't skip checkerboarding layers during compositing, even if the layer's visible region is empty. r=botond (6cf1497019)
- Bug 1230149 - check bigImgIter to see if it's not null. r=jmuizelaar (aeef579f9f)
- Bug 1248325 - Update BufferTextureHost::GetAsSurface() r=nical (39a8b3ca71)
- reapply per misspatch Bug 1200595 - Consolidate the TextureClient's destruction logic (68966e4dc3)
- Bug 1249245 - Add missing header gfxPrefs.h to GrallocTextureClient.cpp. r=cyu (676669eb01)
- Bug 1245057: Refer to |gfx::IntPoint| in |GrallocTextureHostOGL::SetCropRect|, r=sotaro (99e572f3f6)
- Bug 1240867 - Fix non-unified build bustage in OGLShaderProgram.cpp. r=nical (0071f08285)
- Bug 1238015 - Make sure PTexture actors are destroyed after all messages referring to them are sent. r=sotaro (250f99b4a4)
- Bug 1220895 - Add layerviewer for layer tree & display list visualization NPOTB. r=botond (fa211145a1)
- Bug 1213464 - ImageBridgeChild and CompositorChild should delete their Transport. r=billm (a37a0dbdfd)
- Bug 1234343 (part 1) - Make GfxMemoryImageReporter::sAmount signed. r=Bas. (18f0cb61ec)
- Bug 1234343 (part 2) - Add a missing GfxMemoryImageReporter::DidAlloc() call. r=Bas. (69df7f3674)
- Bug 1245249 - Check actor state before calling Send__delete__(); r=luke (65716a5915)
- Bug 1221418 - A better cleanup method for AsmJSCache::ChildRunnable, r=janv (5c8c023b9d)
- Bug 1235657 - Session storage needs to handle origin attributes correctly - part 1 - createOriginAttributesWithUserContextId, r=huseby (f2df8109ef)
- Bug 1245954 - Console StartTimer/StopTimer and IncrementCounter should run in the owning thread, r=bz (64f73d7759)
- Bug 1245957 - Adding assertions in Console about in which thread is running what, r=bz (291ee70e2d)
- Bug 1248022 - ConsoleEvent.styles can be a sequence of nullable strings, r=bz (b94ec79ac0)
- Bug 1245242 - Normalize to unit vector for DOMMatrix.rotateAxisAngleSelf. r=roc (3a9e684b4d)
- Bug 1236329. Back out the patch for bug 492933 (revision d8012b35413b) because it's not web-compatible in practice. r=smaug (f6540d84c3)
- mTarget can be null in CanvasRenderingContext2D::ClearRect(), return early if so. (13e8a4e26a)
594 lines
18 KiB
C++
594 lines
18 KiB
C++
/* -*- 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/. */
|
|
|
|
/*
|
|
* nsBaseContentList is a basic list of content nodes; nsContentList
|
|
* is a commonly used NodeList implementation (used for
|
|
* getElementsByTagName, some properties on nsIDOMHTMLDocument, etc).
|
|
*/
|
|
|
|
#ifndef nsContentList_h___
|
|
#define nsContentList_h___
|
|
|
|
#include "mozilla/Attributes.h"
|
|
#include "nsContentListDeclarations.h"
|
|
#include "nsISupports.h"
|
|
#include "nsTArray.h"
|
|
#include "nsString.h"
|
|
#include "nsIHTMLCollection.h"
|
|
#include "nsIDOMNodeList.h"
|
|
#include "nsINodeList.h"
|
|
#include "nsStubMutationObserver.h"
|
|
#include "nsIAtom.h"
|
|
#include "nsCycleCollectionParticipant.h"
|
|
#include "nsNameSpaceManager.h"
|
|
#include "nsWrapperCache.h"
|
|
#include "nsHashKeys.h"
|
|
#include "mozilla/HashFunctions.h"
|
|
#include "mozilla/dom/NameSpaceConstants.h"
|
|
|
|
namespace mozilla {
|
|
namespace dom {
|
|
class Element;
|
|
} // namespace dom
|
|
} // namespace mozilla
|
|
|
|
|
|
class nsBaseContentList : public nsINodeList
|
|
{
|
|
public:
|
|
NS_DECL_CYCLE_COLLECTING_ISUPPORTS
|
|
|
|
// nsIDOMNodeList
|
|
NS_DECL_NSIDOMNODELIST
|
|
|
|
// nsINodeList
|
|
virtual int32_t IndexOf(nsIContent* aContent) override;
|
|
virtual nsIContent* Item(uint32_t aIndex) override;
|
|
|
|
uint32_t Length() const {
|
|
return mElements.Length();
|
|
}
|
|
|
|
NS_DECL_CYCLE_COLLECTION_SKIPPABLE_SCRIPT_HOLDER_CLASS(nsBaseContentList)
|
|
|
|
void AppendElement(nsIContent *aContent)
|
|
{
|
|
mElements.AppendElement(aContent);
|
|
}
|
|
void MaybeAppendElement(nsIContent* aContent)
|
|
{
|
|
if (aContent)
|
|
AppendElement(aContent);
|
|
}
|
|
|
|
/**
|
|
* Insert the element at a given index, shifting the objects at
|
|
* the given index and later to make space.
|
|
* @param aContent Element to insert, must not be null
|
|
* @param aIndex Index to insert the element at.
|
|
*/
|
|
void InsertElementAt(nsIContent* aContent, int32_t aIndex)
|
|
{
|
|
NS_ASSERTION(aContent, "Element to insert must not be null");
|
|
mElements.InsertElementAt(aIndex, aContent);
|
|
}
|
|
|
|
void RemoveElement(nsIContent *aContent)
|
|
{
|
|
mElements.RemoveElement(aContent);
|
|
}
|
|
|
|
void Reset() {
|
|
mElements.Clear();
|
|
}
|
|
|
|
virtual int32_t IndexOf(nsIContent *aContent, bool aDoFlush);
|
|
|
|
virtual JSObject* WrapObject(JSContext *cx, JS::Handle<JSObject*> aGivenProto)
|
|
override = 0;
|
|
|
|
void SetCapacity(uint32_t aCapacity)
|
|
{
|
|
mElements.SetCapacity(aCapacity);
|
|
}
|
|
|
|
virtual void LastRelease() {}
|
|
|
|
protected:
|
|
virtual ~nsBaseContentList();
|
|
|
|
/**
|
|
* To be called from non-destructor locations (e.g. unlink) that want to
|
|
* remove from caches. Cacheable subclasses should override.
|
|
*/
|
|
virtual void RemoveFromCaches()
|
|
{
|
|
}
|
|
|
|
nsTArray< nsCOMPtr<nsIContent> > mElements;
|
|
};
|
|
|
|
|
|
class nsSimpleContentList : public nsBaseContentList
|
|
{
|
|
public:
|
|
explicit nsSimpleContentList(nsINode* aRoot) : nsBaseContentList(),
|
|
mRoot(aRoot)
|
|
{
|
|
}
|
|
|
|
NS_DECL_ISUPPORTS_INHERITED
|
|
NS_DECL_CYCLE_COLLECTION_CLASS_INHERITED(nsSimpleContentList,
|
|
nsBaseContentList)
|
|
|
|
virtual nsINode* GetParentObject() override
|
|
{
|
|
return mRoot;
|
|
}
|
|
virtual JSObject* WrapObject(JSContext *cx, JS::Handle<JSObject*> aGivenProto) override;
|
|
|
|
protected:
|
|
virtual ~nsSimpleContentList() {}
|
|
|
|
private:
|
|
// This has to be a strong reference, the root might go away before the list.
|
|
nsCOMPtr<nsINode> mRoot;
|
|
};
|
|
|
|
/**
|
|
* Class that's used as the key to hash nsContentList implementations
|
|
* for fast retrieval
|
|
*/
|
|
struct nsContentListKey
|
|
{
|
|
// We have to take an aIsHTMLDocument arg for two reasons:
|
|
// 1) We don't want to include nsIDocument.h in this header.
|
|
// 2) We need to do that to make nsContentList::RemoveFromHashtable
|
|
// work, because by the time it's called the document of the
|
|
// list's root node might have changed.
|
|
nsContentListKey(nsINode* aRootNode,
|
|
int32_t aMatchNameSpaceId,
|
|
const nsAString& aTagname,
|
|
bool aIsHTMLDocument)
|
|
: mRootNode(aRootNode),
|
|
mMatchNameSpaceId(aMatchNameSpaceId),
|
|
mTagname(aTagname),
|
|
mIsHTMLDocument(aIsHTMLDocument),
|
|
mHash(mozilla::AddToHash(mozilla::HashString(aTagname), mRootNode,
|
|
mMatchNameSpaceId, mIsHTMLDocument))
|
|
{
|
|
}
|
|
|
|
nsContentListKey(const nsContentListKey& aContentListKey)
|
|
: mRootNode(aContentListKey.mRootNode),
|
|
mMatchNameSpaceId(aContentListKey.mMatchNameSpaceId),
|
|
mTagname(aContentListKey.mTagname),
|
|
mIsHTMLDocument(aContentListKey.mIsHTMLDocument),
|
|
mHash(aContentListKey.mHash)
|
|
{
|
|
}
|
|
|
|
inline uint32_t GetHash(void) const
|
|
{
|
|
return mHash;
|
|
}
|
|
|
|
nsINode* const mRootNode; // Weak ref
|
|
const int32_t mMatchNameSpaceId;
|
|
const nsAString& mTagname;
|
|
bool mIsHTMLDocument;
|
|
const uint32_t mHash;
|
|
};
|
|
|
|
/**
|
|
* LIST_UP_TO_DATE means that the list is up to date and need not do
|
|
* any walking to be able to answer any questions anyone may have.
|
|
*/
|
|
#define LIST_UP_TO_DATE 0
|
|
/**
|
|
* LIST_DIRTY means that the list contains no useful information and
|
|
* if anyone asks it anything it will have to populate itself before
|
|
* answering.
|
|
*/
|
|
#define LIST_DIRTY 1
|
|
/**
|
|
* LIST_LAZY means that the list has populated itself to a certain
|
|
* extent and that that part of the list is still valid. Requests for
|
|
* things outside that part of the list will require walking the tree
|
|
* some more. When a list is in this state, the last thing in
|
|
* mElements is the last node in the tree that the list looked at.
|
|
*/
|
|
#define LIST_LAZY 2
|
|
|
|
/**
|
|
* Class that implements a live NodeList that matches Elements in the
|
|
* tree based on some criterion.
|
|
*/
|
|
class nsContentList : public nsBaseContentList,
|
|
public nsIHTMLCollection,
|
|
public nsStubMutationObserver
|
|
{
|
|
public:
|
|
NS_DECL_ISUPPORTS_INHERITED
|
|
|
|
/**
|
|
* @param aRootNode The node under which to limit our search.
|
|
* @param aMatchAtom An atom whose meaning depends on aMatchNameSpaceId.
|
|
* The special value "*" always matches whatever aMatchAtom
|
|
* is matched against.
|
|
* @param aMatchNameSpaceId If kNameSpaceID_Unknown, then aMatchAtom is the
|
|
* tagName to match.
|
|
* If kNameSpaceID_Wildcard, then aMatchAtom is the
|
|
* localName to match.
|
|
* Otherwise we match nodes whose namespace is
|
|
* aMatchNameSpaceId and localName matches
|
|
* aMatchAtom.
|
|
* @param aDeep If false, then look only at children of the root, nothing
|
|
* deeper. If true, then look at the whole subtree rooted at
|
|
* our root.
|
|
*/
|
|
nsContentList(nsINode* aRootNode,
|
|
int32_t aMatchNameSpaceId,
|
|
nsIAtom* aHTMLMatchAtom,
|
|
nsIAtom* aXMLMatchAtom,
|
|
bool aDeep = true);
|
|
|
|
/**
|
|
* @param aRootNode The node under which to limit our search.
|
|
* @param aFunc the function to be called to determine whether we match.
|
|
* This function MUST NOT ever cause mutation of the DOM.
|
|
* The nsContentList implementation guarantees that everything
|
|
* passed to the function will be IsElement().
|
|
* @param aDestroyFunc the function that will be called to destroy aData
|
|
* @param aData closure data that will need to be passed back to aFunc
|
|
* @param aDeep If false, then look only at children of the root, nothing
|
|
* deeper. If true, then look at the whole subtree rooted at
|
|
* our root.
|
|
* @param aMatchAtom an atom to be passed back to aFunc
|
|
* @param aMatchNameSpaceId a namespace id to be passed back to aFunc
|
|
* @param aFuncMayDependOnAttr a boolean that indicates whether this list is
|
|
* sensitive to attribute changes.
|
|
*/
|
|
nsContentList(nsINode* aRootNode,
|
|
nsContentListMatchFunc aFunc,
|
|
nsContentListDestroyFunc aDestroyFunc,
|
|
void* aData,
|
|
bool aDeep = true,
|
|
nsIAtom* aMatchAtom = nullptr,
|
|
int32_t aMatchNameSpaceId = kNameSpaceID_None,
|
|
bool aFuncMayDependOnAttr = true);
|
|
|
|
// nsWrapperCache
|
|
using nsWrapperCache::GetWrapperPreserveColor;
|
|
virtual JSObject* WrapObject(JSContext* aCx, JS::Handle<JSObject*> aGivenProto) override;
|
|
protected:
|
|
virtual ~nsContentList();
|
|
|
|
virtual JSObject* GetWrapperPreserveColorInternal() override
|
|
{
|
|
return nsWrapperCache::GetWrapperPreserveColor();
|
|
}
|
|
public:
|
|
|
|
// nsIDOMHTMLCollection
|
|
NS_DECL_NSIDOMHTMLCOLLECTION
|
|
|
|
// nsBaseContentList overrides
|
|
virtual int32_t IndexOf(nsIContent *aContent, bool aDoFlush) override;
|
|
virtual int32_t IndexOf(nsIContent* aContent) override;
|
|
virtual nsINode* GetParentObject() override
|
|
{
|
|
return mRootNode;
|
|
}
|
|
|
|
virtual nsIContent* Item(uint32_t aIndex) override;
|
|
virtual mozilla::dom::Element* GetElementAt(uint32_t index) override;
|
|
virtual mozilla::dom::Element*
|
|
GetFirstNamedElement(const nsAString& aName, bool& aFound) override
|
|
{
|
|
mozilla::dom::Element* item = NamedItem(aName, true);
|
|
aFound = !!item;
|
|
return item;
|
|
}
|
|
virtual void GetSupportedNames(unsigned aFlags,
|
|
nsTArray<nsString>& aNames) override;
|
|
|
|
// nsContentList public methods
|
|
uint32_t Length(bool aDoFlush);
|
|
nsIContent* Item(uint32_t aIndex, bool aDoFlush);
|
|
mozilla::dom::Element*
|
|
NamedItem(const nsAString& aName, bool aDoFlush);
|
|
|
|
// nsIMutationObserver
|
|
NS_DECL_NSIMUTATIONOBSERVER_ATTRIBUTECHANGED
|
|
NS_DECL_NSIMUTATIONOBSERVER_CONTENTAPPENDED
|
|
NS_DECL_NSIMUTATIONOBSERVER_CONTENTINSERTED
|
|
NS_DECL_NSIMUTATIONOBSERVER_CONTENTREMOVED
|
|
NS_DECL_NSIMUTATIONOBSERVER_NODEWILLBEDESTROYED
|
|
|
|
static nsContentList* FromSupports(nsISupports* aSupports)
|
|
{
|
|
nsINodeList* list = static_cast<nsINodeList*>(aSupports);
|
|
#ifdef DEBUG
|
|
{
|
|
nsCOMPtr<nsINodeList> list_qi = do_QueryInterface(aSupports);
|
|
|
|
// If this assertion fires the QI implementation for the object in
|
|
// question doesn't use the nsINodeList pointer as the nsISupports
|
|
// pointer. That must be fixed, or we'll crash...
|
|
NS_ASSERTION(list_qi == list, "Uh, fix QI!");
|
|
}
|
|
#endif
|
|
return static_cast<nsContentList*>(list);
|
|
}
|
|
|
|
bool MatchesKey(const nsContentListKey& aKey) const
|
|
{
|
|
// The root node is most commonly the same: the document. And the
|
|
// most common namespace id is kNameSpaceID_Unknown. So check the
|
|
// string first. Cases in which whether our root's ownerDocument
|
|
// is HTML changes are extremely rare, so check those last.
|
|
NS_PRECONDITION(mXMLMatchAtom,
|
|
"How did we get here with a null match atom on our list?");
|
|
return
|
|
mXMLMatchAtom->Equals(aKey.mTagname) &&
|
|
mRootNode == aKey.mRootNode &&
|
|
mMatchNameSpaceId == aKey.mMatchNameSpaceId &&
|
|
mIsHTMLDocument == aKey.mIsHTMLDocument;
|
|
}
|
|
|
|
/**
|
|
* Sets the state to LIST_DIRTY and clears mElements array.
|
|
* @note This is the only acceptable way to set state to LIST_DIRTY.
|
|
*/
|
|
void SetDirty()
|
|
{
|
|
mState = LIST_DIRTY;
|
|
Reset();
|
|
}
|
|
|
|
virtual void LastRelease() override;
|
|
|
|
protected:
|
|
/**
|
|
* Returns whether the element matches our criterion
|
|
*
|
|
* @param aElement the element to attempt to match
|
|
* @return whether we match
|
|
*/
|
|
bool Match(mozilla::dom::Element *aElement);
|
|
/**
|
|
* See if anything in the subtree rooted at aContent, including
|
|
* aContent itself, matches our criterion.
|
|
*
|
|
* @param aContent the root of the subtree to match against
|
|
* @return whether we match something in the tree rooted at aContent
|
|
*/
|
|
bool MatchSelf(nsIContent *aContent);
|
|
|
|
/**
|
|
* Populate our list. Stop once we have at least aNeededLength
|
|
* elements. At the end of PopulateSelf running, either the last
|
|
* node we examined is the last node in our array or we have
|
|
* traversed the whole document (or both).
|
|
*
|
|
* @param aNeededLength the length the list should have when we are
|
|
* done (unless it exhausts the document)
|
|
*/
|
|
void PopulateSelf(uint32_t aNeededLength);
|
|
|
|
/**
|
|
* @param aContainer a content node which must be a descendant of
|
|
* mRootNode
|
|
* @return true if children or descendants of aContainer could match our
|
|
* criterion.
|
|
* false otherwise.
|
|
*/
|
|
bool MayContainRelevantNodes(nsINode* aContainer)
|
|
{
|
|
return mDeep || aContainer == mRootNode;
|
|
}
|
|
|
|
/**
|
|
* Remove ourselves from the hashtable that caches commonly accessed
|
|
* content lists. Generally done on destruction.
|
|
*/
|
|
void RemoveFromHashtable();
|
|
/**
|
|
* If state is not LIST_UP_TO_DATE, fully populate ourselves with
|
|
* all the nodes we can find.
|
|
*/
|
|
inline void BringSelfUpToDate(bool aDoFlush);
|
|
|
|
/**
|
|
* To be called from non-destructor locations that want to remove from caches.
|
|
* Needed because if subclasses want to have cache behavior they can't just
|
|
* override RemoveFromHashtable(), since we call that in our destructor.
|
|
*/
|
|
virtual void RemoveFromCaches() override
|
|
{
|
|
RemoveFromHashtable();
|
|
}
|
|
|
|
nsINode* mRootNode; // Weak ref
|
|
int32_t mMatchNameSpaceId;
|
|
nsCOMPtr<nsIAtom> mHTMLMatchAtom;
|
|
nsCOMPtr<nsIAtom> mXMLMatchAtom;
|
|
|
|
/**
|
|
* Function to use to determine whether a piece of content matches
|
|
* our criterion
|
|
*/
|
|
nsContentListMatchFunc mFunc;
|
|
/**
|
|
* Cleanup closure data with this.
|
|
*/
|
|
nsContentListDestroyFunc mDestroyFunc;
|
|
/**
|
|
* Closure data to pass to mFunc when we call it
|
|
*/
|
|
void* mData;
|
|
/**
|
|
* The current state of the list (possible values are:
|
|
* LIST_UP_TO_DATE, LIST_LAZY, LIST_DIRTY
|
|
*/
|
|
uint8_t mState;
|
|
|
|
// The booleans have to use uint8_t to pack with mState, because MSVC won't
|
|
// pack different typedefs together. Once we no longer have to worry about
|
|
// flushes in XML documents, we can go back to using bool for the
|
|
// booleans.
|
|
|
|
/**
|
|
* True if we are looking for elements named "*"
|
|
*/
|
|
uint8_t mMatchAll : 1;
|
|
/**
|
|
* Whether to actually descend the tree. If this is false, we won't
|
|
* consider grandkids of mRootNode.
|
|
*/
|
|
uint8_t mDeep : 1;
|
|
/**
|
|
* Whether the return value of mFunc could depend on the values of
|
|
* attributes.
|
|
*/
|
|
uint8_t mFuncMayDependOnAttr : 1;
|
|
/**
|
|
* Whether we actually need to flush to get our state correct.
|
|
*/
|
|
uint8_t mFlushesNeeded : 1;
|
|
/**
|
|
* Whether the ownerDocument of our root node at list creation time was an
|
|
* HTML document. Only needed when we're doing a namespace/atom match, not
|
|
* when doing function matching, always false otherwise.
|
|
*/
|
|
uint8_t mIsHTMLDocument : 1;
|
|
|
|
#ifdef DEBUG_CONTENT_LIST
|
|
void AssertInSync();
|
|
#endif
|
|
};
|
|
|
|
/**
|
|
* A class of cacheable content list; cached on the combination of aRootNode + aFunc + aDataString
|
|
*/
|
|
class nsCacheableFuncStringContentList;
|
|
|
|
class MOZ_STACK_CLASS nsFuncStringCacheKey {
|
|
public:
|
|
nsFuncStringCacheKey(nsINode* aRootNode,
|
|
nsContentListMatchFunc aFunc,
|
|
const nsAString& aString) :
|
|
mRootNode(aRootNode),
|
|
mFunc(aFunc),
|
|
mString(aString)
|
|
{}
|
|
|
|
uint32_t GetHash(void) const
|
|
{
|
|
uint32_t hash = mozilla::HashString(mString);
|
|
return mozilla::AddToHash(hash, mRootNode, mFunc);
|
|
}
|
|
|
|
private:
|
|
friend class nsCacheableFuncStringContentList;
|
|
|
|
nsINode* const mRootNode;
|
|
const nsContentListMatchFunc mFunc;
|
|
const nsAString& mString;
|
|
};
|
|
|
|
// aDestroyFunc is allowed to be null
|
|
// aDataAllocator must always return a non-null pointer
|
|
class nsCacheableFuncStringContentList : public nsContentList {
|
|
public:
|
|
virtual ~nsCacheableFuncStringContentList();
|
|
|
|
bool Equals(const nsFuncStringCacheKey* aKey) {
|
|
return mRootNode == aKey->mRootNode && mFunc == aKey->mFunc &&
|
|
mString == aKey->mString;
|
|
}
|
|
|
|
#ifdef DEBUG
|
|
enum ContentListType {
|
|
eNodeList,
|
|
eHTMLCollection
|
|
};
|
|
ContentListType mType;
|
|
#endif
|
|
|
|
protected:
|
|
nsCacheableFuncStringContentList(nsINode* aRootNode,
|
|
nsContentListMatchFunc aFunc,
|
|
nsContentListDestroyFunc aDestroyFunc,
|
|
nsFuncStringContentListDataAllocator aDataAllocator,
|
|
const nsAString& aString) :
|
|
nsContentList(aRootNode, aFunc, aDestroyFunc, nullptr),
|
|
mString(aString)
|
|
{
|
|
mData = (*aDataAllocator)(aRootNode, &mString);
|
|
MOZ_ASSERT(mData);
|
|
}
|
|
|
|
virtual void RemoveFromCaches() override {
|
|
RemoveFromFuncStringHashtable();
|
|
}
|
|
void RemoveFromFuncStringHashtable();
|
|
|
|
nsString mString;
|
|
};
|
|
|
|
class nsCacheableFuncStringNodeList
|
|
: public nsCacheableFuncStringContentList
|
|
{
|
|
public:
|
|
nsCacheableFuncStringNodeList(nsINode* aRootNode,
|
|
nsContentListMatchFunc aFunc,
|
|
nsContentListDestroyFunc aDestroyFunc,
|
|
nsFuncStringContentListDataAllocator aDataAllocator,
|
|
const nsAString& aString)
|
|
: nsCacheableFuncStringContentList(aRootNode, aFunc, aDestroyFunc,
|
|
aDataAllocator, aString)
|
|
{
|
|
#ifdef DEBUG
|
|
mType = eNodeList;
|
|
#endif
|
|
}
|
|
|
|
virtual JSObject* WrapObject(JSContext *cx, JS::Handle<JSObject*> aGivenProto) override;
|
|
|
|
#ifdef DEBUG
|
|
static const ContentListType sType;
|
|
#endif
|
|
};
|
|
|
|
class nsCacheableFuncStringHTMLCollection
|
|
: public nsCacheableFuncStringContentList
|
|
{
|
|
public:
|
|
nsCacheableFuncStringHTMLCollection(nsINode* aRootNode,
|
|
nsContentListMatchFunc aFunc,
|
|
nsContentListDestroyFunc aDestroyFunc,
|
|
nsFuncStringContentListDataAllocator aDataAllocator,
|
|
const nsAString& aString)
|
|
: nsCacheableFuncStringContentList(aRootNode, aFunc, aDestroyFunc,
|
|
aDataAllocator, aString)
|
|
{
|
|
#ifdef DEBUG
|
|
mType = eHTMLCollection;
|
|
#endif
|
|
}
|
|
|
|
virtual JSObject* WrapObject(JSContext *cx, JS::Handle<JSObject*> aGivenProto) override;
|
|
|
|
#ifdef DEBUG
|
|
static const ContentListType sType;
|
|
#endif
|
|
};
|
|
|
|
#endif // nsContentList_h___
|