AMTL updates and changes to adapt for them to fix menu crashes (bug 5921, r=psychonic).

AMTL:
Removes isVoid from AString.
Fixes support inserting to Vector at length.

--HG--
extra : rebase_source : 02805fad60c2b759a0e2e91c081144854a8e0b54
This commit is contained in:
David Anderson 2013-11-30 10:51:28 -05:00
parent fa057e76f3
commit f0e4fe66ba
7 changed files with 43 additions and 37 deletions

View File

@ -636,10 +636,10 @@ bool CBaseMenu::AppendItem(const char *info, const ItemDrawInfo &draw)
item.info = info;
if (draw.display)
item.display = draw.display;
item.display = new ke::AString(draw.display);
item.style = draw.style;
m_items.append(item);
m_items.append(ke::Move(item));
return true;
}
@ -657,10 +657,10 @@ bool CBaseMenu::InsertItem(unsigned int position, const char *info, const ItemDr
CItem item;
item.info = info;
if (draw.display)
item.display = draw.display;
item.display = new ke::AString(draw.display);
item.style = draw.style;
m_items.insert(position, item);
m_items.insert(position, ke::Move(item));
return true;
}
@ -685,7 +685,7 @@ const char *CBaseMenu::GetItemInfo(unsigned int position, ItemDrawInfo *draw/* =
if (draw)
{
draw->display = m_items[position].display.chars();
draw->display = m_items[position].display->chars();
draw->style = m_items[position].style;
}

View File

@ -45,8 +45,6 @@ class CItem
public:
CItem()
{
info.setVoid();
display.setVoid();
style = 0;
access = 0;
}
@ -57,11 +55,24 @@ public:
style = other->style;
access = other->access;
}
CItem & operator =(ke::Moveable<CItem> other)
{
info = ke::Move(other->info);
display = ke::Move(other->display);
style = other->style;
access = other->access;
return *this;
}
public:
ke::AString info;
ke::AString display;
ke::AutoPtr<ke::AString> display;
unsigned int style;
unsigned int access;
private:
CItem(const CItem &other) KE_DELETE;
CItem &operator =(const CItem &other) KE_DELETE;
};
class CBaseMenuPlayer

View File

@ -204,10 +204,8 @@ HandleType_t HandleSystem::CreateType(const char *name,
pType->dispatch = dispatch;
if (name && name[0] != '\0')
{
pType->name = name;
pType->name = new ke::AString(name);
m_TypeLookup.insert(name, pType);
} else {
pType->name.setVoid();
}
pType->opened = 0;
@ -924,8 +922,8 @@ bool HandleSystem::RemoveType(HandleType_t type, IdentityToken_t *ident)
pType->dispatch = NULL;
/* Remove it from the type cache. */
if (!pType->name.isVoid())
m_TypeLookup.remove(pType->name.chars());
if (pType->name)
m_TypeLookup.remove(pType->name->chars());
return true;
}
@ -1050,8 +1048,8 @@ bool HandleSystem::TryAndFreeSomeHandles()
continue; /* We may have gaps, it's fine. */
}
if (!m_Types[i].name.isVoid())
pTypeName = m_Types[i].name.chars();
if (m_Types[i].name)
pTypeName = m_Types[i].name->chars();
else
pTypeName = "ANON";
@ -1118,8 +1116,8 @@ void HandleSystem::Dump(HANDLE_REPORTER rep)
unsigned int size = 0;
unsigned int parentIdx;
bool bresult;
if (!pType->name.isVoid())
type = pType->name.chars();
if (pType->name)
type = pType->name->chars();
if ((parentIdx = m_Handles[i].clone) != 0)
{

View File

@ -103,11 +103,11 @@ struct QHandleType
TypeAccess typeSec;
HandleAccess hndlSec;
unsigned int opened;
ke::AString name;
ke::AutoPtr<ke::AString> name;
static inline bool matches(const char *key, const QHandleType *type)
{
return type->name.compare(key) == 0;
return type->name && type->name->compare(key) == 0;
}
};

View File

@ -104,29 +104,17 @@ class AString
return chars()[index];
}
void setVoid() {
chars_ = NULL;
length_ = kInvalidLength;
}
bool isVoid() const {
return length_ == kInvalidLength;
}
size_t length() const {
assert(!isVoid());
return length_;
}
const char *chars() const {
if (!chars_)
return isVoid() ? NULL : "";
return "";
return chars_;
}
private:
static const size_t kInvalidLength = (size_t)-1;
void set(const char *str, size_t length) {
chars_ = new char[length + 1];
length_ = length;

View File

@ -91,7 +91,7 @@ class AutoPtr
: t_(t)
{
}
AutoPtr(Moveable<AutoPtr<T> > &other)
AutoPtr(Moveable<AutoPtr<T> > other)
{
t_ = other->t_;
other->t_ = NULL;
@ -116,7 +116,7 @@ class AutoPtr
t_ = t;
return t_;
}
T *operator =(Moveable<AutoPtr<T> > &other) {
T *operator =(Moveable<AutoPtr<T> > other) {
delete t_;
t_ = other->t_;
other->t_ = NULL;

View File

@ -86,14 +86,22 @@ class Vector : public AllocPolicy
}
// Shift all elements including |at| up by one, and insert |item| at the
// given position. This is a linear-time operation.
// given position. If |at| is one greater than the last usable index,
// i.e. |at == length()|, then this is the same as append(). No other
// invalid indexes are allowed.
//
// This is a linear-time operation.
bool insert(size_t at, const T &item) {
if (at == length())
return append(item);
if (!moveUp(at))
return false;
new (&data_[at]) T(item);
return true;
}
bool insert(size_t at, Moveable<T> item) {
if (at == length())
return append(item);
if (!moveUp(at))
return false;
new (&data_[at]) T(item);
@ -104,7 +112,7 @@ class Vector : public AllocPolicy
// element. This is a linear-time operation.
void remove(size_t at) {
for (size_t i = at; i < length() - 1; i++)
data_[i] = T(Moveable<T>(data_[i + 1]));
data_[i] = Moveable<T>(data_[i + 1]);
pop();
}
@ -178,11 +186,12 @@ class Vector : public AllocPolicy
}
bool moveUp(size_t at) {
assert(at < nitems_);
if (!growIfNeeded(1))
return false;
nitems_++;
for (size_t i = nitems_ - 1; i > at; i--)
data_[i] = T(Moveable<T>(data_[i - 1]));
data_[i] = Moveable<T>(data_[i - 1]);
return true;
}