JSNameScope.cpp 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. /*
  2. * Copyright (C) 2008, 2009, 2012 Apple Inc. All Rights Reserved.
  3. *
  4. * Redistribution and use in source and binary forms, with or without
  5. * modification, are permitted provided that the following conditions
  6. * are met:
  7. * 1. Redistributions of source code must retain the above copyright
  8. * notice, this list of conditions and the following disclaimer.
  9. * 2. Redistributions in binary form must reproduce the above copyright
  10. * notice, this list of conditions and the following disclaimer in the
  11. * documentation and/or other materials provided with the distribution.
  12. *
  13. * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
  14. * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  15. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  16. * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
  17. * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  18. * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  19. * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
  20. * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
  21. * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  22. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  23. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  24. */
  25. #include "config.h"
  26. #include "JSNameScope.h"
  27. #include "Error.h"
  28. #include "Operations.h"
  29. namespace JSC {
  30. const ClassInfo JSNameScope::s_info = { "NameScope", &Base::s_info, 0, 0, CREATE_METHOD_TABLE(JSNameScope) };
  31. void JSNameScope::visitChildren(JSCell* cell, SlotVisitor& visitor)
  32. {
  33. JSNameScope* thisObject = jsCast<JSNameScope*>(cell);
  34. ASSERT_GC_OBJECT_INHERITS(thisObject, &s_info);
  35. COMPILE_ASSERT(StructureFlags & OverridesVisitChildren, OverridesVisitChildrenWithoutSettingFlag);
  36. ASSERT(thisObject->structure()->typeInfo().overridesVisitChildren());
  37. Base::visitChildren(thisObject, visitor);
  38. visitor.append(&thisObject->m_registerStore);
  39. }
  40. JSObject* JSNameScope::toThisObject(JSCell*, ExecState* exec)
  41. {
  42. return exec->globalThisValue();
  43. }
  44. void JSNameScope::put(JSCell* cell, ExecState* exec, PropertyName propertyName, JSValue value, PutPropertySlot& slot)
  45. {
  46. JSNameScope* thisObject = jsCast<JSNameScope*>(cell);
  47. if (slot.isStrictMode()) {
  48. // Double lookup in strict mode, but this only occurs when
  49. // a) indirectly writing to an exception slot
  50. // b) writing to a function expression name
  51. // (a) is unlikely, and (b) is an error.
  52. // Also with a single entry the symbol table lookup should simply be
  53. // a pointer compare.
  54. PropertySlot slot;
  55. bool isWritable = true;
  56. symbolTableGet(thisObject, propertyName, slot, isWritable);
  57. if (!isWritable) {
  58. throwError(exec, createTypeError(exec, StrictModeReadonlyPropertyWriteError));
  59. return;
  60. }
  61. }
  62. if (symbolTablePut(thisObject, exec, propertyName, value, slot.isStrictMode()))
  63. return;
  64. RELEASE_ASSERT_NOT_REACHED();
  65. }
  66. bool JSNameScope::getOwnPropertySlot(JSCell* cell, ExecState*, PropertyName propertyName, PropertySlot& slot)
  67. {
  68. return symbolTableGet(jsCast<JSNameScope*>(cell), propertyName, slot);
  69. }
  70. } // namespace JSC