mirror of
https://github.com/rkd77/elinks.git
synced 2025-01-03 14:57:44 -05:00
[spidermonkey] Free strings allocated in get_elements_by_class_name
This commit is contained in:
parent
14c9eff83c
commit
88fdf42ade
@ -27,6 +27,7 @@
|
|||||||
#include "document/libdom/corestrings.h"
|
#include "document/libdom/corestrings.h"
|
||||||
#include "document/view.h"
|
#include "document/view.h"
|
||||||
#include "js/ecmascript.h"
|
#include "js/ecmascript.h"
|
||||||
|
#include "js/ecmascript-c.h"
|
||||||
#include "js/spidermonkey/collection.h"
|
#include "js/spidermonkey/collection.h"
|
||||||
#include "js/spidermonkey/element.h"
|
#include "js/spidermonkey/element.h"
|
||||||
#include "intl/libintl.h"
|
#include "intl/libintl.h"
|
||||||
@ -56,7 +57,8 @@
|
|||||||
enum {
|
enum {
|
||||||
SLOT_NODE = 0,
|
SLOT_NODE = 0,
|
||||||
SLOT_ITEM_NAMEDITEM,
|
SLOT_ITEM_NAMEDITEM,
|
||||||
SLOT_ARRAY
|
SLOT_ARRAY,
|
||||||
|
SLOT_WAS_CLASS_NAME
|
||||||
};
|
};
|
||||||
|
|
||||||
static bool htmlCollection2_item(JSContext *ctx, unsigned int argc, JS::Value *rval);
|
static bool htmlCollection2_item(JSContext *ctx, unsigned int argc, JS::Value *rval);
|
||||||
@ -69,12 +71,26 @@ static void htmlCollection_finalize(JS::GCContext *op, JSObject *obj)
|
|||||||
#ifdef ECMASCRIPT_DEBUG
|
#ifdef ECMASCRIPT_DEBUG
|
||||||
fprintf(stderr, "%s:%s\n", __FILE__, __FUNCTION__);
|
fprintf(stderr, "%s:%s\n", __FILE__, __FUNCTION__);
|
||||||
#endif
|
#endif
|
||||||
|
bool was_class_name = JS::GetReservedSlot(obj, SLOT_WAS_CLASS_NAME).toBoolean();
|
||||||
|
|
||||||
|
if (was_class_name) {
|
||||||
|
struct el_dom_html_collection *ns = JS::GetMaybePtrFromReservedSlot<el_dom_html_collection>(obj, SLOT_NODE);
|
||||||
|
|
||||||
|
if (ns) {
|
||||||
|
if (ns->refcnt > 0) {
|
||||||
|
free_el_dom_collection(ns->ctx);
|
||||||
|
ns->ctx = NULL;
|
||||||
|
dom_html_collection_unref((dom_html_collection *)ns);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
dom_html_collection *ns = JS::GetMaybePtrFromReservedSlot<dom_html_collection>(obj, SLOT_NODE);
|
dom_html_collection *ns = JS::GetMaybePtrFromReservedSlot<dom_html_collection>(obj, SLOT_NODE);
|
||||||
|
|
||||||
if (ns) {
|
if (ns) {
|
||||||
dom_html_collection_unref(ns);
|
dom_html_collection_unref(ns);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void htmlCollection2_finalize(JS::GCContext *op, JSObject *obj)
|
static void htmlCollection2_finalize(JS::GCContext *op, JSObject *obj)
|
||||||
{
|
{
|
||||||
@ -192,7 +208,7 @@ js::ObjectOps col_obj_ops = {
|
|||||||
|
|
||||||
JSClass htmlCollection_class = {
|
JSClass htmlCollection_class = {
|
||||||
"htmlCollection",
|
"htmlCollection",
|
||||||
JSCLASS_HAS_RESERVED_SLOTS(3),
|
JSCLASS_HAS_RESERVED_SLOTS(4),
|
||||||
&htmlCollection_ops,
|
&htmlCollection_ops,
|
||||||
.oOps = &col_obj_ops
|
.oOps = &col_obj_ops
|
||||||
};
|
};
|
||||||
@ -506,8 +522,8 @@ htmlCollection_set_items(JSContext *ctx, JS::HandleObject hobj, void *node)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
JSObject *
|
static JSObject *
|
||||||
getCollection(JSContext *ctx, void *node)
|
getCollection_common(JSContext *ctx, void *node, bool was_class_name)
|
||||||
{
|
{
|
||||||
#ifdef ECMASCRIPT_DEBUG
|
#ifdef ECMASCRIPT_DEBUG
|
||||||
fprintf(stderr, "%s:%s\n", __FILE__, __FUNCTION__);
|
fprintf(stderr, "%s:%s\n", __FILE__, __FUNCTION__);
|
||||||
@ -545,6 +561,19 @@ getCollection(JSContext *ctx, void *node)
|
|||||||
JS::SetReservedSlot(el, SLOT_NODE, JS::PrivateValue(node));
|
JS::SetReservedSlot(el, SLOT_NODE, JS::PrivateValue(node));
|
||||||
JS::SetReservedSlot(el, SLOT_ITEM_NAMEDITEM, JS::ObjectValue(*col));
|
JS::SetReservedSlot(el, SLOT_ITEM_NAMEDITEM, JS::ObjectValue(*col));
|
||||||
JS::SetReservedSlot(el, SLOT_ARRAY, JS::ObjectValue(*arr));
|
JS::SetReservedSlot(el, SLOT_ARRAY, JS::ObjectValue(*arr));
|
||||||
|
JS::SetReservedSlot(el, SLOT_WAS_CLASS_NAME, JS::BooleanValue(was_class_name));
|
||||||
|
|
||||||
return el;
|
return el;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
JSObject *
|
||||||
|
getCollection(JSContext *ctx, void *node)
|
||||||
|
{
|
||||||
|
return getCollection_common(ctx, node, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
JSObject *
|
||||||
|
getCollection2(JSContext *ctx, void *node)
|
||||||
|
{
|
||||||
|
return getCollection_common(ctx, node, true);
|
||||||
|
}
|
||||||
|
@ -4,5 +4,6 @@
|
|||||||
#include "js/spidermonkey/util.h"
|
#include "js/spidermonkey/util.h"
|
||||||
|
|
||||||
JSObject *getCollection(JSContext *ctx, void *node);
|
JSObject *getCollection(JSContext *ctx, void *node);
|
||||||
|
JSObject *getCollection2(JSContext *ctx, void *node);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -2004,7 +2004,7 @@ document_getElementsByClassName(JSContext *ctx, unsigned int argc, JS::Value *vp
|
|||||||
args.rval().setNull();
|
args.rval().setNull();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
JSObject *obj = getCollection(ctx, col);
|
JSObject *obj = getCollection2(ctx, col);
|
||||||
args.rval().setObject(*obj);
|
args.rval().setObject(*obj);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
Loading…
Reference in New Issue
Block a user