diff -r 000000000000 -r 6474c204b198 js/xpconnect/wrappers/ChromeObjectWrapper.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/js/xpconnect/wrappers/ChromeObjectWrapper.h Wed Dec 31 06:09:35 2014 +0100 @@ -0,0 +1,59 @@ +/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/* vim: set ts=8 sts=4 et sw=4 tw=99: */ +/* 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/. */ + +#ifndef __ChromeObjectWrapper_h__ +#define __ChromeObjectWrapper_h__ + +#include "mozilla/Attributes.h" + +#include "FilteringWrapper.h" + +namespace xpc { + +struct ExposedPropertiesOnly; + +// When chrome JS objects are exposed to content, they get a ChromeObjectWrapper. +// +// The base filtering wrapper here does most of the work for us. We define a +// custom class here to introduce custom behavior with respect to the prototype +// chain. +#define ChromeObjectWrapperBase \ + FilteringWrapper + +class ChromeObjectWrapper : public ChromeObjectWrapperBase +{ + public: + ChromeObjectWrapper() : ChromeObjectWrapperBase(0) {} + + /* Custom traps. */ + virtual bool getPropertyDescriptor(JSContext *cx, JS::Handle wrapper, + JS::Handle id, + JS::MutableHandle desc) MOZ_OVERRIDE; + virtual bool has(JSContext *cx, JS::Handle wrapper, + JS::Handle id, bool *bp) MOZ_OVERRIDE; + virtual bool get(JSContext *cx, JS::Handle wrapper, JS::Handle receiver, + JS::Handle id, JS::MutableHandle vp) MOZ_OVERRIDE; + + virtual bool objectClassIs(JS::Handle obj, js::ESClassValue classValue, + JSContext *cx) MOZ_OVERRIDE; + + virtual bool enter(JSContext *cx, JS::Handle wrapper, JS::Handle id, + js::Wrapper::Action act, bool *bp) MOZ_OVERRIDE; + + // NB: One might think we'd need to implement enumerate(), keys(), iterate(), + // and getPropertyNames() here. However, ES5 built-in properties aren't + // enumerable (and SpiderMonkey's implementation seems to match the spec + // modulo Error.prototype.fileName and Error.prototype.lineNumber). Since + // we're only remapping the prototypes of standard objects, there would + // never be anything more to enumerate up the prototype chain. So we can + // atually skip these. + + static ChromeObjectWrapper singleton; +}; + +} /* namespace xpc */ + +#endif /* __ChromeObjectWrapper_h__ */