mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:30:27 +00:00
1367963d3d
- Bug 1198124 - Enable -Wshadow in directories that have no -Wshadow warnings. r=glandium (d03cfc1bb6) - Bug 1204403 - Fix -Wshadow warnings in xpcom. r=mccr8 (3247b5b146) - Bug 1140120 - Remove a couple of unused test functions on ServiceWorkerContainer; r=baku (efe1119749) - Bug 1180148 - Clear service workers registered for a site when clearing the cookies and stored data is not working in b2g. r=baku (7fb1d522ff) - Bug 1162333 - Add stronger assertions to PromiseWorkerProxy in debug builds. r=catalinb (0005a76252) - Bug 1190672 - Fix use of AutoReleasePromiseWorkerProxy in PushManager. r=catalinb (18f7358163) - Bug 1191495 - Relax PushManager callback assertions. r=kitcambridge (8a3822969f) - Bug 1189543 - pushManager.getSubscription() should return null for nonexistent push subscriptions in workers. r=nsm (b990083262) - spacing (44b87017a7) - Bug 1180295 - Rip out the Fennec code to set the screen render offset. r=rbarker (67183ae8bf) - Bug 1187804 - Un-adjust fixed layers by the async transform of the scroll frame that they're fixed with respect to, not of the nearest ancestor scroll frame. r=kats (7c5e7ac29c) - Bug 1131359 - Fix an include-what-you-use error in AsyncCompositionManager.cpp. r=kats (fe04815939) - Bug 1187804 - When a layer is scrolled by multiple scroll frames, do an AlignFixedAndStickyLayers pass on its subtree for each of the scroll frames. r=kats (031a5686f1) - Bug 1180295 - Stop clipping the content while the toolbar is in the process of sliding off. r=rbarker (9d806870e4) - Bug 1186968 - Fix Compositor::SetScreenRotation() call r=nical (e554c4b4a2) - Bug 1180295 - Implement seamless snapping to the stable state. r=rbarker (d1e7978eb7) - Bug 1131470 - Part 1: Rename existing use of ScreenOrientation to ScreenOrientationInternal. r=baku (63f0cb994b) - Bug 1131470 - Part 2: Update screen configuration HAL to report orientation angle. r=snorp,mwu (39b537f008) - Bug 1167597 - Mark PromiseReportRejectFeature::mPromise as MOZ_NON_OWNING_REF. r=ehsan (3ad520790a) - Bug 1086627 - Rename Promise constructs to more closely match the specification. r=nsm,jst (cea1d71cb1) - Bug 1086627 - Rename ThenableResolverTask to PromiseResolveThenableJob to more closely match Promise spec. r=nsm (e7102fe506) - Bug 1164725 - Convert flags in nsIDocument into bit fields. r=smaug (9f5d5f352d) - Bug 1192467 - Formalize precondition that SetDisplayDocument must not be called with null. - r=peterv (1aa8e91d14) - Bug 1153841 - Remove the 'it must be 2D' restriction for transforms on fixed-pos layers. r=BenWa,mattwoodrow (5bab86ec6a) - Bug 1173521 - Properly handle unapplying 3D projective transforms to rectangles in APZ code. r=botond (45c9850d5c) - Bug 1166301 - When applying an async adjustment to a fixed layer, only adjust its mask layer under the same circumstances as its clip rect. r=mattwoodrow (2801c48fe9) - Bug 1166301 - Update an old comment in AsyncCompositionManager::AlignFixedAndStickyLayers. r=kats (7e1d5c97d0) - Bug 1166301 - Allow async scrolling to move the clip rects of fixed background layers. r=mattwoodrow (edd889ec2b) - Bug 1200399 - Only send the RCD's metrics to Java-land for fennec-apz. r=rbarker (3b36a52f3a) - Bug 1201625 - Special-case B2GDroid since it doesn't have a root content document. r=rbarker (4fcdda1b0a) - Bug 1201529 - Fall back to rootmost metrics if there is no root content document metrics. r=botond (615c2ee727) - Bug 1201581 - Extract a helper method. r=rbarker (f2cccb8666) - Bug 1201581 - Hook up the syncFrameMetrics call to sync metrics info from the compositor to Java-land on each composite. r=rbarker (48e15bbde8) - Bug 1203760 P1 Allow pipe to wake up multiple streams at the same time. r=froydnj (5baed00637) - Bug 1203760 P2 Add gtests for nsPipeInputStream AsyncRead(). r=froydnj (52e5129dc8) - Bug 1201889 - When adjusting fixed and sticky layers in AsyncCompsitionManager, unapply all async transforms on the path from the fixed layer to the layer it's fixed with respect to. r=kats (dbb203178e) - Bug 1165536. Don't include resolution compensation when adjusting the cliprect of ancestors of scrollbars. r=botond (3bef5f2c18) - Fix async transforms on scrollbars not including any existing shadow transform. (bug 1128740 part 2, r=botond) (af12d76775) - missing of Bug 943728 - Replace double quotes with single quotes in Makefiles (e11470540f) - Bug 1188766 - Avoid exporting UPLOAD_EXTRA_FILES from mozconfig. r=mshal (4241b9e80b) - Fixup for bug 1188766 for valgrind bustage on a CLOSED TREE. r=me (4401dedf06) - Bug 1077622 - Fixes cp missing operand message if no .mozconfig found r=glandium (6eca1e5214) - Bug 1200523 - Remove leftover debugging code from js/src/Makefile.in; r=ted (414b72c74e) - spacing (99cda3f8a7)
680 lines
16 KiB
C++
680 lines
16 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/. */
|
|
|
|
#include "nsTHashtable.h"
|
|
#include "nsBaseHashtable.h"
|
|
#include "nsDataHashtable.h"
|
|
#include "nsInterfaceHashtable.h"
|
|
#include "nsClassHashtable.h"
|
|
|
|
#include "nsCOMPtr.h"
|
|
#include "nsISupports.h"
|
|
#include "nsCOMArray.h"
|
|
#include "mozilla/Attributes.h"
|
|
|
|
#include <stdio.h>
|
|
|
|
namespace TestHashtables {
|
|
|
|
class TestUniChar // for nsClassHashtable
|
|
{
|
|
public:
|
|
explicit TestUniChar(uint32_t aWord)
|
|
{
|
|
printf(" TestUniChar::TestUniChar() %u\n", aWord);
|
|
mWord = aWord;
|
|
}
|
|
|
|
~TestUniChar()
|
|
{
|
|
printf(" TestUniChar::~TestUniChar() %u\n", mWord);
|
|
}
|
|
|
|
uint32_t GetChar() const { return mWord; }
|
|
|
|
private:
|
|
uint32_t mWord;
|
|
};
|
|
|
|
struct EntityNode {
|
|
const char* mStr; // never owns buffer
|
|
uint32_t mUnicode;
|
|
};
|
|
|
|
EntityNode gEntities[] = {
|
|
{"nbsp",160},
|
|
{"iexcl",161},
|
|
{"cent",162},
|
|
{"pound",163},
|
|
{"curren",164},
|
|
{"yen",165},
|
|
{"brvbar",166},
|
|
{"sect",167},
|
|
{"uml",168},
|
|
{"copy",169},
|
|
{"ordf",170},
|
|
{"laquo",171},
|
|
{"not",172},
|
|
{"shy",173},
|
|
{"reg",174},
|
|
{"macr",175}
|
|
};
|
|
|
|
#define ENTITY_COUNT (unsigned(sizeof(gEntities)/sizeof(EntityNode)))
|
|
|
|
class EntityToUnicodeEntry : public PLDHashEntryHdr
|
|
{
|
|
public:
|
|
typedef const char* KeyType;
|
|
typedef const char* KeyTypePointer;
|
|
|
|
explicit EntityToUnicodeEntry(const char* aKey) { mNode = nullptr; }
|
|
EntityToUnicodeEntry(const EntityToUnicodeEntry& aEntry) { mNode = aEntry.mNode; }
|
|
~EntityToUnicodeEntry() { }
|
|
|
|
bool KeyEquals(const char* aEntity) const { return !strcmp(mNode->mStr, aEntity); }
|
|
static const char* KeyToPointer(const char* aEntity) { return aEntity; }
|
|
static PLDHashNumber HashKey(const char* aEntity) { return mozilla::HashString(aEntity); }
|
|
enum { ALLOW_MEMMOVE = true };
|
|
|
|
const EntityNode* mNode;
|
|
};
|
|
|
|
static uint32_t
|
|
nsTIterPrint(nsTHashtable<EntityToUnicodeEntry>& hash)
|
|
{
|
|
uint32_t n = 0;
|
|
for (auto iter = hash.Iter(); !iter.Done(); iter.Next()) {
|
|
EntityToUnicodeEntry* entry = iter.Get();
|
|
printf(" enumerated \"%s\" = %u\n",
|
|
entry->mNode->mStr, entry->mNode->mUnicode);
|
|
n++;
|
|
}
|
|
return n;
|
|
}
|
|
|
|
static uint32_t
|
|
nsTIterPrintRemove(nsTHashtable<EntityToUnicodeEntry>& hash)
|
|
{
|
|
uint32_t n = 0;
|
|
for (auto iter = hash.Iter(); !iter.Done(); iter.Next()) {
|
|
EntityToUnicodeEntry* entry = iter.Get();
|
|
printf(" enumerated \"%s\" = %u\n",
|
|
entry->mNode->mStr, entry->mNode->mUnicode);
|
|
iter.Remove();
|
|
n++;
|
|
}
|
|
return n;
|
|
}
|
|
|
|
void
|
|
testTHashtable(nsTHashtable<EntityToUnicodeEntry>& hash, uint32_t numEntries) {
|
|
printf("Filling hash with %d entries.\n", numEntries);
|
|
|
|
uint32_t i;
|
|
for (i = 0; i < numEntries; ++i) {
|
|
printf(" Putting entry \"%s\"...", gEntities[i].mStr);
|
|
EntityToUnicodeEntry* entry =
|
|
hash.PutEntry(gEntities[i].mStr);
|
|
|
|
if (!entry) {
|
|
printf("FAILED\n");
|
|
exit (2);
|
|
}
|
|
printf("OK...");
|
|
|
|
if (entry->mNode) {
|
|
printf("entry already exists!\n");
|
|
exit (3);
|
|
}
|
|
printf("\n");
|
|
|
|
entry->mNode = &gEntities[i];
|
|
}
|
|
|
|
printf("Testing Get:\n");
|
|
|
|
for (i = 0; i < numEntries; ++i) {
|
|
printf(" Getting entry \"%s\"...", gEntities[i].mStr);
|
|
EntityToUnicodeEntry* entry =
|
|
hash.GetEntry(gEntities[i].mStr);
|
|
|
|
if (!entry) {
|
|
printf("FAILED\n");
|
|
exit (4);
|
|
}
|
|
|
|
printf("Found %u\n", entry->mNode->mUnicode);
|
|
}
|
|
|
|
printf("Testing nonexistent entries...");
|
|
|
|
EntityToUnicodeEntry* entry =
|
|
hash.GetEntry("xxxy");
|
|
|
|
if (entry) {
|
|
printf("FOUND! BAD!\n");
|
|
exit (5);
|
|
}
|
|
|
|
printf("not found; good.\n");
|
|
|
|
printf("Enumerating:\n");
|
|
uint32_t count = nsTIterPrint(hash);
|
|
if (count != numEntries) {
|
|
printf(" Bad count!\n");
|
|
exit (6);
|
|
}
|
|
}
|
|
|
|
PLDHashOperator
|
|
nsDEnumRead(const uint32_t& aKey, const char* aData, void* userArg) {
|
|
printf(" enumerated %u = \"%s\"\n", aKey, aData);
|
|
return PL_DHASH_NEXT;
|
|
}
|
|
|
|
PLDHashOperator
|
|
nsDEnum(const uint32_t& aKey, const char*& aData, void* userArg) {
|
|
printf(" enumerated %u = \"%s\"\n", aKey, aData);
|
|
return PL_DHASH_NEXT;
|
|
}
|
|
|
|
PLDHashOperator
|
|
nsCEnumRead(const nsACString& aKey, TestUniChar* aData, void* userArg) {
|
|
printf(" enumerated \"%s\" = %c\n",
|
|
PromiseFlatCString(aKey).get(), aData->GetChar());
|
|
return PL_DHASH_NEXT;
|
|
}
|
|
|
|
PLDHashOperator
|
|
nsCEnum(const nsACString& aKey, nsAutoPtr<TestUniChar>& aData, void* userArg) {
|
|
printf(" enumerated \"%s\" = %c\n",
|
|
PromiseFlatCString(aKey).get(), aData->GetChar());
|
|
return PL_DHASH_NEXT;
|
|
}
|
|
|
|
//
|
|
// all this nsIFoo stuff was copied wholesale from TestCOMPtr.cpp
|
|
//
|
|
|
|
#define NS_IFOO_IID \
|
|
{ 0x6f7652e0, 0xee43, 0x11d1, \
|
|
{ 0x9c, 0xc3, 0x00, 0x60, 0x08, 0x8c, 0xa6, 0xb3 } }
|
|
|
|
class IFoo final : public nsISupports
|
|
{
|
|
public:
|
|
NS_DECLARE_STATIC_IID_ACCESSOR(NS_IFOO_IID)
|
|
|
|
IFoo();
|
|
|
|
NS_IMETHOD_(MozExternalRefCountType) AddRef();
|
|
NS_IMETHOD_(MozExternalRefCountType) Release();
|
|
NS_IMETHOD QueryInterface( const nsIID&, void** );
|
|
|
|
NS_IMETHOD SetString(const nsACString& /*in*/ aString);
|
|
NS_IMETHOD GetString(nsACString& /*out*/ aString);
|
|
|
|
static void print_totals();
|
|
|
|
private:
|
|
~IFoo();
|
|
|
|
unsigned int refcount_;
|
|
|
|
static unsigned int total_constructions_;
|
|
static unsigned int total_destructions_;
|
|
nsCString mString;
|
|
};
|
|
|
|
NS_DEFINE_STATIC_IID_ACCESSOR(IFoo, NS_IFOO_IID)
|
|
|
|
unsigned int IFoo::total_constructions_;
|
|
unsigned int IFoo::total_destructions_;
|
|
|
|
void
|
|
IFoo::print_totals()
|
|
{
|
|
printf("total constructions/destructions --> %d/%d\n",
|
|
total_constructions_, total_destructions_);
|
|
}
|
|
|
|
IFoo::IFoo()
|
|
: refcount_(0)
|
|
{
|
|
++total_constructions_;
|
|
printf(" new IFoo@%p [#%d]\n",
|
|
static_cast<void*>(this), total_constructions_);
|
|
}
|
|
|
|
IFoo::~IFoo()
|
|
{
|
|
++total_destructions_;
|
|
printf("IFoo@%p::~IFoo() [#%d]\n",
|
|
static_cast<void*>(this), total_destructions_);
|
|
}
|
|
|
|
MozExternalRefCountType
|
|
IFoo::AddRef()
|
|
{
|
|
++refcount_;
|
|
printf("IFoo@%p::AddRef(), refcount --> %d\n",
|
|
static_cast<void*>(this), refcount_);
|
|
return refcount_;
|
|
}
|
|
|
|
MozExternalRefCountType
|
|
IFoo::Release()
|
|
{
|
|
int newcount = --refcount_;
|
|
if ( newcount == 0 )
|
|
printf(">>");
|
|
|
|
printf("IFoo@%p::Release(), refcount --> %d\n",
|
|
static_cast<void*>(this), refcount_);
|
|
|
|
if ( newcount == 0 )
|
|
{
|
|
printf(" delete IFoo@%p\n", static_cast<void*>(this));
|
|
printf("<<IFoo@%p::Release()\n", static_cast<void*>(this));
|
|
delete this;
|
|
}
|
|
|
|
return newcount;
|
|
}
|
|
|
|
nsresult
|
|
IFoo::QueryInterface( const nsIID& aIID, void** aResult )
|
|
{
|
|
printf("IFoo@%p::QueryInterface()\n", static_cast<void*>(this));
|
|
nsISupports* rawPtr = 0;
|
|
nsresult status = NS_OK;
|
|
|
|
if ( aIID.Equals(NS_GET_IID(IFoo)) )
|
|
rawPtr = this;
|
|
else
|
|
{
|
|
nsID iid_of_ISupports = NS_ISUPPORTS_IID;
|
|
if ( aIID.Equals(iid_of_ISupports) )
|
|
rawPtr = static_cast<nsISupports*>(this);
|
|
else
|
|
status = NS_ERROR_NO_INTERFACE;
|
|
}
|
|
|
|
NS_IF_ADDREF(rawPtr);
|
|
*aResult = rawPtr;
|
|
|
|
return status;
|
|
}
|
|
|
|
nsresult
|
|
IFoo::SetString(const nsACString& aString)
|
|
{
|
|
mString = aString;
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult
|
|
IFoo::GetString(nsACString& aString)
|
|
{
|
|
aString = mString;
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult
|
|
CreateIFoo( IFoo** result )
|
|
// a typical factory function (that calls AddRef)
|
|
{
|
|
printf(" >>CreateIFoo() --> ");
|
|
IFoo* foop = new IFoo();
|
|
printf("IFoo@%p\n", static_cast<void*>(foop));
|
|
|
|
foop->AddRef();
|
|
*result = foop;
|
|
|
|
printf("<<CreateIFoo()\n");
|
|
return NS_OK;
|
|
}
|
|
|
|
PLDHashOperator
|
|
nsIEnumRead(const uint32_t& aKey, IFoo* aFoo, void* userArg) {
|
|
nsAutoCString str;
|
|
aFoo->GetString(str);
|
|
|
|
printf(" enumerated %u = \"%s\"\n", aKey, str.get());
|
|
return PL_DHASH_NEXT;
|
|
}
|
|
|
|
PLDHashOperator
|
|
nsIEnum(const uint32_t& aKey, nsCOMPtr<IFoo>& aData, void* userArg) {
|
|
nsAutoCString str;
|
|
aData->GetString(str);
|
|
|
|
printf(" enumerated %u = \"%s\"\n", aKey, str.get());
|
|
return PL_DHASH_NEXT;
|
|
}
|
|
|
|
PLDHashOperator
|
|
nsIEnum2Read(nsISupports* aKey, uint32_t aData, void* userArg) {
|
|
nsAutoCString str;
|
|
nsCOMPtr<IFoo> foo = do_QueryInterface(aKey);
|
|
foo->GetString(str);
|
|
|
|
|
|
printf(" enumerated \"%s\" = %u\n", str.get(), aData);
|
|
return PL_DHASH_NEXT;
|
|
}
|
|
|
|
PLDHashOperator
|
|
nsIEnum2(nsISupports* aKey, uint32_t& aData, void* userArg) {
|
|
nsAutoCString str;
|
|
nsCOMPtr<IFoo> foo = do_QueryInterface(aKey);
|
|
foo->GetString(str);
|
|
|
|
printf(" enumerated \"%s\" = %u\n", str.get(), aData);
|
|
return PL_DHASH_NEXT;
|
|
}
|
|
|
|
} // namespace TestHashtables
|
|
|
|
using namespace TestHashtables;
|
|
|
|
int
|
|
main(void) {
|
|
// check an nsTHashtable
|
|
printf("Initializing nsTHashtable...");
|
|
nsTHashtable<EntityToUnicodeEntry> EntityToUnicode(ENTITY_COUNT);
|
|
printf("OK\n");
|
|
|
|
printf("Partially filling nsTHashtable:\n");
|
|
testTHashtable(EntityToUnicode, 5);
|
|
|
|
printf("Enumerate-removing...\n");
|
|
uint32_t count = nsTIterPrintRemove(EntityToUnicode);
|
|
if (count != 5) {
|
|
printf("wrong count\n");
|
|
exit (7);
|
|
}
|
|
printf("OK\n");
|
|
|
|
printf("Check enumeration...");
|
|
count = nsTIterPrint(EntityToUnicode);
|
|
if (count) {
|
|
printf("entries remain in table!\n");
|
|
exit (8);
|
|
}
|
|
printf("OK\n");
|
|
|
|
printf("Filling nsTHashtable:\n");
|
|
testTHashtable(EntityToUnicode, ENTITY_COUNT);
|
|
|
|
printf("Clearing...");
|
|
EntityToUnicode.Clear();
|
|
printf("OK\n");
|
|
|
|
printf("Check enumeration...");
|
|
count = nsTIterPrint(EntityToUnicode);
|
|
if (count) {
|
|
printf("entries remain in table!\n");
|
|
exit (9);
|
|
}
|
|
printf("OK\n");
|
|
|
|
//
|
|
// now check a data-hashtable
|
|
//
|
|
|
|
printf("Initializing nsDataHashtable...");
|
|
nsDataHashtable<nsUint32HashKey,const char*> UniToEntity(ENTITY_COUNT);
|
|
printf("OK\n");
|
|
|
|
printf("Filling hash with %u entries.\n", ENTITY_COUNT);
|
|
|
|
uint32_t i;
|
|
for (i = 0; i < ENTITY_COUNT; ++i) {
|
|
printf(" Putting entry %u...", gEntities[i].mUnicode);
|
|
UniToEntity.Put(gEntities[i].mUnicode, gEntities[i].mStr);
|
|
printf("OK...\n");
|
|
}
|
|
|
|
printf("Testing Get:\n");
|
|
const char* str;
|
|
|
|
for (i = 0; i < ENTITY_COUNT; ++i) {
|
|
printf(" Getting entry %u...", gEntities[i].mUnicode);
|
|
if (!UniToEntity.Get(gEntities[i].mUnicode, &str)) {
|
|
printf("FAILED\n");
|
|
exit (12);
|
|
}
|
|
|
|
printf("Found %s\n", str);
|
|
}
|
|
|
|
printf("Testing nonexistent entries...");
|
|
if (UniToEntity.Get(99446, &str)) {
|
|
printf("FOUND! BAD!\n");
|
|
exit (13);
|
|
}
|
|
|
|
printf("not found; good.\n");
|
|
|
|
printf("Enumerating:\n");
|
|
|
|
count = UniToEntity.EnumerateRead(nsDEnumRead, nullptr);
|
|
if (count != ENTITY_COUNT) {
|
|
printf(" Bad count!\n");
|
|
exit (14);
|
|
}
|
|
|
|
printf("Clearing...");
|
|
UniToEntity.Clear();
|
|
printf("OK\n");
|
|
|
|
printf("Checking count...");
|
|
count = UniToEntity.Enumerate(nsDEnum, nullptr);
|
|
if (count) {
|
|
printf(" Clear did not remove all entries.\n");
|
|
exit (15);
|
|
}
|
|
|
|
printf("OK\n");
|
|
|
|
//
|
|
// now check a class-hashtable
|
|
//
|
|
|
|
printf("Initializing nsClassHashtable...");
|
|
nsClassHashtable<nsCStringHashKey,TestUniChar> EntToUniClass(ENTITY_COUNT);
|
|
printf("OK\n");
|
|
|
|
printf("Filling hash with %u entries.\n", ENTITY_COUNT);
|
|
|
|
for (i = 0; i < ENTITY_COUNT; ++i) {
|
|
printf(" Putting entry %u...", gEntities[i].mUnicode);
|
|
TestUniChar* temp = new TestUniChar(gEntities[i].mUnicode);
|
|
|
|
EntToUniClass.Put(nsDependentCString(gEntities[i].mStr), temp);
|
|
printf("OK...\n");
|
|
}
|
|
|
|
printf("Testing Get:\n");
|
|
TestUniChar* myChar;
|
|
|
|
for (i = 0; i < ENTITY_COUNT; ++i) {
|
|
printf(" Getting entry %s...", gEntities[i].mStr);
|
|
if (!EntToUniClass.Get(nsDependentCString(gEntities[i].mStr), &myChar)) {
|
|
printf("FAILED\n");
|
|
exit (18);
|
|
}
|
|
|
|
printf("Found %c\n", myChar->GetChar());
|
|
}
|
|
|
|
printf("Testing nonexistent entries...");
|
|
if (EntToUniClass.Get(NS_LITERAL_CSTRING("xxxx"), &myChar)) {
|
|
printf("FOUND! BAD!\n");
|
|
exit (19);
|
|
}
|
|
|
|
printf("not found; good.\n");
|
|
|
|
printf("Enumerating:\n");
|
|
|
|
count = EntToUniClass.EnumerateRead(nsCEnumRead, nullptr);
|
|
if (count != ENTITY_COUNT) {
|
|
printf(" Bad count!\n");
|
|
exit (20);
|
|
}
|
|
|
|
printf("Clearing...\n");
|
|
EntToUniClass.Clear();
|
|
printf(" Clearing OK\n");
|
|
|
|
printf("Checking count...");
|
|
count = EntToUniClass.Enumerate(nsCEnum, nullptr);
|
|
if (count) {
|
|
printf(" Clear did not remove all entries.\n");
|
|
exit (21);
|
|
}
|
|
|
|
printf("OK\n");
|
|
|
|
//
|
|
// now check a data-hashtable with an interface key
|
|
//
|
|
|
|
printf("Initializing nsDataHashtable with interface key...");
|
|
nsDataHashtable<nsISupportsHashKey,uint32_t> EntToUniClass2(ENTITY_COUNT);
|
|
printf("OK\n");
|
|
|
|
printf("Filling hash with %u entries.\n", ENTITY_COUNT);
|
|
|
|
nsCOMArray<IFoo> fooArray;
|
|
|
|
for (i = 0; i < ENTITY_COUNT; ++i) {
|
|
printf(" Putting entry %u...", gEntities[i].mUnicode);
|
|
nsCOMPtr<IFoo> foo;
|
|
CreateIFoo(getter_AddRefs(foo));
|
|
foo->SetString(nsDependentCString(gEntities[i].mStr));
|
|
|
|
fooArray.InsertObjectAt(foo, i);
|
|
|
|
EntToUniClass2.Put(foo, gEntities[i].mUnicode);
|
|
printf("OK...\n");
|
|
}
|
|
|
|
printf("Testing Get:\n");
|
|
uint32_t myChar2;
|
|
|
|
for (i = 0; i < ENTITY_COUNT; ++i) {
|
|
printf(" Getting entry %s...", gEntities[i].mStr);
|
|
|
|
if (!EntToUniClass2.Get(fooArray[i], &myChar2)) {
|
|
printf("FAILED\n");
|
|
exit (24);
|
|
}
|
|
|
|
printf("Found %c\n", myChar2);
|
|
}
|
|
|
|
printf("Testing nonexistent entries...");
|
|
if (EntToUniClass2.Get((nsISupports*) 0x55443316, &myChar2)) {
|
|
printf("FOUND! BAD!\n");
|
|
exit (25);
|
|
}
|
|
|
|
printf("not found; good.\n");
|
|
|
|
printf("Enumerating:\n");
|
|
|
|
count = EntToUniClass2.EnumerateRead(nsIEnum2Read, nullptr);
|
|
if (count != ENTITY_COUNT) {
|
|
printf(" Bad count!\n");
|
|
exit (26);
|
|
}
|
|
|
|
printf("Clearing...\n");
|
|
EntToUniClass2.Clear();
|
|
printf(" Clearing OK\n");
|
|
|
|
printf("Checking count...");
|
|
count = EntToUniClass2.Enumerate(nsIEnum2, nullptr);
|
|
if (count) {
|
|
printf(" Clear did not remove all entries.\n");
|
|
exit (27);
|
|
}
|
|
|
|
printf("OK\n");
|
|
|
|
//
|
|
// now check an interface-hashtable with an uint32_t key
|
|
//
|
|
|
|
printf("Initializing nsInterfaceHashtable...");
|
|
nsInterfaceHashtable<nsUint32HashKey,IFoo> UniToEntClass2(ENTITY_COUNT);
|
|
printf("OK\n");
|
|
|
|
printf("Filling hash with %u entries.\n", ENTITY_COUNT);
|
|
|
|
for (i = 0; i < ENTITY_COUNT; ++i) {
|
|
printf(" Putting entry %u...", gEntities[i].mUnicode);
|
|
nsCOMPtr<IFoo> foo;
|
|
CreateIFoo(getter_AddRefs(foo));
|
|
foo->SetString(nsDependentCString(gEntities[i].mStr));
|
|
|
|
UniToEntClass2.Put(gEntities[i].mUnicode, foo);
|
|
printf("OK...\n");
|
|
}
|
|
|
|
printf("Testing Get:\n");
|
|
|
|
for (i = 0; i < ENTITY_COUNT; ++i) {
|
|
printf(" Getting entry %s...", gEntities[i].mStr);
|
|
|
|
nsCOMPtr<IFoo> myEnt;
|
|
if (!UniToEntClass2.Get(gEntities[i].mUnicode, getter_AddRefs(myEnt))) {
|
|
printf("FAILED\n");
|
|
exit (30);
|
|
}
|
|
|
|
nsAutoCString myEntStr;
|
|
myEnt->GetString(myEntStr);
|
|
printf("Found %s\n", myEntStr.get());
|
|
}
|
|
|
|
printf("Testing nonexistent entries...");
|
|
nsCOMPtr<IFoo> myEnt;
|
|
if (UniToEntClass2.Get(9462, getter_AddRefs(myEnt))) {
|
|
printf("FOUND! BAD!\n");
|
|
exit (31);
|
|
}
|
|
|
|
printf("not found; good.\n");
|
|
|
|
printf("Enumerating:\n");
|
|
|
|
count = UniToEntClass2.EnumerateRead(nsIEnumRead, nullptr);
|
|
if (count != ENTITY_COUNT) {
|
|
printf(" Bad count!\n");
|
|
exit (32);
|
|
}
|
|
|
|
printf("Clearing...\n");
|
|
UniToEntClass2.Clear();
|
|
printf(" Clearing OK\n");
|
|
|
|
printf("Checking count...");
|
|
count = UniToEntClass2.Enumerate(nsIEnum, nullptr);
|
|
if (count) {
|
|
printf(" Clear did not remove all entries.\n");
|
|
exit (33);
|
|
}
|
|
|
|
printf("OK\n");
|
|
|
|
return 0;
|
|
}
|