therubyracer 0.9.0beta4 → 0.9.0beta5
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of therubyracer might be problematic. Click here for more details.
- data/.gitignore +1 -0
- data/Rakefile +0 -11
- data/ext/v8/extconf.rb +9 -9
- data/ext/v8/v8_external.cpp +40 -10
- data/lib/v8/cli.rb +2 -1
- data/lib/v8/version.rb +1 -1
- data/spec/redjs/.gitignore +1 -0
- data/therubyracer.gemspec +2 -3
- metadata +33 -779
- data/ext/v8/upstream/Makefile +0 -38
- data/ext/v8/upstream/detect_cpu.rb +0 -27
- data/ext/v8/upstream/fpic-on-linux-amd64.patch +0 -13
- data/ext/v8/upstream/scons/CHANGES.txt +0 -5183
- data/ext/v8/upstream/scons/LICENSE.txt +0 -20
- data/ext/v8/upstream/scons/MANIFEST +0 -202
- data/ext/v8/upstream/scons/PKG-INFO +0 -13
- data/ext/v8/upstream/scons/README.txt +0 -273
- data/ext/v8/upstream/scons/RELEASE.txt +0 -1040
- data/ext/v8/upstream/scons/engine/SCons/Action.py +0 -1256
- data/ext/v8/upstream/scons/engine/SCons/Builder.py +0 -868
- data/ext/v8/upstream/scons/engine/SCons/CacheDir.py +0 -217
- data/ext/v8/upstream/scons/engine/SCons/Conftest.py +0 -794
- data/ext/v8/upstream/scons/engine/SCons/Debug.py +0 -237
- data/ext/v8/upstream/scons/engine/SCons/Defaults.py +0 -485
- data/ext/v8/upstream/scons/engine/SCons/Environment.py +0 -2327
- data/ext/v8/upstream/scons/engine/SCons/Errors.py +0 -207
- data/ext/v8/upstream/scons/engine/SCons/Executor.py +0 -636
- data/ext/v8/upstream/scons/engine/SCons/Job.py +0 -435
- data/ext/v8/upstream/scons/engine/SCons/Memoize.py +0 -292
- data/ext/v8/upstream/scons/engine/SCons/Node/Alias.py +0 -153
- data/ext/v8/upstream/scons/engine/SCons/Node/FS.py +0 -3220
- data/ext/v8/upstream/scons/engine/SCons/Node/Python.py +0 -128
- data/ext/v8/upstream/scons/engine/SCons/Node/__init__.py +0 -1341
- data/ext/v8/upstream/scons/engine/SCons/Options/BoolOption.py +0 -50
- data/ext/v8/upstream/scons/engine/SCons/Options/EnumOption.py +0 -50
- data/ext/v8/upstream/scons/engine/SCons/Options/ListOption.py +0 -50
- data/ext/v8/upstream/scons/engine/SCons/Options/PackageOption.py +0 -50
- data/ext/v8/upstream/scons/engine/SCons/Options/PathOption.py +0 -76
- data/ext/v8/upstream/scons/engine/SCons/Options/__init__.py +0 -74
- data/ext/v8/upstream/scons/engine/SCons/PathList.py +0 -232
- data/ext/v8/upstream/scons/engine/SCons/Platform/__init__.py +0 -236
- data/ext/v8/upstream/scons/engine/SCons/Platform/aix.py +0 -70
- data/ext/v8/upstream/scons/engine/SCons/Platform/cygwin.py +0 -55
- data/ext/v8/upstream/scons/engine/SCons/Platform/darwin.py +0 -46
- data/ext/v8/upstream/scons/engine/SCons/Platform/hpux.py +0 -46
- data/ext/v8/upstream/scons/engine/SCons/Platform/irix.py +0 -44
- data/ext/v8/upstream/scons/engine/SCons/Platform/os2.py +0 -58
- data/ext/v8/upstream/scons/engine/SCons/Platform/posix.py +0 -264
- data/ext/v8/upstream/scons/engine/SCons/Platform/sunos.py +0 -50
- data/ext/v8/upstream/scons/engine/SCons/Platform/win32.py +0 -386
- data/ext/v8/upstream/scons/engine/SCons/SConf.py +0 -1038
- data/ext/v8/upstream/scons/engine/SCons/SConsign.py +0 -381
- data/ext/v8/upstream/scons/engine/SCons/Scanner/C.py +0 -132
- data/ext/v8/upstream/scons/engine/SCons/Scanner/D.py +0 -74
- data/ext/v8/upstream/scons/engine/SCons/Scanner/Dir.py +0 -111
- data/ext/v8/upstream/scons/engine/SCons/Scanner/Fortran.py +0 -320
- data/ext/v8/upstream/scons/engine/SCons/Scanner/IDL.py +0 -48
- data/ext/v8/upstream/scons/engine/SCons/Scanner/LaTeX.py +0 -378
- data/ext/v8/upstream/scons/engine/SCons/Scanner/Prog.py +0 -103
- data/ext/v8/upstream/scons/engine/SCons/Scanner/RC.py +0 -55
- data/ext/v8/upstream/scons/engine/SCons/Scanner/__init__.py +0 -415
- data/ext/v8/upstream/scons/engine/SCons/Script/Interactive.py +0 -386
- data/ext/v8/upstream/scons/engine/SCons/Script/Main.py +0 -1360
- data/ext/v8/upstream/scons/engine/SCons/Script/SConsOptions.py +0 -944
- data/ext/v8/upstream/scons/engine/SCons/Script/SConscript.py +0 -642
- data/ext/v8/upstream/scons/engine/SCons/Script/__init__.py +0 -414
- data/ext/v8/upstream/scons/engine/SCons/Sig.py +0 -63
- data/ext/v8/upstream/scons/engine/SCons/Subst.py +0 -911
- data/ext/v8/upstream/scons/engine/SCons/Taskmaster.py +0 -1030
- data/ext/v8/upstream/scons/engine/SCons/Tool/386asm.py +0 -61
- data/ext/v8/upstream/scons/engine/SCons/Tool/BitKeeper.py +0 -65
- data/ext/v8/upstream/scons/engine/SCons/Tool/CVS.py +0 -73
- data/ext/v8/upstream/scons/engine/SCons/Tool/FortranCommon.py +0 -247
- data/ext/v8/upstream/scons/engine/SCons/Tool/JavaCommon.py +0 -324
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/__init__.py +0 -56
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/arch.py +0 -61
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/common.py +0 -210
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/netframework.py +0 -84
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/sdk.py +0 -321
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/vc.py +0 -367
- data/ext/v8/upstream/scons/engine/SCons/Tool/MSCommon/vs.py +0 -497
- data/ext/v8/upstream/scons/engine/SCons/Tool/Perforce.py +0 -104
- data/ext/v8/upstream/scons/engine/SCons/Tool/PharLapCommon.py +0 -138
- data/ext/v8/upstream/scons/engine/SCons/Tool/RCS.py +0 -64
- data/ext/v8/upstream/scons/engine/SCons/Tool/SCCS.py +0 -64
- data/ext/v8/upstream/scons/engine/SCons/Tool/Subversion.py +0 -71
- data/ext/v8/upstream/scons/engine/SCons/Tool/__init__.py +0 -675
- data/ext/v8/upstream/scons/engine/SCons/Tool/aixc++.py +0 -82
- data/ext/v8/upstream/scons/engine/SCons/Tool/aixcc.py +0 -74
- data/ext/v8/upstream/scons/engine/SCons/Tool/aixf77.py +0 -80
- data/ext/v8/upstream/scons/engine/SCons/Tool/aixlink.py +0 -76
- data/ext/v8/upstream/scons/engine/SCons/Tool/applelink.py +0 -71
- data/ext/v8/upstream/scons/engine/SCons/Tool/ar.py +0 -63
- data/ext/v8/upstream/scons/engine/SCons/Tool/as.py +0 -78
- data/ext/v8/upstream/scons/engine/SCons/Tool/bcc32.py +0 -82
- data/ext/v8/upstream/scons/engine/SCons/Tool/c++.py +0 -99
- data/ext/v8/upstream/scons/engine/SCons/Tool/cc.py +0 -114
- data/ext/v8/upstream/scons/engine/SCons/Tool/cvf.py +0 -58
- data/ext/v8/upstream/scons/engine/SCons/Tool/default.py +0 -50
- data/ext/v8/upstream/scons/engine/SCons/Tool/dmd.py +0 -224
- data/ext/v8/upstream/scons/engine/SCons/Tool/dvi.py +0 -64
- data/ext/v8/upstream/scons/engine/SCons/Tool/dvipdf.py +0 -125
- data/ext/v8/upstream/scons/engine/SCons/Tool/dvips.py +0 -94
- data/ext/v8/upstream/scons/engine/SCons/Tool/f77.py +0 -62
- data/ext/v8/upstream/scons/engine/SCons/Tool/f90.py +0 -62
- data/ext/v8/upstream/scons/engine/SCons/Tool/f95.py +0 -63
- data/ext/v8/upstream/scons/engine/SCons/Tool/filesystem.py +0 -98
- data/ext/v8/upstream/scons/engine/SCons/Tool/fortran.py +0 -63
- data/ext/v8/upstream/scons/engine/SCons/Tool/g++.py +0 -90
- data/ext/v8/upstream/scons/engine/SCons/Tool/g77.py +0 -73
- data/ext/v8/upstream/scons/engine/SCons/Tool/gas.py +0 -53
- data/ext/v8/upstream/scons/engine/SCons/Tool/gcc.py +0 -80
- data/ext/v8/upstream/scons/engine/SCons/Tool/gfortran.py +0 -64
- data/ext/v8/upstream/scons/engine/SCons/Tool/gnulink.py +0 -63
- data/ext/v8/upstream/scons/engine/SCons/Tool/gs.py +0 -81
- data/ext/v8/upstream/scons/engine/SCons/Tool/hpc++.py +0 -85
- data/ext/v8/upstream/scons/engine/SCons/Tool/hpcc.py +0 -53
- data/ext/v8/upstream/scons/engine/SCons/Tool/hplink.py +0 -77
- data/ext/v8/upstream/scons/engine/SCons/Tool/icc.py +0 -59
- data/ext/v8/upstream/scons/engine/SCons/Tool/icl.py +0 -52
- data/ext/v8/upstream/scons/engine/SCons/Tool/ifl.py +0 -72
- data/ext/v8/upstream/scons/engine/SCons/Tool/ifort.py +0 -90
- data/ext/v8/upstream/scons/engine/SCons/Tool/ilink.py +0 -59
- data/ext/v8/upstream/scons/engine/SCons/Tool/ilink32.py +0 -60
- data/ext/v8/upstream/scons/engine/SCons/Tool/install.py +0 -229
- data/ext/v8/upstream/scons/engine/SCons/Tool/intelc.py +0 -490
- data/ext/v8/upstream/scons/engine/SCons/Tool/ipkg.py +0 -71
- data/ext/v8/upstream/scons/engine/SCons/Tool/jar.py +0 -110
- data/ext/v8/upstream/scons/engine/SCons/Tool/javac.py +0 -234
- data/ext/v8/upstream/scons/engine/SCons/Tool/javah.py +0 -138
- data/ext/v8/upstream/scons/engine/SCons/Tool/latex.py +0 -79
- data/ext/v8/upstream/scons/engine/SCons/Tool/lex.py +0 -99
- data/ext/v8/upstream/scons/engine/SCons/Tool/link.py +0 -121
- data/ext/v8/upstream/scons/engine/SCons/Tool/linkloc.py +0 -112
- data/ext/v8/upstream/scons/engine/SCons/Tool/m4.py +0 -63
- data/ext/v8/upstream/scons/engine/SCons/Tool/masm.py +0 -77
- data/ext/v8/upstream/scons/engine/SCons/Tool/midl.py +0 -90
- data/ext/v8/upstream/scons/engine/SCons/Tool/mingw.py +0 -159
- data/ext/v8/upstream/scons/engine/SCons/Tool/mslib.py +0 -64
- data/ext/v8/upstream/scons/engine/SCons/Tool/mslink.py +0 -266
- data/ext/v8/upstream/scons/engine/SCons/Tool/mssdk.py +0 -50
- data/ext/v8/upstream/scons/engine/SCons/Tool/msvc.py +0 -269
- data/ext/v8/upstream/scons/engine/SCons/Tool/msvs.py +0 -1439
- data/ext/v8/upstream/scons/engine/SCons/Tool/mwcc.py +0 -208
- data/ext/v8/upstream/scons/engine/SCons/Tool/mwld.py +0 -107
- data/ext/v8/upstream/scons/engine/SCons/Tool/nasm.py +0 -72
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/__init__.py +0 -314
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/ipk.py +0 -185
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/msi.py +0 -526
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/rpm.py +0 -367
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_tarbz2.py +0 -43
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_targz.py +0 -43
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/src_zip.py +0 -43
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/tarbz2.py +0 -44
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/targz.py +0 -44
- data/ext/v8/upstream/scons/engine/SCons/Tool/packaging/zip.py +0 -44
- data/ext/v8/upstream/scons/engine/SCons/Tool/pdf.py +0 -78
- data/ext/v8/upstream/scons/engine/SCons/Tool/pdflatex.py +0 -83
- data/ext/v8/upstream/scons/engine/SCons/Tool/pdftex.py +0 -108
- data/ext/v8/upstream/scons/engine/SCons/Tool/qt.py +0 -336
- data/ext/v8/upstream/scons/engine/SCons/Tool/rmic.py +0 -121
- data/ext/v8/upstream/scons/engine/SCons/Tool/rpcgen.py +0 -70
- data/ext/v8/upstream/scons/engine/SCons/Tool/rpm.py +0 -132
- data/ext/v8/upstream/scons/engine/SCons/Tool/sgiar.py +0 -68
- data/ext/v8/upstream/scons/engine/SCons/Tool/sgic++.py +0 -58
- data/ext/v8/upstream/scons/engine/SCons/Tool/sgicc.py +0 -53
- data/ext/v8/upstream/scons/engine/SCons/Tool/sgilink.py +0 -63
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunar.py +0 -67
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunc++.py +0 -142
- data/ext/v8/upstream/scons/engine/SCons/Tool/suncc.py +0 -58
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunf77.py +0 -63
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunf90.py +0 -64
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunf95.py +0 -64
- data/ext/v8/upstream/scons/engine/SCons/Tool/sunlink.py +0 -77
- data/ext/v8/upstream/scons/engine/SCons/Tool/swig.py +0 -186
- data/ext/v8/upstream/scons/engine/SCons/Tool/tar.py +0 -73
- data/ext/v8/upstream/scons/engine/SCons/Tool/tex.py +0 -805
- data/ext/v8/upstream/scons/engine/SCons/Tool/textfile.py +0 -175
- data/ext/v8/upstream/scons/engine/SCons/Tool/tlib.py +0 -53
- data/ext/v8/upstream/scons/engine/SCons/Tool/wix.py +0 -100
- data/ext/v8/upstream/scons/engine/SCons/Tool/yacc.py +0 -131
- data/ext/v8/upstream/scons/engine/SCons/Tool/zip.py +0 -100
- data/ext/v8/upstream/scons/engine/SCons/Util.py +0 -1645
- data/ext/v8/upstream/scons/engine/SCons/Variables/BoolVariable.py +0 -91
- data/ext/v8/upstream/scons/engine/SCons/Variables/EnumVariable.py +0 -107
- data/ext/v8/upstream/scons/engine/SCons/Variables/ListVariable.py +0 -139
- data/ext/v8/upstream/scons/engine/SCons/Variables/PackageVariable.py +0 -109
- data/ext/v8/upstream/scons/engine/SCons/Variables/PathVariable.py +0 -147
- data/ext/v8/upstream/scons/engine/SCons/Variables/__init__.py +0 -317
- data/ext/v8/upstream/scons/engine/SCons/Warnings.py +0 -228
- data/ext/v8/upstream/scons/engine/SCons/__init__.py +0 -49
- data/ext/v8/upstream/scons/engine/SCons/compat/__init__.py +0 -302
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_UserString.py +0 -98
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_hashlib.py +0 -91
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_itertools.py +0 -124
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_optparse.py +0 -1725
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_sets.py +0 -583
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_sets15.py +0 -176
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_shlex.py +0 -325
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_subprocess.py +0 -1296
- data/ext/v8/upstream/scons/engine/SCons/compat/_scons_textwrap.py +0 -382
- data/ext/v8/upstream/scons/engine/SCons/compat/builtins.py +0 -187
- data/ext/v8/upstream/scons/engine/SCons/cpp.py +0 -598
- data/ext/v8/upstream/scons/engine/SCons/dblite.py +0 -248
- data/ext/v8/upstream/scons/engine/SCons/exitfuncs.py +0 -77
- data/ext/v8/upstream/scons/os_spawnv_fix.diff +0 -83
- data/ext/v8/upstream/scons/scons-time.1 +0 -1017
- data/ext/v8/upstream/scons/scons.1 +0 -15179
- data/ext/v8/upstream/scons/sconsign.1 +0 -208
- data/ext/v8/upstream/scons/script/scons +0 -184
- data/ext/v8/upstream/scons/script/scons-time +0 -1529
- data/ext/v8/upstream/scons/script/scons.bat +0 -31
- data/ext/v8/upstream/scons/script/sconsign +0 -508
- data/ext/v8/upstream/scons/setup.cfg +0 -6
- data/ext/v8/upstream/scons/setup.py +0 -427
- data/ext/v8/upstream/v8/.gitignore +0 -33
- data/ext/v8/upstream/v8/AUTHORS +0 -42
- data/ext/v8/upstream/v8/ChangeLog +0 -2663
- data/ext/v8/upstream/v8/LICENSE +0 -52
- data/ext/v8/upstream/v8/LICENSE.strongtalk +0 -29
- data/ext/v8/upstream/v8/LICENSE.v8 +0 -26
- data/ext/v8/upstream/v8/LICENSE.valgrind +0 -45
- data/ext/v8/upstream/v8/SConstruct +0 -1473
- data/ext/v8/upstream/v8/build/README.txt +0 -25
- data/ext/v8/upstream/v8/build/all.gyp +0 -18
- data/ext/v8/upstream/v8/build/armu.gypi +0 -32
- data/ext/v8/upstream/v8/build/common.gypi +0 -82
- data/ext/v8/upstream/v8/build/gyp_v8 +0 -145
- data/ext/v8/upstream/v8/include/v8-debug.h +0 -394
- data/ext/v8/upstream/v8/include/v8-preparser.h +0 -116
- data/ext/v8/upstream/v8/include/v8-profiler.h +0 -505
- data/ext/v8/upstream/v8/include/v8-testing.h +0 -104
- data/ext/v8/upstream/v8/include/v8.h +0 -4000
- data/ext/v8/upstream/v8/include/v8stdint.h +0 -53
- data/ext/v8/upstream/v8/preparser/SConscript +0 -38
- data/ext/v8/upstream/v8/preparser/preparser-process.cc +0 -169
- data/ext/v8/upstream/v8/src/SConscript +0 -380
- data/ext/v8/upstream/v8/src/accessors.cc +0 -766
- data/ext/v8/upstream/v8/src/accessors.h +0 -121
- data/ext/v8/upstream/v8/src/allocation-inl.h +0 -49
- data/ext/v8/upstream/v8/src/allocation.cc +0 -122
- data/ext/v8/upstream/v8/src/allocation.h +0 -143
- data/ext/v8/upstream/v8/src/api.cc +0 -5678
- data/ext/v8/upstream/v8/src/api.h +0 -572
- data/ext/v8/upstream/v8/src/apinatives.js +0 -110
- data/ext/v8/upstream/v8/src/apiutils.h +0 -73
- data/ext/v8/upstream/v8/src/arguments.h +0 -116
- data/ext/v8/upstream/v8/src/arm/assembler-arm-inl.h +0 -353
- data/ext/v8/upstream/v8/src/arm/assembler-arm.cc +0 -2877
- data/ext/v8/upstream/v8/src/arm/assembler-arm.h +0 -1382
- data/ext/v8/upstream/v8/src/arm/builtins-arm.cc +0 -1634
- data/ext/v8/upstream/v8/src/arm/code-stubs-arm.cc +0 -6917
- data/ext/v8/upstream/v8/src/arm/code-stubs-arm.h +0 -623
- data/ext/v8/upstream/v8/src/arm/codegen-arm-inl.h +0 -48
- data/ext/v8/upstream/v8/src/arm/codegen-arm.cc +0 -7437
- data/ext/v8/upstream/v8/src/arm/codegen-arm.h +0 -595
- data/ext/v8/upstream/v8/src/arm/constants-arm.cc +0 -152
- data/ext/v8/upstream/v8/src/arm/constants-arm.h +0 -778
- data/ext/v8/upstream/v8/src/arm/cpu-arm.cc +0 -149
- data/ext/v8/upstream/v8/src/arm/debug-arm.cc +0 -317
- data/ext/v8/upstream/v8/src/arm/deoptimizer-arm.cc +0 -737
- data/ext/v8/upstream/v8/src/arm/disasm-arm.cc +0 -1503
- data/ext/v8/upstream/v8/src/arm/frames-arm.cc +0 -45
- data/ext/v8/upstream/v8/src/arm/frames-arm.h +0 -168
- data/ext/v8/upstream/v8/src/arm/full-codegen-arm.cc +0 -4374
- data/ext/v8/upstream/v8/src/arm/ic-arm.cc +0 -1793
- data/ext/v8/upstream/v8/src/arm/jump-target-arm.cc +0 -174
- data/ext/v8/upstream/v8/src/arm/lithium-arm.cc +0 -2120
- data/ext/v8/upstream/v8/src/arm/lithium-arm.h +0 -2179
- data/ext/v8/upstream/v8/src/arm/lithium-codegen-arm.cc +0 -4132
- data/ext/v8/upstream/v8/src/arm/lithium-codegen-arm.h +0 -329
- data/ext/v8/upstream/v8/src/arm/lithium-gap-resolver-arm.cc +0 -305
- data/ext/v8/upstream/v8/src/arm/lithium-gap-resolver-arm.h +0 -84
- data/ext/v8/upstream/v8/src/arm/macro-assembler-arm.cc +0 -2939
- data/ext/v8/upstream/v8/src/arm/macro-assembler-arm.h +0 -1071
- data/ext/v8/upstream/v8/src/arm/regexp-macro-assembler-arm.cc +0 -1287
- data/ext/v8/upstream/v8/src/arm/regexp-macro-assembler-arm.h +0 -253
- data/ext/v8/upstream/v8/src/arm/register-allocator-arm-inl.h +0 -100
- data/ext/v8/upstream/v8/src/arm/register-allocator-arm.cc +0 -63
- data/ext/v8/upstream/v8/src/arm/register-allocator-arm.h +0 -44
- data/ext/v8/upstream/v8/src/arm/simulator-arm.cc +0 -3288
- data/ext/v8/upstream/v8/src/arm/simulator-arm.h +0 -413
- data/ext/v8/upstream/v8/src/arm/stub-cache-arm.cc +0 -4034
- data/ext/v8/upstream/v8/src/arm/virtual-frame-arm-inl.h +0 -59
- data/ext/v8/upstream/v8/src/arm/virtual-frame-arm.cc +0 -843
- data/ext/v8/upstream/v8/src/arm/virtual-frame-arm.h +0 -523
- data/ext/v8/upstream/v8/src/array.js +0 -1249
- data/ext/v8/upstream/v8/src/assembler.cc +0 -1067
- data/ext/v8/upstream/v8/src/assembler.h +0 -823
- data/ext/v8/upstream/v8/src/ast-inl.h +0 -112
- data/ext/v8/upstream/v8/src/ast.cc +0 -1078
- data/ext/v8/upstream/v8/src/ast.h +0 -2234
- data/ext/v8/upstream/v8/src/atomicops.h +0 -167
- data/ext/v8/upstream/v8/src/atomicops_internals_arm_gcc.h +0 -145
- data/ext/v8/upstream/v8/src/atomicops_internals_mips_gcc.h +0 -169
- data/ext/v8/upstream/v8/src/atomicops_internals_x86_gcc.cc +0 -126
- data/ext/v8/upstream/v8/src/atomicops_internals_x86_gcc.h +0 -287
- data/ext/v8/upstream/v8/src/atomicops_internals_x86_macosx.h +0 -301
- data/ext/v8/upstream/v8/src/atomicops_internals_x86_msvc.h +0 -203
- data/ext/v8/upstream/v8/src/bignum-dtoa.cc +0 -655
- data/ext/v8/upstream/v8/src/bignum-dtoa.h +0 -81
- data/ext/v8/upstream/v8/src/bignum.cc +0 -768
- data/ext/v8/upstream/v8/src/bignum.h +0 -140
- data/ext/v8/upstream/v8/src/bootstrapper.cc +0 -2138
- data/ext/v8/upstream/v8/src/bootstrapper.h +0 -185
- data/ext/v8/upstream/v8/src/builtins.cc +0 -1708
- data/ext/v8/upstream/v8/src/builtins.h +0 -368
- data/ext/v8/upstream/v8/src/bytecodes-irregexp.h +0 -105
- data/ext/v8/upstream/v8/src/cached-powers.cc +0 -177
- data/ext/v8/upstream/v8/src/cached-powers.h +0 -65
- data/ext/v8/upstream/v8/src/char-predicates-inl.h +0 -94
- data/ext/v8/upstream/v8/src/char-predicates.h +0 -65
- data/ext/v8/upstream/v8/src/checks.cc +0 -110
- data/ext/v8/upstream/v8/src/checks.h +0 -296
- data/ext/v8/upstream/v8/src/circular-queue-inl.h +0 -53
- data/ext/v8/upstream/v8/src/circular-queue.cc +0 -122
- data/ext/v8/upstream/v8/src/circular-queue.h +0 -103
- data/ext/v8/upstream/v8/src/code-stubs.cc +0 -240
- data/ext/v8/upstream/v8/src/code-stubs.h +0 -971
- data/ext/v8/upstream/v8/src/code.h +0 -68
- data/ext/v8/upstream/v8/src/codegen-inl.h +0 -68
- data/ext/v8/upstream/v8/src/codegen.cc +0 -505
- data/ext/v8/upstream/v8/src/codegen.h +0 -245
- data/ext/v8/upstream/v8/src/compilation-cache.cc +0 -540
- data/ext/v8/upstream/v8/src/compilation-cache.h +0 -287
- data/ext/v8/upstream/v8/src/compiler.cc +0 -792
- data/ext/v8/upstream/v8/src/compiler.h +0 -307
- data/ext/v8/upstream/v8/src/contexts.cc +0 -327
- data/ext/v8/upstream/v8/src/contexts.h +0 -382
- data/ext/v8/upstream/v8/src/conversions-inl.h +0 -110
- data/ext/v8/upstream/v8/src/conversions.cc +0 -1125
- data/ext/v8/upstream/v8/src/conversions.h +0 -122
- data/ext/v8/upstream/v8/src/counters.cc +0 -93
- data/ext/v8/upstream/v8/src/counters.h +0 -254
- data/ext/v8/upstream/v8/src/cpu-profiler-inl.h +0 -101
- data/ext/v8/upstream/v8/src/cpu-profiler.cc +0 -606
- data/ext/v8/upstream/v8/src/cpu-profiler.h +0 -305
- data/ext/v8/upstream/v8/src/cpu.h +0 -67
- data/ext/v8/upstream/v8/src/d8-debug.cc +0 -367
- data/ext/v8/upstream/v8/src/d8-debug.h +0 -158
- data/ext/v8/upstream/v8/src/d8-posix.cc +0 -695
- data/ext/v8/upstream/v8/src/d8-readline.cc +0 -128
- data/ext/v8/upstream/v8/src/d8-windows.cc +0 -42
- data/ext/v8/upstream/v8/src/d8.cc +0 -796
- data/ext/v8/upstream/v8/src/d8.gyp +0 -88
- data/ext/v8/upstream/v8/src/d8.h +0 -231
- data/ext/v8/upstream/v8/src/d8.js +0 -2798
- data/ext/v8/upstream/v8/src/data-flow.cc +0 -545
- data/ext/v8/upstream/v8/src/data-flow.h +0 -379
- data/ext/v8/upstream/v8/src/date.js +0 -1103
- data/ext/v8/upstream/v8/src/dateparser-inl.h +0 -125
- data/ext/v8/upstream/v8/src/dateparser.cc +0 -178
- data/ext/v8/upstream/v8/src/dateparser.h +0 -265
- data/ext/v8/upstream/v8/src/debug-agent.cc +0 -447
- data/ext/v8/upstream/v8/src/debug-agent.h +0 -129
- data/ext/v8/upstream/v8/src/debug-debugger.js +0 -2569
- data/ext/v8/upstream/v8/src/debug.cc +0 -3188
- data/ext/v8/upstream/v8/src/debug.h +0 -1055
- data/ext/v8/upstream/v8/src/deoptimizer.cc +0 -1296
- data/ext/v8/upstream/v8/src/deoptimizer.h +0 -629
- data/ext/v8/upstream/v8/src/disasm.h +0 -80
- data/ext/v8/upstream/v8/src/disassembler.cc +0 -339
- data/ext/v8/upstream/v8/src/disassembler.h +0 -56
- data/ext/v8/upstream/v8/src/diy-fp.cc +0 -58
- data/ext/v8/upstream/v8/src/diy-fp.h +0 -117
- data/ext/v8/upstream/v8/src/double.h +0 -238
- data/ext/v8/upstream/v8/src/dtoa.cc +0 -103
- data/ext/v8/upstream/v8/src/dtoa.h +0 -85
- data/ext/v8/upstream/v8/src/execution.cc +0 -791
- data/ext/v8/upstream/v8/src/execution.h +0 -291
- data/ext/v8/upstream/v8/src/extensions/experimental/break-iterator.cc +0 -250
- data/ext/v8/upstream/v8/src/extensions/experimental/break-iterator.h +0 -89
- data/ext/v8/upstream/v8/src/extensions/experimental/experimental.gyp +0 -55
- data/ext/v8/upstream/v8/src/extensions/experimental/i18n-extension.cc +0 -284
- data/ext/v8/upstream/v8/src/extensions/experimental/i18n-extension.h +0 -64
- data/ext/v8/upstream/v8/src/extensions/externalize-string-extension.cc +0 -141
- data/ext/v8/upstream/v8/src/extensions/externalize-string-extension.h +0 -50
- data/ext/v8/upstream/v8/src/extensions/gc-extension.cc +0 -58
- data/ext/v8/upstream/v8/src/extensions/gc-extension.h +0 -49
- data/ext/v8/upstream/v8/src/factory.cc +0 -1194
- data/ext/v8/upstream/v8/src/factory.h +0 -436
- data/ext/v8/upstream/v8/src/fast-dtoa.cc +0 -736
- data/ext/v8/upstream/v8/src/fast-dtoa.h +0 -83
- data/ext/v8/upstream/v8/src/fixed-dtoa.cc +0 -405
- data/ext/v8/upstream/v8/src/fixed-dtoa.h +0 -55
- data/ext/v8/upstream/v8/src/flag-definitions.h +0 -556
- data/ext/v8/upstream/v8/src/flags.cc +0 -551
- data/ext/v8/upstream/v8/src/flags.h +0 -79
- data/ext/v8/upstream/v8/src/frame-element.cc +0 -37
- data/ext/v8/upstream/v8/src/frame-element.h +0 -269
- data/ext/v8/upstream/v8/src/frames-inl.h +0 -236
- data/ext/v8/upstream/v8/src/frames.cc +0 -1273
- data/ext/v8/upstream/v8/src/frames.h +0 -854
- data/ext/v8/upstream/v8/src/full-codegen.cc +0 -1385
- data/ext/v8/upstream/v8/src/full-codegen.h +0 -753
- data/ext/v8/upstream/v8/src/func-name-inferrer.cc +0 -91
- data/ext/v8/upstream/v8/src/func-name-inferrer.h +0 -111
- data/ext/v8/upstream/v8/src/gdb-jit.cc +0 -1548
- data/ext/v8/upstream/v8/src/gdb-jit.h +0 -138
- data/ext/v8/upstream/v8/src/global-handles.cc +0 -596
- data/ext/v8/upstream/v8/src/global-handles.h +0 -239
- data/ext/v8/upstream/v8/src/globals.h +0 -325
- data/ext/v8/upstream/v8/src/handles-inl.h +0 -177
- data/ext/v8/upstream/v8/src/handles.cc +0 -965
- data/ext/v8/upstream/v8/src/handles.h +0 -372
- data/ext/v8/upstream/v8/src/hashmap.cc +0 -230
- data/ext/v8/upstream/v8/src/hashmap.h +0 -121
- data/ext/v8/upstream/v8/src/heap-inl.h +0 -703
- data/ext/v8/upstream/v8/src/heap-profiler.cc +0 -1173
- data/ext/v8/upstream/v8/src/heap-profiler.h +0 -396
- data/ext/v8/upstream/v8/src/heap.cc +0 -5856
- data/ext/v8/upstream/v8/src/heap.h +0 -2264
- data/ext/v8/upstream/v8/src/hydrogen-instructions.cc +0 -1639
- data/ext/v8/upstream/v8/src/hydrogen-instructions.h +0 -3657
- data/ext/v8/upstream/v8/src/hydrogen.cc +0 -6011
- data/ext/v8/upstream/v8/src/hydrogen.h +0 -1137
- data/ext/v8/upstream/v8/src/ia32/assembler-ia32-inl.h +0 -430
- data/ext/v8/upstream/v8/src/ia32/assembler-ia32.cc +0 -2846
- data/ext/v8/upstream/v8/src/ia32/assembler-ia32.h +0 -1159
- data/ext/v8/upstream/v8/src/ia32/builtins-ia32.cc +0 -1596
- data/ext/v8/upstream/v8/src/ia32/code-stubs-ia32.cc +0 -6549
- data/ext/v8/upstream/v8/src/ia32/code-stubs-ia32.h +0 -495
- data/ext/v8/upstream/v8/src/ia32/codegen-ia32-inl.h +0 -46
- data/ext/v8/upstream/v8/src/ia32/codegen-ia32.cc +0 -10385
- data/ext/v8/upstream/v8/src/ia32/codegen-ia32.h +0 -801
- data/ext/v8/upstream/v8/src/ia32/cpu-ia32.cc +0 -88
- data/ext/v8/upstream/v8/src/ia32/debug-ia32.cc +0 -312
- data/ext/v8/upstream/v8/src/ia32/deoptimizer-ia32.cc +0 -774
- data/ext/v8/upstream/v8/src/ia32/disasm-ia32.cc +0 -1620
- data/ext/v8/upstream/v8/src/ia32/frames-ia32.cc +0 -45
- data/ext/v8/upstream/v8/src/ia32/frames-ia32.h +0 -140
- data/ext/v8/upstream/v8/src/ia32/full-codegen-ia32.cc +0 -4357
- data/ext/v8/upstream/v8/src/ia32/ic-ia32.cc +0 -1779
- data/ext/v8/upstream/v8/src/ia32/jump-target-ia32.cc +0 -437
- data/ext/v8/upstream/v8/src/ia32/lithium-codegen-ia32.cc +0 -4158
- data/ext/v8/upstream/v8/src/ia32/lithium-codegen-ia32.h +0 -318
- data/ext/v8/upstream/v8/src/ia32/lithium-gap-resolver-ia32.cc +0 -466
- data/ext/v8/upstream/v8/src/ia32/lithium-gap-resolver-ia32.h +0 -110
- data/ext/v8/upstream/v8/src/ia32/lithium-ia32.cc +0 -2181
- data/ext/v8/upstream/v8/src/ia32/lithium-ia32.h +0 -2235
- data/ext/v8/upstream/v8/src/ia32/macro-assembler-ia32.cc +0 -2056
- data/ext/v8/upstream/v8/src/ia32/macro-assembler-ia32.h +0 -807
- data/ext/v8/upstream/v8/src/ia32/regexp-macro-assembler-ia32.cc +0 -1264
- data/ext/v8/upstream/v8/src/ia32/regexp-macro-assembler-ia32.h +0 -216
- data/ext/v8/upstream/v8/src/ia32/register-allocator-ia32-inl.h +0 -82
- data/ext/v8/upstream/v8/src/ia32/register-allocator-ia32.cc +0 -157
- data/ext/v8/upstream/v8/src/ia32/register-allocator-ia32.h +0 -43
- data/ext/v8/upstream/v8/src/ia32/simulator-ia32.cc +0 -30
- data/ext/v8/upstream/v8/src/ia32/simulator-ia32.h +0 -72
- data/ext/v8/upstream/v8/src/ia32/stub-cache-ia32.cc +0 -3711
- data/ext/v8/upstream/v8/src/ia32/virtual-frame-ia32.cc +0 -1366
- data/ext/v8/upstream/v8/src/ia32/virtual-frame-ia32.h +0 -650
- data/ext/v8/upstream/v8/src/ic-inl.h +0 -130
- data/ext/v8/upstream/v8/src/ic.cc +0 -2389
- data/ext/v8/upstream/v8/src/ic.h +0 -675
- data/ext/v8/upstream/v8/src/inspector.cc +0 -63
- data/ext/v8/upstream/v8/src/inspector.h +0 -62
- data/ext/v8/upstream/v8/src/interpreter-irregexp.cc +0 -659
- data/ext/v8/upstream/v8/src/interpreter-irregexp.h +0 -49
- data/ext/v8/upstream/v8/src/isolate.cc +0 -883
- data/ext/v8/upstream/v8/src/isolate.h +0 -1306
- data/ext/v8/upstream/v8/src/json.js +0 -342
- data/ext/v8/upstream/v8/src/jsregexp.cc +0 -5371
- data/ext/v8/upstream/v8/src/jsregexp.h +0 -1483
- data/ext/v8/upstream/v8/src/jump-target-heavy-inl.h +0 -51
- data/ext/v8/upstream/v8/src/jump-target-heavy.cc +0 -427
- data/ext/v8/upstream/v8/src/jump-target-heavy.h +0 -238
- data/ext/v8/upstream/v8/src/jump-target-inl.h +0 -48
- data/ext/v8/upstream/v8/src/jump-target-light-inl.h +0 -56
- data/ext/v8/upstream/v8/src/jump-target-light.cc +0 -111
- data/ext/v8/upstream/v8/src/jump-target-light.h +0 -193
- data/ext/v8/upstream/v8/src/jump-target.cc +0 -91
- data/ext/v8/upstream/v8/src/jump-target.h +0 -90
- data/ext/v8/upstream/v8/src/list-inl.h +0 -206
- data/ext/v8/upstream/v8/src/list.h +0 -164
- data/ext/v8/upstream/v8/src/lithium-allocator-inl.h +0 -142
- data/ext/v8/upstream/v8/src/lithium-allocator.cc +0 -2105
- data/ext/v8/upstream/v8/src/lithium-allocator.h +0 -630
- data/ext/v8/upstream/v8/src/lithium.cc +0 -169
- data/ext/v8/upstream/v8/src/lithium.h +0 -592
- data/ext/v8/upstream/v8/src/liveedit-debugger.js +0 -1082
- data/ext/v8/upstream/v8/src/liveedit.cc +0 -1693
- data/ext/v8/upstream/v8/src/liveedit.h +0 -179
- data/ext/v8/upstream/v8/src/liveobjectlist-inl.h +0 -126
- data/ext/v8/upstream/v8/src/liveobjectlist.cc +0 -2589
- data/ext/v8/upstream/v8/src/liveobjectlist.h +0 -322
- data/ext/v8/upstream/v8/src/log-inl.h +0 -59
- data/ext/v8/upstream/v8/src/log-utils.cc +0 -423
- data/ext/v8/upstream/v8/src/log-utils.h +0 -229
- data/ext/v8/upstream/v8/src/log.cc +0 -1666
- data/ext/v8/upstream/v8/src/log.h +0 -446
- data/ext/v8/upstream/v8/src/macro-assembler.h +0 -120
- data/ext/v8/upstream/v8/src/macros.py +0 -178
- data/ext/v8/upstream/v8/src/mark-compact.cc +0 -3092
- data/ext/v8/upstream/v8/src/mark-compact.h +0 -506
- data/ext/v8/upstream/v8/src/math.js +0 -264
- data/ext/v8/upstream/v8/src/messages.cc +0 -166
- data/ext/v8/upstream/v8/src/messages.h +0 -114
- data/ext/v8/upstream/v8/src/messages.js +0 -1090
- data/ext/v8/upstream/v8/src/mips/assembler-mips-inl.h +0 -335
- data/ext/v8/upstream/v8/src/mips/assembler-mips.cc +0 -2093
- data/ext/v8/upstream/v8/src/mips/assembler-mips.h +0 -1066
- data/ext/v8/upstream/v8/src/mips/builtins-mips.cc +0 -148
- data/ext/v8/upstream/v8/src/mips/code-stubs-mips.cc +0 -752
- data/ext/v8/upstream/v8/src/mips/code-stubs-mips.h +0 -511
- data/ext/v8/upstream/v8/src/mips/codegen-mips-inl.h +0 -64
- data/ext/v8/upstream/v8/src/mips/codegen-mips.cc +0 -1213
- data/ext/v8/upstream/v8/src/mips/codegen-mips.h +0 -633
- data/ext/v8/upstream/v8/src/mips/constants-mips.cc +0 -352
- data/ext/v8/upstream/v8/src/mips/constants-mips.h +0 -723
- data/ext/v8/upstream/v8/src/mips/cpu-mips.cc +0 -90
- data/ext/v8/upstream/v8/src/mips/debug-mips.cc +0 -155
- data/ext/v8/upstream/v8/src/mips/deoptimizer-mips.cc +0 -91
- data/ext/v8/upstream/v8/src/mips/disasm-mips.cc +0 -1023
- data/ext/v8/upstream/v8/src/mips/frames-mips.cc +0 -48
- data/ext/v8/upstream/v8/src/mips/frames-mips.h +0 -179
- data/ext/v8/upstream/v8/src/mips/full-codegen-mips.cc +0 -727
- data/ext/v8/upstream/v8/src/mips/ic-mips.cc +0 -244
- data/ext/v8/upstream/v8/src/mips/jump-target-mips.cc +0 -80
- data/ext/v8/upstream/v8/src/mips/lithium-codegen-mips.h +0 -65
- data/ext/v8/upstream/v8/src/mips/lithium-mips.h +0 -304
- data/ext/v8/upstream/v8/src/mips/macro-assembler-mips.cc +0 -3327
- data/ext/v8/upstream/v8/src/mips/macro-assembler-mips.h +0 -1058
- data/ext/v8/upstream/v8/src/mips/regexp-macro-assembler-mips.cc +0 -478
- data/ext/v8/upstream/v8/src/mips/regexp-macro-assembler-mips.h +0 -250
- data/ext/v8/upstream/v8/src/mips/register-allocator-mips-inl.h +0 -134
- data/ext/v8/upstream/v8/src/mips/register-allocator-mips.cc +0 -63
- data/ext/v8/upstream/v8/src/mips/register-allocator-mips.h +0 -47
- data/ext/v8/upstream/v8/src/mips/simulator-mips.cc +0 -2438
- data/ext/v8/upstream/v8/src/mips/simulator-mips.h +0 -394
- data/ext/v8/upstream/v8/src/mips/stub-cache-mips.cc +0 -601
- data/ext/v8/upstream/v8/src/mips/virtual-frame-mips-inl.h +0 -58
- data/ext/v8/upstream/v8/src/mips/virtual-frame-mips.cc +0 -307
- data/ext/v8/upstream/v8/src/mips/virtual-frame-mips.h +0 -530
- data/ext/v8/upstream/v8/src/mirror-debugger.js +0 -2381
- data/ext/v8/upstream/v8/src/mksnapshot.cc +0 -256
- data/ext/v8/upstream/v8/src/natives.h +0 -63
- data/ext/v8/upstream/v8/src/objects-debug.cc +0 -722
- data/ext/v8/upstream/v8/src/objects-inl.h +0 -4166
- data/ext/v8/upstream/v8/src/objects-printer.cc +0 -801
- data/ext/v8/upstream/v8/src/objects-visiting.cc +0 -142
- data/ext/v8/upstream/v8/src/objects-visiting.h +0 -422
- data/ext/v8/upstream/v8/src/objects.cc +0 -10296
- data/ext/v8/upstream/v8/src/objects.h +0 -6662
- data/ext/v8/upstream/v8/src/parser.cc +0 -5168
- data/ext/v8/upstream/v8/src/parser.h +0 -823
- data/ext/v8/upstream/v8/src/platform-cygwin.cc +0 -811
- data/ext/v8/upstream/v8/src/platform-freebsd.cc +0 -854
- data/ext/v8/upstream/v8/src/platform-linux.cc +0 -1120
- data/ext/v8/upstream/v8/src/platform-macos.cc +0 -865
- data/ext/v8/upstream/v8/src/platform-nullos.cc +0 -504
- data/ext/v8/upstream/v8/src/platform-openbsd.cc +0 -672
- data/ext/v8/upstream/v8/src/platform-posix.cc +0 -424
- data/ext/v8/upstream/v8/src/platform-solaris.cc +0 -796
- data/ext/v8/upstream/v8/src/platform-tls-mac.h +0 -62
- data/ext/v8/upstream/v8/src/platform-tls-win32.h +0 -62
- data/ext/v8/upstream/v8/src/platform-tls.h +0 -50
- data/ext/v8/upstream/v8/src/platform-win32.cc +0 -2072
- data/ext/v8/upstream/v8/src/platform.h +0 -693
- data/ext/v8/upstream/v8/src/preparse-data.cc +0 -185
- data/ext/v8/upstream/v8/src/preparse-data.h +0 -249
- data/ext/v8/upstream/v8/src/preparser-api.cc +0 -219
- data/ext/v8/upstream/v8/src/preparser.cc +0 -1205
- data/ext/v8/upstream/v8/src/preparser.h +0 -278
- data/ext/v8/upstream/v8/src/prettyprinter.cc +0 -1530
- data/ext/v8/upstream/v8/src/prettyprinter.h +0 -223
- data/ext/v8/upstream/v8/src/profile-generator-inl.h +0 -128
- data/ext/v8/upstream/v8/src/profile-generator.cc +0 -3095
- data/ext/v8/upstream/v8/src/profile-generator.h +0 -1125
- data/ext/v8/upstream/v8/src/property.cc +0 -102
- data/ext/v8/upstream/v8/src/property.h +0 -348
- data/ext/v8/upstream/v8/src/regexp-macro-assembler-irregexp-inl.h +0 -78
- data/ext/v8/upstream/v8/src/regexp-macro-assembler-irregexp.cc +0 -470
- data/ext/v8/upstream/v8/src/regexp-macro-assembler-irregexp.h +0 -142
- data/ext/v8/upstream/v8/src/regexp-macro-assembler-tracer.cc +0 -373
- data/ext/v8/upstream/v8/src/regexp-macro-assembler-tracer.h +0 -104
- data/ext/v8/upstream/v8/src/regexp-macro-assembler.cc +0 -266
- data/ext/v8/upstream/v8/src/regexp-macro-assembler.h +0 -236
- data/ext/v8/upstream/v8/src/regexp-stack.cc +0 -111
- data/ext/v8/upstream/v8/src/regexp-stack.h +0 -147
- data/ext/v8/upstream/v8/src/regexp.js +0 -483
- data/ext/v8/upstream/v8/src/register-allocator-inl.h +0 -141
- data/ext/v8/upstream/v8/src/register-allocator.cc +0 -98
- data/ext/v8/upstream/v8/src/register-allocator.h +0 -310
- data/ext/v8/upstream/v8/src/rewriter.cc +0 -1024
- data/ext/v8/upstream/v8/src/rewriter.h +0 -59
- data/ext/v8/upstream/v8/src/runtime-profiler.cc +0 -478
- data/ext/v8/upstream/v8/src/runtime-profiler.h +0 -192
- data/ext/v8/upstream/v8/src/runtime.cc +0 -11949
- data/ext/v8/upstream/v8/src/runtime.h +0 -643
- data/ext/v8/upstream/v8/src/runtime.js +0 -643
- data/ext/v8/upstream/v8/src/safepoint-table.cc +0 -256
- data/ext/v8/upstream/v8/src/safepoint-table.h +0 -269
- data/ext/v8/upstream/v8/src/scanner-base.cc +0 -964
- data/ext/v8/upstream/v8/src/scanner-base.h +0 -664
- data/ext/v8/upstream/v8/src/scanner.cc +0 -584
- data/ext/v8/upstream/v8/src/scanner.h +0 -196
- data/ext/v8/upstream/v8/src/scopeinfo.cc +0 -631
- data/ext/v8/upstream/v8/src/scopeinfo.h +0 -249
- data/ext/v8/upstream/v8/src/scopes.cc +0 -1093
- data/ext/v8/upstream/v8/src/scopes.h +0 -508
- data/ext/v8/upstream/v8/src/serialize.cc +0 -1574
- data/ext/v8/upstream/v8/src/serialize.h +0 -589
- data/ext/v8/upstream/v8/src/shell.h +0 -55
- data/ext/v8/upstream/v8/src/simulator.h +0 -43
- data/ext/v8/upstream/v8/src/small-pointer-list.h +0 -163
- data/ext/v8/upstream/v8/src/smart-pointer.h +0 -109
- data/ext/v8/upstream/v8/src/snapshot-common.cc +0 -82
- data/ext/v8/upstream/v8/src/snapshot-empty.cc +0 -50
- data/ext/v8/upstream/v8/src/snapshot.h +0 -73
- data/ext/v8/upstream/v8/src/spaces-inl.h +0 -529
- data/ext/v8/upstream/v8/src/spaces.cc +0 -3147
- data/ext/v8/upstream/v8/src/spaces.h +0 -2368
- data/ext/v8/upstream/v8/src/splay-tree-inl.h +0 -310
- data/ext/v8/upstream/v8/src/splay-tree.h +0 -203
- data/ext/v8/upstream/v8/src/string-search.cc +0 -41
- data/ext/v8/upstream/v8/src/string-search.h +0 -568
- data/ext/v8/upstream/v8/src/string-stream.cc +0 -592
- data/ext/v8/upstream/v8/src/string-stream.h +0 -191
- data/ext/v8/upstream/v8/src/string.js +0 -915
- data/ext/v8/upstream/v8/src/strtod.cc +0 -440
- data/ext/v8/upstream/v8/src/strtod.h +0 -40
- data/ext/v8/upstream/v8/src/stub-cache.cc +0 -1940
- data/ext/v8/upstream/v8/src/stub-cache.h +0 -866
- data/ext/v8/upstream/v8/src/third_party/valgrind/valgrind.h +0 -3925
- data/ext/v8/upstream/v8/src/token.cc +0 -63
- data/ext/v8/upstream/v8/src/token.h +0 -288
- data/ext/v8/upstream/v8/src/top.cc +0 -983
- data/ext/v8/upstream/v8/src/type-info.cc +0 -472
- data/ext/v8/upstream/v8/src/type-info.h +0 -290
- data/ext/v8/upstream/v8/src/unbound-queue-inl.h +0 -95
- data/ext/v8/upstream/v8/src/unbound-queue.h +0 -67
- data/ext/v8/upstream/v8/src/unicode-inl.h +0 -238
- data/ext/v8/upstream/v8/src/unicode.cc +0 -1624
- data/ext/v8/upstream/v8/src/unicode.h +0 -280
- data/ext/v8/upstream/v8/src/uri.js +0 -402
- data/ext/v8/upstream/v8/src/utils.cc +0 -371
- data/ext/v8/upstream/v8/src/utils.h +0 -796
- data/ext/v8/upstream/v8/src/v8-counters.cc +0 -62
- data/ext/v8/upstream/v8/src/v8-counters.h +0 -311
- data/ext/v8/upstream/v8/src/v8.cc +0 -215
- data/ext/v8/upstream/v8/src/v8.h +0 -130
- data/ext/v8/upstream/v8/src/v8checks.h +0 -64
- data/ext/v8/upstream/v8/src/v8dll-main.cc +0 -39
- data/ext/v8/upstream/v8/src/v8globals.h +0 -486
- data/ext/v8/upstream/v8/src/v8memory.h +0 -82
- data/ext/v8/upstream/v8/src/v8natives.js +0 -1293
- data/ext/v8/upstream/v8/src/v8preparserdll-main.cc +0 -39
- data/ext/v8/upstream/v8/src/v8threads.cc +0 -453
- data/ext/v8/upstream/v8/src/v8threads.h +0 -164
- data/ext/v8/upstream/v8/src/v8utils.h +0 -317
- data/ext/v8/upstream/v8/src/variables.cc +0 -132
- data/ext/v8/upstream/v8/src/variables.h +0 -212
- data/ext/v8/upstream/v8/src/version.cc +0 -116
- data/ext/v8/upstream/v8/src/version.h +0 -68
- data/ext/v8/upstream/v8/src/virtual-frame-heavy-inl.h +0 -190
- data/ext/v8/upstream/v8/src/virtual-frame-heavy.cc +0 -312
- data/ext/v8/upstream/v8/src/virtual-frame-inl.h +0 -39
- data/ext/v8/upstream/v8/src/virtual-frame-light-inl.h +0 -171
- data/ext/v8/upstream/v8/src/virtual-frame-light.cc +0 -52
- data/ext/v8/upstream/v8/src/virtual-frame.cc +0 -49
- data/ext/v8/upstream/v8/src/virtual-frame.h +0 -59
- data/ext/v8/upstream/v8/src/vm-state-inl.h +0 -138
- data/ext/v8/upstream/v8/src/vm-state.h +0 -70
- data/ext/v8/upstream/v8/src/win32-headers.h +0 -96
- data/ext/v8/upstream/v8/src/x64/assembler-x64-inl.h +0 -456
- data/ext/v8/upstream/v8/src/x64/assembler-x64.cc +0 -2954
- data/ext/v8/upstream/v8/src/x64/assembler-x64.h +0 -1630
- data/ext/v8/upstream/v8/src/x64/builtins-x64.cc +0 -1493
- data/ext/v8/upstream/v8/src/x64/code-stubs-x64.cc +0 -5132
- data/ext/v8/upstream/v8/src/x64/code-stubs-x64.h +0 -477
- data/ext/v8/upstream/v8/src/x64/codegen-x64-inl.h +0 -46
- data/ext/v8/upstream/v8/src/x64/codegen-x64.cc +0 -8843
- data/ext/v8/upstream/v8/src/x64/codegen-x64.h +0 -753
- data/ext/v8/upstream/v8/src/x64/cpu-x64.cc +0 -88
- data/ext/v8/upstream/v8/src/x64/debug-x64.cc +0 -318
- data/ext/v8/upstream/v8/src/x64/deoptimizer-x64.cc +0 -815
- data/ext/v8/upstream/v8/src/x64/disasm-x64.cc +0 -1752
- data/ext/v8/upstream/v8/src/x64/frames-x64.cc +0 -45
- data/ext/v8/upstream/v8/src/x64/frames-x64.h +0 -130
- data/ext/v8/upstream/v8/src/x64/full-codegen-x64.cc +0 -4339
- data/ext/v8/upstream/v8/src/x64/ic-x64.cc +0 -1752
- data/ext/v8/upstream/v8/src/x64/jump-target-x64.cc +0 -437
- data/ext/v8/upstream/v8/src/x64/lithium-codegen-x64.cc +0 -3970
- data/ext/v8/upstream/v8/src/x64/lithium-codegen-x64.h +0 -318
- data/ext/v8/upstream/v8/src/x64/lithium-gap-resolver-x64.cc +0 -320
- data/ext/v8/upstream/v8/src/x64/lithium-gap-resolver-x64.h +0 -74
- data/ext/v8/upstream/v8/src/x64/lithium-x64.cc +0 -2115
- data/ext/v8/upstream/v8/src/x64/lithium-x64.h +0 -2161
- data/ext/v8/upstream/v8/src/x64/macro-assembler-x64.cc +0 -2911
- data/ext/v8/upstream/v8/src/x64/macro-assembler-x64.h +0 -1984
- data/ext/v8/upstream/v8/src/x64/regexp-macro-assembler-x64.cc +0 -1398
- data/ext/v8/upstream/v8/src/x64/regexp-macro-assembler-x64.h +0 -282
- data/ext/v8/upstream/v8/src/x64/register-allocator-x64-inl.h +0 -87
- data/ext/v8/upstream/v8/src/x64/register-allocator-x64.cc +0 -95
- data/ext/v8/upstream/v8/src/x64/register-allocator-x64.h +0 -43
- data/ext/v8/upstream/v8/src/x64/simulator-x64.cc +0 -27
- data/ext/v8/upstream/v8/src/x64/simulator-x64.h +0 -71
- data/ext/v8/upstream/v8/src/x64/stub-cache-x64.cc +0 -3460
- data/ext/v8/upstream/v8/src/x64/virtual-frame-x64.cc +0 -1296
- data/ext/v8/upstream/v8/src/x64/virtual-frame-x64.h +0 -597
- data/ext/v8/upstream/v8/src/zone-inl.h +0 -129
- data/ext/v8/upstream/v8/src/zone.cc +0 -196
- data/ext/v8/upstream/v8/src/zone.h +0 -236
- data/ext/v8/upstream/v8/tools/codemap.js +0 -265
- data/ext/v8/upstream/v8/tools/consarray.js +0 -93
- data/ext/v8/upstream/v8/tools/csvparser.js +0 -78
- data/ext/v8/upstream/v8/tools/disasm.py +0 -92
- data/ext/v8/upstream/v8/tools/freebsd-tick-processor +0 -10
- data/ext/v8/upstream/v8/tools/gc-nvp-trace-processor.py +0 -328
- data/ext/v8/upstream/v8/tools/generate-ten-powers.scm +0 -286
- data/ext/v8/upstream/v8/tools/grokdump.py +0 -840
- data/ext/v8/upstream/v8/tools/gyp/v8.gyp +0 -844
- data/ext/v8/upstream/v8/tools/js2c.py +0 -380
- data/ext/v8/upstream/v8/tools/jsmin.py +0 -280
- data/ext/v8/upstream/v8/tools/linux-tick-processor +0 -35
- data/ext/v8/upstream/v8/tools/ll_prof.py +0 -919
- data/ext/v8/upstream/v8/tools/logreader.js +0 -185
- data/ext/v8/upstream/v8/tools/mac-nm +0 -18
- data/ext/v8/upstream/v8/tools/mac-tick-processor +0 -6
- data/ext/v8/upstream/v8/tools/oom_dump/README +0 -31
- data/ext/v8/upstream/v8/tools/oom_dump/SConstruct +0 -42
- data/ext/v8/upstream/v8/tools/oom_dump/oom_dump.cc +0 -288
- data/ext/v8/upstream/v8/tools/presubmit.py +0 -305
- data/ext/v8/upstream/v8/tools/process-heap-prof.py +0 -120
- data/ext/v8/upstream/v8/tools/profile.js +0 -751
- data/ext/v8/upstream/v8/tools/profile_view.js +0 -219
- data/ext/v8/upstream/v8/tools/run-valgrind.py +0 -77
- data/ext/v8/upstream/v8/tools/splaytree.js +0 -316
- data/ext/v8/upstream/v8/tools/stats-viewer.py +0 -468
- data/ext/v8/upstream/v8/tools/test.py +0 -1490
- data/ext/v8/upstream/v8/tools/tickprocessor-driver.js +0 -59
- data/ext/v8/upstream/v8/tools/tickprocessor.js +0 -877
- data/ext/v8/upstream/v8/tools/utils.py +0 -96
- data/ext/v8/upstream/v8/tools/visual_studio/README.txt +0 -70
- data/ext/v8/upstream/v8/tools/visual_studio/arm.vsprops +0 -14
- data/ext/v8/upstream/v8/tools/visual_studio/common.vsprops +0 -34
- data/ext/v8/upstream/v8/tools/visual_studio/d8.vcproj +0 -193
- data/ext/v8/upstream/v8/tools/visual_studio/d8_arm.vcproj +0 -193
- data/ext/v8/upstream/v8/tools/visual_studio/d8_x64.vcproj +0 -209
- data/ext/v8/upstream/v8/tools/visual_studio/d8js2c.cmd +0 -6
- data/ext/v8/upstream/v8/tools/visual_studio/debug.vsprops +0 -17
- data/ext/v8/upstream/v8/tools/visual_studio/ia32.vsprops +0 -17
- data/ext/v8/upstream/v8/tools/visual_studio/js2c.cmd +0 -6
- data/ext/v8/upstream/v8/tools/visual_studio/release.vsprops +0 -24
- data/ext/v8/upstream/v8/tools/visual_studio/v8.sln +0 -101
- data/ext/v8/upstream/v8/tools/visual_studio/v8.vcproj +0 -227
- data/ext/v8/upstream/v8/tools/visual_studio/v8_arm.sln +0 -74
- data/ext/v8/upstream/v8/tools/visual_studio/v8_arm.vcproj +0 -227
- data/ext/v8/upstream/v8/tools/visual_studio/v8_base.vcproj +0 -1308
- data/ext/v8/upstream/v8/tools/visual_studio/v8_base_arm.vcproj +0 -1238
- data/ext/v8/upstream/v8/tools/visual_studio/v8_base_x64.vcproj +0 -1300
- data/ext/v8/upstream/v8/tools/visual_studio/v8_cctest.vcproj +0 -265
- data/ext/v8/upstream/v8/tools/visual_studio/v8_cctest_arm.vcproj +0 -249
- data/ext/v8/upstream/v8/tools/visual_studio/v8_cctest_x64.vcproj +0 -257
- data/ext/v8/upstream/v8/tools/visual_studio/v8_mksnapshot.vcproj +0 -145
- data/ext/v8/upstream/v8/tools/visual_studio/v8_mksnapshot_x64.vcproj +0 -145
- data/ext/v8/upstream/v8/tools/visual_studio/v8_process_sample.vcproj +0 -145
- data/ext/v8/upstream/v8/tools/visual_studio/v8_process_sample_arm.vcproj +0 -145
- data/ext/v8/upstream/v8/tools/visual_studio/v8_process_sample_x64.vcproj +0 -161
- data/ext/v8/upstream/v8/tools/visual_studio/v8_shell_sample.vcproj +0 -147
- data/ext/v8/upstream/v8/tools/visual_studio/v8_shell_sample_arm.vcproj +0 -147
- data/ext/v8/upstream/v8/tools/visual_studio/v8_shell_sample_x64.vcproj +0 -163
- data/ext/v8/upstream/v8/tools/visual_studio/v8_snapshot.vcproj +0 -142
- data/ext/v8/upstream/v8/tools/visual_studio/v8_snapshot_cc.vcproj +0 -92
- data/ext/v8/upstream/v8/tools/visual_studio/v8_snapshot_cc_x64.vcproj +0 -92
- data/ext/v8/upstream/v8/tools/visual_studio/v8_snapshot_x64.vcproj +0 -142
- data/ext/v8/upstream/v8/tools/visual_studio/v8_x64.sln +0 -101
- data/ext/v8/upstream/v8/tools/visual_studio/v8_x64.vcproj +0 -227
- data/ext/v8/upstream/v8/tools/visual_studio/x64.vsprops +0 -18
- data/ext/v8/upstream/v8/tools/windows-tick-processor.bat +0 -30
@@ -1,249 +0,0 @@
|
|
1
|
-
// Copyright 2006-2008 the V8 project authors. All rights reserved.
|
2
|
-
// Redistribution and use in source and binary forms, with or without
|
3
|
-
// modification, are permitted provided that the following conditions are
|
4
|
-
// met:
|
5
|
-
//
|
6
|
-
// * Redistributions of source code must retain the above copyright
|
7
|
-
// notice, this list of conditions and the following disclaimer.
|
8
|
-
// * Redistributions in binary form must reproduce the above
|
9
|
-
// copyright notice, this list of conditions and the following
|
10
|
-
// disclaimer in the documentation and/or other materials provided
|
11
|
-
// with the distribution.
|
12
|
-
// * Neither the name of Google Inc. nor the names of its
|
13
|
-
// contributors may be used to endorse or promote products derived
|
14
|
-
// from this software without specific prior written permission.
|
15
|
-
//
|
16
|
-
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
17
|
-
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
18
|
-
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
19
|
-
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
20
|
-
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
21
|
-
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
22
|
-
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
23
|
-
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
24
|
-
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
25
|
-
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
26
|
-
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
27
|
-
|
28
|
-
#ifndef V8_SCOPEINFO_H_
|
29
|
-
#define V8_SCOPEINFO_H_
|
30
|
-
|
31
|
-
#include "variables.h"
|
32
|
-
#include "zone-inl.h"
|
33
|
-
|
34
|
-
namespace v8 {
|
35
|
-
namespace internal {
|
36
|
-
|
37
|
-
// Scope information represents information about a functions's
|
38
|
-
// scopes (currently only one, because we don't do any inlining)
|
39
|
-
// and the allocation of the scope's variables. Scope information
|
40
|
-
// is stored in a compressed form in FixedArray objects and is used
|
41
|
-
// at runtime (stack dumps, deoptimization, etc.).
|
42
|
-
//
|
43
|
-
// Historical note: In other VMs built by this team, ScopeInfo was
|
44
|
-
// usually called DebugInfo since the information was used (among
|
45
|
-
// other things) for on-demand debugging (Self, Smalltalk). However,
|
46
|
-
// DebugInfo seems misleading, since this information is primarily used
|
47
|
-
// in debugging-unrelated contexts.
|
48
|
-
|
49
|
-
// Forward defined as
|
50
|
-
// template <class Allocator = FreeStoreAllocationPolicy> class ScopeInfo;
|
51
|
-
template<class Allocator>
|
52
|
-
class ScopeInfo BASE_EMBEDDED {
|
53
|
-
public:
|
54
|
-
// Create a ScopeInfo instance from a scope.
|
55
|
-
explicit ScopeInfo(Scope* scope);
|
56
|
-
|
57
|
-
// Create a ScopeInfo instance from SerializedScopeInfo.
|
58
|
-
explicit ScopeInfo(SerializedScopeInfo* data);
|
59
|
-
|
60
|
-
// Creates a SerializedScopeInfo holding the serialized scope info.
|
61
|
-
Handle<SerializedScopeInfo> Serialize();
|
62
|
-
|
63
|
-
// --------------------------------------------------------------------------
|
64
|
-
// Lookup
|
65
|
-
|
66
|
-
Handle<String> function_name() const { return function_name_; }
|
67
|
-
|
68
|
-
Handle<String> parameter_name(int i) const { return parameters_[i]; }
|
69
|
-
int number_of_parameters() const { return parameters_.length(); }
|
70
|
-
|
71
|
-
Handle<String> stack_slot_name(int i) const { return stack_slots_[i]; }
|
72
|
-
int number_of_stack_slots() const { return stack_slots_.length(); }
|
73
|
-
|
74
|
-
Handle<String> context_slot_name(int i) const {
|
75
|
-
return context_slots_[i - Context::MIN_CONTEXT_SLOTS];
|
76
|
-
}
|
77
|
-
int number_of_context_slots() const {
|
78
|
-
int l = context_slots_.length();
|
79
|
-
return l == 0 ? 0 : l + Context::MIN_CONTEXT_SLOTS;
|
80
|
-
}
|
81
|
-
|
82
|
-
Handle<String> LocalName(int i) const;
|
83
|
-
int NumberOfLocals() const;
|
84
|
-
|
85
|
-
// --------------------------------------------------------------------------
|
86
|
-
// Debugging support
|
87
|
-
|
88
|
-
#ifdef DEBUG
|
89
|
-
void Print();
|
90
|
-
#endif
|
91
|
-
|
92
|
-
private:
|
93
|
-
Handle<String> function_name_;
|
94
|
-
bool calls_eval_;
|
95
|
-
List<Handle<String>, Allocator > parameters_;
|
96
|
-
List<Handle<String>, Allocator > stack_slots_;
|
97
|
-
List<Handle<String>, Allocator > context_slots_;
|
98
|
-
List<Variable::Mode, Allocator > context_modes_;
|
99
|
-
};
|
100
|
-
|
101
|
-
|
102
|
-
// This object provides quick access to scope info details for runtime
|
103
|
-
// routines w/o the need to explicitly create a ScopeInfo object.
|
104
|
-
class SerializedScopeInfo : public FixedArray {
|
105
|
-
public :
|
106
|
-
|
107
|
-
static SerializedScopeInfo* cast(Object* object) {
|
108
|
-
ASSERT(object->IsFixedArray());
|
109
|
-
return reinterpret_cast<SerializedScopeInfo*>(object);
|
110
|
-
}
|
111
|
-
|
112
|
-
// Does this scope call eval?
|
113
|
-
bool CallsEval();
|
114
|
-
|
115
|
-
// Does this scope have an arguments shadow?
|
116
|
-
bool HasArgumentsShadow() {
|
117
|
-
return StackSlotIndex(GetHeap()->arguments_shadow_symbol()) >= 0;
|
118
|
-
}
|
119
|
-
|
120
|
-
// Return the number of stack slots for code.
|
121
|
-
int NumberOfStackSlots();
|
122
|
-
|
123
|
-
// Return the number of context slots for code.
|
124
|
-
int NumberOfContextSlots();
|
125
|
-
|
126
|
-
// Return if this has context slots besides MIN_CONTEXT_SLOTS;
|
127
|
-
bool HasHeapAllocatedLocals();
|
128
|
-
|
129
|
-
// Lookup support for serialized scope info. Returns the
|
130
|
-
// the stack slot index for a given slot name if the slot is
|
131
|
-
// present; otherwise returns a value < 0. The name must be a symbol
|
132
|
-
// (canonicalized).
|
133
|
-
int StackSlotIndex(String* name);
|
134
|
-
|
135
|
-
// Lookup support for serialized scope info. Returns the
|
136
|
-
// context slot index for a given slot name if the slot is present; otherwise
|
137
|
-
// returns a value < 0. The name must be a symbol (canonicalized).
|
138
|
-
// If the slot is present and mode != NULL, sets *mode to the corresponding
|
139
|
-
// mode for that variable.
|
140
|
-
int ContextSlotIndex(String* name, Variable::Mode* mode);
|
141
|
-
|
142
|
-
// Lookup support for serialized scope info. Returns the
|
143
|
-
// parameter index for a given parameter name if the parameter is present;
|
144
|
-
// otherwise returns a value < 0. The name must be a symbol (canonicalized).
|
145
|
-
int ParameterIndex(String* name);
|
146
|
-
|
147
|
-
// Lookup support for serialized scope info. Returns the
|
148
|
-
// function context slot index if the function name is present (named
|
149
|
-
// function expressions, only), otherwise returns a value < 0. The name
|
150
|
-
// must be a symbol (canonicalized).
|
151
|
-
int FunctionContextSlotIndex(String* name);
|
152
|
-
|
153
|
-
static Handle<SerializedScopeInfo> Create(Scope* scope);
|
154
|
-
|
155
|
-
// Serializes empty scope info.
|
156
|
-
static SerializedScopeInfo* Empty();
|
157
|
-
|
158
|
-
private:
|
159
|
-
|
160
|
-
inline Object** ContextEntriesAddr();
|
161
|
-
|
162
|
-
inline Object** ParameterEntriesAddr();
|
163
|
-
|
164
|
-
inline Object** StackSlotEntriesAddr();
|
165
|
-
};
|
166
|
-
|
167
|
-
|
168
|
-
// Cache for mapping (data, property name) into context slot index.
|
169
|
-
// The cache contains both positive and negative results.
|
170
|
-
// Slot index equals -1 means the property is absent.
|
171
|
-
// Cleared at startup and prior to mark sweep collection.
|
172
|
-
class ContextSlotCache {
|
173
|
-
public:
|
174
|
-
// Lookup context slot index for (data, name).
|
175
|
-
// If absent, kNotFound is returned.
|
176
|
-
int Lookup(Object* data,
|
177
|
-
String* name,
|
178
|
-
Variable::Mode* mode);
|
179
|
-
|
180
|
-
// Update an element in the cache.
|
181
|
-
void Update(Object* data,
|
182
|
-
String* name,
|
183
|
-
Variable::Mode mode,
|
184
|
-
int slot_index);
|
185
|
-
|
186
|
-
// Clear the cache.
|
187
|
-
void Clear();
|
188
|
-
|
189
|
-
static const int kNotFound = -2;
|
190
|
-
private:
|
191
|
-
ContextSlotCache() {
|
192
|
-
for (int i = 0; i < kLength; ++i) {
|
193
|
-
keys_[i].data = NULL;
|
194
|
-
keys_[i].name = NULL;
|
195
|
-
values_[i] = kNotFound;
|
196
|
-
}
|
197
|
-
}
|
198
|
-
|
199
|
-
inline static int Hash(Object* data, String* name);
|
200
|
-
|
201
|
-
#ifdef DEBUG
|
202
|
-
void ValidateEntry(Object* data,
|
203
|
-
String* name,
|
204
|
-
Variable::Mode mode,
|
205
|
-
int slot_index);
|
206
|
-
#endif
|
207
|
-
|
208
|
-
static const int kLength = 256;
|
209
|
-
struct Key {
|
210
|
-
Object* data;
|
211
|
-
String* name;
|
212
|
-
};
|
213
|
-
|
214
|
-
struct Value {
|
215
|
-
Value(Variable::Mode mode, int index) {
|
216
|
-
ASSERT(ModeField::is_valid(mode));
|
217
|
-
ASSERT(IndexField::is_valid(index));
|
218
|
-
value_ = ModeField::encode(mode) | IndexField::encode(index);
|
219
|
-
ASSERT(mode == this->mode());
|
220
|
-
ASSERT(index == this->index());
|
221
|
-
}
|
222
|
-
|
223
|
-
inline Value(uint32_t value) : value_(value) {}
|
224
|
-
|
225
|
-
uint32_t raw() { return value_; }
|
226
|
-
|
227
|
-
Variable::Mode mode() { return ModeField::decode(value_); }
|
228
|
-
|
229
|
-
int index() { return IndexField::decode(value_); }
|
230
|
-
|
231
|
-
// Bit fields in value_ (type, shift, size). Must be public so the
|
232
|
-
// constants can be embedded in generated code.
|
233
|
-
class ModeField: public BitField<Variable::Mode, 0, 3> {};
|
234
|
-
class IndexField: public BitField<int, 3, 32-3> {};
|
235
|
-
private:
|
236
|
-
uint32_t value_;
|
237
|
-
};
|
238
|
-
|
239
|
-
Key keys_[kLength];
|
240
|
-
uint32_t values_[kLength];
|
241
|
-
|
242
|
-
friend class Isolate;
|
243
|
-
DISALLOW_COPY_AND_ASSIGN(ContextSlotCache);
|
244
|
-
};
|
245
|
-
|
246
|
-
|
247
|
-
} } // namespace v8::internal
|
248
|
-
|
249
|
-
#endif // V8_SCOPEINFO_H_
|
@@ -1,1093 +0,0 @@
|
|
1
|
-
// Copyright 2010 the V8 project authors. All rights reserved.
|
2
|
-
// Redistribution and use in source and binary forms, with or without
|
3
|
-
// modification, are permitted provided that the following conditions are
|
4
|
-
// met:
|
5
|
-
//
|
6
|
-
// * Redistributions of source code must retain the above copyright
|
7
|
-
// notice, this list of conditions and the following disclaimer.
|
8
|
-
// * Redistributions in binary form must reproduce the above
|
9
|
-
// copyright notice, this list of conditions and the following
|
10
|
-
// disclaimer in the documentation and/or other materials provided
|
11
|
-
// with the distribution.
|
12
|
-
// * Neither the name of Google Inc. nor the names of its
|
13
|
-
// contributors may be used to endorse or promote products derived
|
14
|
-
// from this software without specific prior written permission.
|
15
|
-
//
|
16
|
-
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
17
|
-
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
18
|
-
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
19
|
-
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
20
|
-
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
21
|
-
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
22
|
-
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
23
|
-
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
24
|
-
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
25
|
-
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
26
|
-
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
27
|
-
|
28
|
-
#include "v8.h"
|
29
|
-
|
30
|
-
#include "scopes.h"
|
31
|
-
|
32
|
-
#include "bootstrapper.h"
|
33
|
-
#include "compiler.h"
|
34
|
-
#include "prettyprinter.h"
|
35
|
-
#include "scopeinfo.h"
|
36
|
-
|
37
|
-
namespace v8 {
|
38
|
-
namespace internal {
|
39
|
-
|
40
|
-
// ----------------------------------------------------------------------------
|
41
|
-
// A Zone allocator for use with LocalsMap.
|
42
|
-
|
43
|
-
// TODO(isolates): It is probably worth it to change the Allocator class to
|
44
|
-
// take a pointer to an isolate.
|
45
|
-
class ZoneAllocator: public Allocator {
|
46
|
-
public:
|
47
|
-
/* nothing to do */
|
48
|
-
virtual ~ZoneAllocator() {}
|
49
|
-
|
50
|
-
virtual void* New(size_t size) { return ZONE->New(static_cast<int>(size)); }
|
51
|
-
|
52
|
-
/* ignored - Zone is freed in one fell swoop */
|
53
|
-
virtual void Delete(void* p) {}
|
54
|
-
};
|
55
|
-
|
56
|
-
|
57
|
-
static ZoneAllocator LocalsMapAllocator;
|
58
|
-
|
59
|
-
|
60
|
-
// ----------------------------------------------------------------------------
|
61
|
-
// Implementation of LocalsMap
|
62
|
-
//
|
63
|
-
// Note: We are storing the handle locations as key values in the hash map.
|
64
|
-
// When inserting a new variable via Declare(), we rely on the fact that
|
65
|
-
// the handle location remains alive for the duration of that variable
|
66
|
-
// use. Because a Variable holding a handle with the same location exists
|
67
|
-
// this is ensured.
|
68
|
-
|
69
|
-
static bool Match(void* key1, void* key2) {
|
70
|
-
String* name1 = *reinterpret_cast<String**>(key1);
|
71
|
-
String* name2 = *reinterpret_cast<String**>(key2);
|
72
|
-
ASSERT(name1->IsSymbol());
|
73
|
-
ASSERT(name2->IsSymbol());
|
74
|
-
return name1 == name2;
|
75
|
-
}
|
76
|
-
|
77
|
-
|
78
|
-
// Dummy constructor
|
79
|
-
VariableMap::VariableMap(bool gotta_love_static_overloading) : HashMap() {}
|
80
|
-
|
81
|
-
VariableMap::VariableMap() : HashMap(Match, &LocalsMapAllocator, 8) {}
|
82
|
-
VariableMap::~VariableMap() {}
|
83
|
-
|
84
|
-
|
85
|
-
Variable* VariableMap::Declare(Scope* scope,
|
86
|
-
Handle<String> name,
|
87
|
-
Variable::Mode mode,
|
88
|
-
bool is_valid_lhs,
|
89
|
-
Variable::Kind kind) {
|
90
|
-
HashMap::Entry* p = HashMap::Lookup(name.location(), name->Hash(), true);
|
91
|
-
if (p->value == NULL) {
|
92
|
-
// The variable has not been declared yet -> insert it.
|
93
|
-
ASSERT(p->key == name.location());
|
94
|
-
p->value = new Variable(scope, name, mode, is_valid_lhs, kind);
|
95
|
-
}
|
96
|
-
return reinterpret_cast<Variable*>(p->value);
|
97
|
-
}
|
98
|
-
|
99
|
-
|
100
|
-
Variable* VariableMap::Lookup(Handle<String> name) {
|
101
|
-
HashMap::Entry* p = HashMap::Lookup(name.location(), name->Hash(), false);
|
102
|
-
if (p != NULL) {
|
103
|
-
ASSERT(*reinterpret_cast<String**>(p->key) == *name);
|
104
|
-
ASSERT(p->value != NULL);
|
105
|
-
return reinterpret_cast<Variable*>(p->value);
|
106
|
-
}
|
107
|
-
return NULL;
|
108
|
-
}
|
109
|
-
|
110
|
-
|
111
|
-
// ----------------------------------------------------------------------------
|
112
|
-
// Implementation of Scope
|
113
|
-
|
114
|
-
|
115
|
-
// Dummy constructor
|
116
|
-
Scope::Scope(Type type)
|
117
|
-
: inner_scopes_(0),
|
118
|
-
variables_(false),
|
119
|
-
temps_(0),
|
120
|
-
params_(0),
|
121
|
-
unresolved_(0),
|
122
|
-
decls_(0) {
|
123
|
-
SetDefaults(type, NULL, NULL);
|
124
|
-
ASSERT(!resolved());
|
125
|
-
}
|
126
|
-
|
127
|
-
|
128
|
-
Scope::Scope(Scope* outer_scope, Type type)
|
129
|
-
: inner_scopes_(4),
|
130
|
-
variables_(),
|
131
|
-
temps_(4),
|
132
|
-
params_(4),
|
133
|
-
unresolved_(16),
|
134
|
-
decls_(4) {
|
135
|
-
SetDefaults(type, outer_scope, NULL);
|
136
|
-
// At some point we might want to provide outer scopes to
|
137
|
-
// eval scopes (by walking the stack and reading the scope info).
|
138
|
-
// In that case, the ASSERT below needs to be adjusted.
|
139
|
-
ASSERT((type == GLOBAL_SCOPE || type == EVAL_SCOPE) == (outer_scope == NULL));
|
140
|
-
ASSERT(!HasIllegalRedeclaration());
|
141
|
-
ASSERT(!resolved());
|
142
|
-
}
|
143
|
-
|
144
|
-
|
145
|
-
Scope::Scope(Scope* inner_scope, SerializedScopeInfo* scope_info)
|
146
|
-
: inner_scopes_(4),
|
147
|
-
variables_(),
|
148
|
-
temps_(4),
|
149
|
-
params_(4),
|
150
|
-
unresolved_(16),
|
151
|
-
decls_(4) {
|
152
|
-
ASSERT(scope_info != NULL);
|
153
|
-
SetDefaults(FUNCTION_SCOPE, NULL, scope_info);
|
154
|
-
ASSERT(resolved());
|
155
|
-
if (scope_info->HasHeapAllocatedLocals()) {
|
156
|
-
num_heap_slots_ = scope_info_->NumberOfContextSlots();
|
157
|
-
}
|
158
|
-
|
159
|
-
AddInnerScope(inner_scope);
|
160
|
-
|
161
|
-
// This scope's arguments shadow (if present) is context-allocated if an inner
|
162
|
-
// scope accesses this one's parameters. Allocate the arguments_shadow_
|
163
|
-
// variable if necessary.
|
164
|
-
Isolate* isolate = Isolate::Current();
|
165
|
-
Variable::Mode mode;
|
166
|
-
int arguments_shadow_index =
|
167
|
-
scope_info_->ContextSlotIndex(
|
168
|
-
isolate->heap()->arguments_shadow_symbol(), &mode);
|
169
|
-
if (arguments_shadow_index >= 0) {
|
170
|
-
ASSERT(mode == Variable::INTERNAL);
|
171
|
-
arguments_shadow_ = new Variable(
|
172
|
-
this,
|
173
|
-
isolate->factory()->arguments_shadow_symbol(),
|
174
|
-
Variable::INTERNAL,
|
175
|
-
true,
|
176
|
-
Variable::ARGUMENTS);
|
177
|
-
arguments_shadow_->set_rewrite(
|
178
|
-
new Slot(arguments_shadow_, Slot::CONTEXT, arguments_shadow_index));
|
179
|
-
arguments_shadow_->set_is_used(true);
|
180
|
-
}
|
181
|
-
}
|
182
|
-
|
183
|
-
|
184
|
-
Scope* Scope::DeserializeScopeChain(CompilationInfo* info,
|
185
|
-
Scope* global_scope) {
|
186
|
-
ASSERT(!info->closure().is_null());
|
187
|
-
// If we have a serialized scope info, reuse it.
|
188
|
-
Scope* innermost_scope = NULL;
|
189
|
-
Scope* scope = NULL;
|
190
|
-
|
191
|
-
SerializedScopeInfo* scope_info = info->closure()->shared()->scope_info();
|
192
|
-
if (scope_info != SerializedScopeInfo::Empty()) {
|
193
|
-
JSFunction* current = *info->closure();
|
194
|
-
do {
|
195
|
-
current = current->context()->closure();
|
196
|
-
SerializedScopeInfo* scope_info = current->shared()->scope_info();
|
197
|
-
if (scope_info != SerializedScopeInfo::Empty()) {
|
198
|
-
scope = new Scope(scope, scope_info);
|
199
|
-
if (innermost_scope == NULL) innermost_scope = scope;
|
200
|
-
} else {
|
201
|
-
ASSERT(current->context()->IsGlobalContext());
|
202
|
-
}
|
203
|
-
} while (!current->context()->IsGlobalContext());
|
204
|
-
}
|
205
|
-
|
206
|
-
global_scope->AddInnerScope(scope);
|
207
|
-
if (innermost_scope == NULL) innermost_scope = global_scope;
|
208
|
-
|
209
|
-
return innermost_scope;
|
210
|
-
}
|
211
|
-
|
212
|
-
|
213
|
-
bool Scope::Analyze(CompilationInfo* info) {
|
214
|
-
ASSERT(info->function() != NULL);
|
215
|
-
Scope* top = info->function()->scope();
|
216
|
-
|
217
|
-
while (top->outer_scope() != NULL) top = top->outer_scope();
|
218
|
-
top->AllocateVariables(info->calling_context());
|
219
|
-
|
220
|
-
#ifdef DEBUG
|
221
|
-
if (info->isolate()->bootstrapper()->IsActive()
|
222
|
-
? FLAG_print_builtin_scopes
|
223
|
-
: FLAG_print_scopes) {
|
224
|
-
info->function()->scope()->Print();
|
225
|
-
}
|
226
|
-
#endif
|
227
|
-
|
228
|
-
info->SetScope(info->function()->scope());
|
229
|
-
return true; // Can not fail.
|
230
|
-
}
|
231
|
-
|
232
|
-
|
233
|
-
void Scope::Initialize(bool inside_with) {
|
234
|
-
ASSERT(!resolved());
|
235
|
-
|
236
|
-
// Add this scope as a new inner scope of the outer scope.
|
237
|
-
if (outer_scope_ != NULL) {
|
238
|
-
outer_scope_->inner_scopes_.Add(this);
|
239
|
-
scope_inside_with_ = outer_scope_->scope_inside_with_ || inside_with;
|
240
|
-
} else {
|
241
|
-
scope_inside_with_ = inside_with;
|
242
|
-
}
|
243
|
-
|
244
|
-
// Declare convenience variables.
|
245
|
-
// Declare and allocate receiver (even for the global scope, and even
|
246
|
-
// if naccesses_ == 0).
|
247
|
-
// NOTE: When loading parameters in the global scope, we must take
|
248
|
-
// care not to access them as properties of the global object, but
|
249
|
-
// instead load them directly from the stack. Currently, the only
|
250
|
-
// such parameter is 'this' which is passed on the stack when
|
251
|
-
// invoking scripts
|
252
|
-
Variable* var =
|
253
|
-
variables_.Declare(this, FACTORY->this_symbol(), Variable::VAR,
|
254
|
-
false, Variable::THIS);
|
255
|
-
var->set_rewrite(new Slot(var, Slot::PARAMETER, -1));
|
256
|
-
receiver_ = var;
|
257
|
-
|
258
|
-
if (is_function_scope()) {
|
259
|
-
// Declare 'arguments' variable which exists in all functions.
|
260
|
-
// Note that it might never be accessed, in which case it won't be
|
261
|
-
// allocated during variable allocation.
|
262
|
-
variables_.Declare(this, FACTORY->arguments_symbol(), Variable::VAR,
|
263
|
-
true, Variable::ARGUMENTS);
|
264
|
-
}
|
265
|
-
}
|
266
|
-
|
267
|
-
|
268
|
-
Variable* Scope::LocalLookup(Handle<String> name) {
|
269
|
-
Variable* result = variables_.Lookup(name);
|
270
|
-
if (result != NULL || !resolved()) {
|
271
|
-
return result;
|
272
|
-
}
|
273
|
-
// If the scope is resolved, we can find a variable in serialized scope info.
|
274
|
-
|
275
|
-
// We should never lookup 'arguments' in this scope
|
276
|
-
// as it is implicitly present in any scope.
|
277
|
-
ASSERT(*name != *FACTORY->arguments_symbol());
|
278
|
-
|
279
|
-
// Assert that there is no local slot with the given name.
|
280
|
-
ASSERT(scope_info_->StackSlotIndex(*name) < 0);
|
281
|
-
|
282
|
-
// Check context slot lookup.
|
283
|
-
Variable::Mode mode;
|
284
|
-
int index = scope_info_->ContextSlotIndex(*name, &mode);
|
285
|
-
if (index >= 0) {
|
286
|
-
Variable* var =
|
287
|
-
variables_.Declare(this, name, mode, true, Variable::NORMAL);
|
288
|
-
var->set_rewrite(new Slot(var, Slot::CONTEXT, index));
|
289
|
-
return var;
|
290
|
-
}
|
291
|
-
|
292
|
-
index = scope_info_->ParameterIndex(*name);
|
293
|
-
if (index >= 0) {
|
294
|
-
// ".arguments" must be present in context slots.
|
295
|
-
ASSERT(arguments_shadow_ != NULL);
|
296
|
-
Variable* var =
|
297
|
-
variables_.Declare(this, name, Variable::VAR, true, Variable::NORMAL);
|
298
|
-
Property* rewrite =
|
299
|
-
new Property(new VariableProxy(arguments_shadow_),
|
300
|
-
new Literal(Handle<Object>(Smi::FromInt(index))),
|
301
|
-
RelocInfo::kNoPosition,
|
302
|
-
Property::SYNTHETIC);
|
303
|
-
rewrite->set_is_arguments_access(true);
|
304
|
-
var->set_rewrite(rewrite);
|
305
|
-
return var;
|
306
|
-
}
|
307
|
-
|
308
|
-
index = scope_info_->FunctionContextSlotIndex(*name);
|
309
|
-
if (index >= 0) {
|
310
|
-
// Check that there is no local slot with the given name.
|
311
|
-
ASSERT(scope_info_->StackSlotIndex(*name) < 0);
|
312
|
-
Variable* var =
|
313
|
-
variables_.Declare(this, name, Variable::VAR, true, Variable::NORMAL);
|
314
|
-
var->set_rewrite(new Slot(var, Slot::CONTEXT, index));
|
315
|
-
return var;
|
316
|
-
}
|
317
|
-
|
318
|
-
return NULL;
|
319
|
-
}
|
320
|
-
|
321
|
-
|
322
|
-
Variable* Scope::Lookup(Handle<String> name) {
|
323
|
-
for (Scope* scope = this;
|
324
|
-
scope != NULL;
|
325
|
-
scope = scope->outer_scope()) {
|
326
|
-
Variable* var = scope->LocalLookup(name);
|
327
|
-
if (var != NULL) return var;
|
328
|
-
}
|
329
|
-
return NULL;
|
330
|
-
}
|
331
|
-
|
332
|
-
|
333
|
-
Variable* Scope::DeclareFunctionVar(Handle<String> name) {
|
334
|
-
ASSERT(is_function_scope() && function_ == NULL);
|
335
|
-
function_ = new Variable(this, name, Variable::CONST, true, Variable::NORMAL);
|
336
|
-
return function_;
|
337
|
-
}
|
338
|
-
|
339
|
-
|
340
|
-
Variable* Scope::DeclareLocal(Handle<String> name, Variable::Mode mode) {
|
341
|
-
// DYNAMIC variables are introduces during variable allocation,
|
342
|
-
// INTERNAL variables are allocated explicitly, and TEMPORARY
|
343
|
-
// variables are allocated via NewTemporary().
|
344
|
-
ASSERT(!resolved());
|
345
|
-
ASSERT(mode == Variable::VAR || mode == Variable::CONST);
|
346
|
-
return variables_.Declare(this, name, mode, true, Variable::NORMAL);
|
347
|
-
}
|
348
|
-
|
349
|
-
|
350
|
-
Variable* Scope::DeclareGlobal(Handle<String> name) {
|
351
|
-
ASSERT(is_global_scope());
|
352
|
-
return variables_.Declare(this, name, Variable::DYNAMIC_GLOBAL, true,
|
353
|
-
Variable::NORMAL);
|
354
|
-
}
|
355
|
-
|
356
|
-
|
357
|
-
void Scope::AddParameter(Variable* var) {
|
358
|
-
ASSERT(is_function_scope());
|
359
|
-
ASSERT(LocalLookup(var->name()) == var);
|
360
|
-
params_.Add(var);
|
361
|
-
}
|
362
|
-
|
363
|
-
|
364
|
-
VariableProxy* Scope::NewUnresolved(Handle<String> name,
|
365
|
-
bool inside_with,
|
366
|
-
int position) {
|
367
|
-
// Note that we must not share the unresolved variables with
|
368
|
-
// the same name because they may be removed selectively via
|
369
|
-
// RemoveUnresolved().
|
370
|
-
ASSERT(!resolved());
|
371
|
-
VariableProxy* proxy = new VariableProxy(name, false, inside_with, position);
|
372
|
-
unresolved_.Add(proxy);
|
373
|
-
return proxy;
|
374
|
-
}
|
375
|
-
|
376
|
-
|
377
|
-
void Scope::RemoveUnresolved(VariableProxy* var) {
|
378
|
-
// Most likely (always?) any variable we want to remove
|
379
|
-
// was just added before, so we search backwards.
|
380
|
-
for (int i = unresolved_.length(); i-- > 0;) {
|
381
|
-
if (unresolved_[i] == var) {
|
382
|
-
unresolved_.Remove(i);
|
383
|
-
return;
|
384
|
-
}
|
385
|
-
}
|
386
|
-
}
|
387
|
-
|
388
|
-
|
389
|
-
Variable* Scope::NewTemporary(Handle<String> name) {
|
390
|
-
ASSERT(!resolved());
|
391
|
-
Variable* var =
|
392
|
-
new Variable(this, name, Variable::TEMPORARY, true, Variable::NORMAL);
|
393
|
-
temps_.Add(var);
|
394
|
-
return var;
|
395
|
-
}
|
396
|
-
|
397
|
-
|
398
|
-
void Scope::AddDeclaration(Declaration* declaration) {
|
399
|
-
decls_.Add(declaration);
|
400
|
-
}
|
401
|
-
|
402
|
-
|
403
|
-
void Scope::SetIllegalRedeclaration(Expression* expression) {
|
404
|
-
// Record only the first illegal redeclaration.
|
405
|
-
if (!HasIllegalRedeclaration()) {
|
406
|
-
illegal_redecl_ = expression;
|
407
|
-
}
|
408
|
-
ASSERT(HasIllegalRedeclaration());
|
409
|
-
}
|
410
|
-
|
411
|
-
|
412
|
-
void Scope::VisitIllegalRedeclaration(AstVisitor* visitor) {
|
413
|
-
ASSERT(HasIllegalRedeclaration());
|
414
|
-
illegal_redecl_->Accept(visitor);
|
415
|
-
}
|
416
|
-
|
417
|
-
|
418
|
-
template<class Allocator>
|
419
|
-
void Scope::CollectUsedVariables(List<Variable*, Allocator>* locals) {
|
420
|
-
// Collect variables in this scope.
|
421
|
-
// Note that the function_ variable - if present - is not
|
422
|
-
// collected here but handled separately in ScopeInfo
|
423
|
-
// which is the current user of this function).
|
424
|
-
for (int i = 0; i < temps_.length(); i++) {
|
425
|
-
Variable* var = temps_[i];
|
426
|
-
if (var->is_used()) {
|
427
|
-
locals->Add(var);
|
428
|
-
}
|
429
|
-
}
|
430
|
-
for (VariableMap::Entry* p = variables_.Start();
|
431
|
-
p != NULL;
|
432
|
-
p = variables_.Next(p)) {
|
433
|
-
Variable* var = reinterpret_cast<Variable*>(p->value);
|
434
|
-
if (var->is_used()) {
|
435
|
-
locals->Add(var);
|
436
|
-
}
|
437
|
-
}
|
438
|
-
}
|
439
|
-
|
440
|
-
|
441
|
-
// Make sure the method gets instantiated by the template system.
|
442
|
-
template void Scope::CollectUsedVariables(
|
443
|
-
List<Variable*, FreeStoreAllocationPolicy>* locals);
|
444
|
-
template void Scope::CollectUsedVariables(
|
445
|
-
List<Variable*, PreallocatedStorage>* locals);
|
446
|
-
template void Scope::CollectUsedVariables(
|
447
|
-
List<Variable*, ZoneListAllocationPolicy>* locals);
|
448
|
-
|
449
|
-
|
450
|
-
void Scope::AllocateVariables(Handle<Context> context) {
|
451
|
-
ASSERT(outer_scope_ == NULL); // eval or global scopes only
|
452
|
-
|
453
|
-
// 1) Propagate scope information.
|
454
|
-
// If we are in an eval scope, we may have other outer scopes about
|
455
|
-
// which we don't know anything at this point. Thus we must be conservative
|
456
|
-
// and assume they may invoke eval themselves. Eventually we could capture
|
457
|
-
// this information in the ScopeInfo and then use it here (by traversing
|
458
|
-
// the call chain stack, at compile time).
|
459
|
-
bool eval_scope = is_eval_scope();
|
460
|
-
PropagateScopeInfo(eval_scope, eval_scope);
|
461
|
-
|
462
|
-
// 2) Resolve variables.
|
463
|
-
Scope* global_scope = NULL;
|
464
|
-
if (is_global_scope()) global_scope = this;
|
465
|
-
ResolveVariablesRecursively(global_scope, context);
|
466
|
-
|
467
|
-
// 3) Allocate variables.
|
468
|
-
AllocateVariablesRecursively();
|
469
|
-
}
|
470
|
-
|
471
|
-
|
472
|
-
bool Scope::AllowsLazyCompilation() const {
|
473
|
-
return !force_eager_compilation_ && HasTrivialOuterContext();
|
474
|
-
}
|
475
|
-
|
476
|
-
|
477
|
-
bool Scope::HasTrivialContext() const {
|
478
|
-
// A function scope has a trivial context if it always is the global
|
479
|
-
// context. We iteratively scan out the context chain to see if
|
480
|
-
// there is anything that makes this scope non-trivial; otherwise we
|
481
|
-
// return true.
|
482
|
-
for (const Scope* scope = this; scope != NULL; scope = scope->outer_scope_) {
|
483
|
-
if (scope->is_eval_scope()) return false;
|
484
|
-
if (scope->scope_inside_with_) return false;
|
485
|
-
if (scope->num_heap_slots_ > 0) return false;
|
486
|
-
}
|
487
|
-
return true;
|
488
|
-
}
|
489
|
-
|
490
|
-
|
491
|
-
bool Scope::HasTrivialOuterContext() const {
|
492
|
-
Scope* outer = outer_scope_;
|
493
|
-
if (outer == NULL) return true;
|
494
|
-
// Note that the outer context may be trivial in general, but the current
|
495
|
-
// scope may be inside a 'with' statement in which case the outer context
|
496
|
-
// for this scope is not trivial.
|
497
|
-
return !scope_inside_with_ && outer->HasTrivialContext();
|
498
|
-
}
|
499
|
-
|
500
|
-
|
501
|
-
int Scope::ContextChainLength(Scope* scope) {
|
502
|
-
int n = 0;
|
503
|
-
for (Scope* s = this; s != scope; s = s->outer_scope_) {
|
504
|
-
ASSERT(s != NULL); // scope must be in the scope chain
|
505
|
-
if (s->num_heap_slots() > 0) n++;
|
506
|
-
}
|
507
|
-
return n;
|
508
|
-
}
|
509
|
-
|
510
|
-
|
511
|
-
#ifdef DEBUG
|
512
|
-
static const char* Header(Scope::Type type) {
|
513
|
-
switch (type) {
|
514
|
-
case Scope::EVAL_SCOPE: return "eval";
|
515
|
-
case Scope::FUNCTION_SCOPE: return "function";
|
516
|
-
case Scope::GLOBAL_SCOPE: return "global";
|
517
|
-
}
|
518
|
-
UNREACHABLE();
|
519
|
-
return NULL;
|
520
|
-
}
|
521
|
-
|
522
|
-
|
523
|
-
static void Indent(int n, const char* str) {
|
524
|
-
PrintF("%*s%s", n, "", str);
|
525
|
-
}
|
526
|
-
|
527
|
-
|
528
|
-
static void PrintName(Handle<String> name) {
|
529
|
-
SmartPointer<char> s = name->ToCString(DISALLOW_NULLS);
|
530
|
-
PrintF("%s", *s);
|
531
|
-
}
|
532
|
-
|
533
|
-
|
534
|
-
static void PrintVar(PrettyPrinter* printer, int indent, Variable* var) {
|
535
|
-
if (var->is_used() || var->rewrite() != NULL) {
|
536
|
-
Indent(indent, Variable::Mode2String(var->mode()));
|
537
|
-
PrintF(" ");
|
538
|
-
PrintName(var->name());
|
539
|
-
PrintF("; // ");
|
540
|
-
if (var->rewrite() != NULL) {
|
541
|
-
PrintF("%s, ", printer->Print(var->rewrite()));
|
542
|
-
if (var->is_accessed_from_inner_scope()) PrintF(", ");
|
543
|
-
}
|
544
|
-
if (var->is_accessed_from_inner_scope()) PrintF("inner scope access");
|
545
|
-
PrintF("\n");
|
546
|
-
}
|
547
|
-
}
|
548
|
-
|
549
|
-
|
550
|
-
static void PrintMap(PrettyPrinter* printer, int indent, VariableMap* map) {
|
551
|
-
for (VariableMap::Entry* p = map->Start(); p != NULL; p = map->Next(p)) {
|
552
|
-
Variable* var = reinterpret_cast<Variable*>(p->value);
|
553
|
-
PrintVar(printer, indent, var);
|
554
|
-
}
|
555
|
-
}
|
556
|
-
|
557
|
-
|
558
|
-
void Scope::Print(int n) {
|
559
|
-
int n0 = (n > 0 ? n : 0);
|
560
|
-
int n1 = n0 + 2; // indentation
|
561
|
-
|
562
|
-
// Print header.
|
563
|
-
Indent(n0, Header(type_));
|
564
|
-
if (scope_name_->length() > 0) {
|
565
|
-
PrintF(" ");
|
566
|
-
PrintName(scope_name_);
|
567
|
-
}
|
568
|
-
|
569
|
-
// Print parameters, if any.
|
570
|
-
if (is_function_scope()) {
|
571
|
-
PrintF(" (");
|
572
|
-
for (int i = 0; i < params_.length(); i++) {
|
573
|
-
if (i > 0) PrintF(", ");
|
574
|
-
PrintName(params_[i]->name());
|
575
|
-
}
|
576
|
-
PrintF(")");
|
577
|
-
}
|
578
|
-
|
579
|
-
PrintF(" {\n");
|
580
|
-
|
581
|
-
// Function name, if any (named function literals, only).
|
582
|
-
if (function_ != NULL) {
|
583
|
-
Indent(n1, "// (local) function name: ");
|
584
|
-
PrintName(function_->name());
|
585
|
-
PrintF("\n");
|
586
|
-
}
|
587
|
-
|
588
|
-
// Scope info.
|
589
|
-
if (HasTrivialOuterContext()) {
|
590
|
-
Indent(n1, "// scope has trivial outer context\n");
|
591
|
-
}
|
592
|
-
if (scope_inside_with_) Indent(n1, "// scope inside 'with'\n");
|
593
|
-
if (scope_contains_with_) Indent(n1, "// scope contains 'with'\n");
|
594
|
-
if (scope_calls_eval_) Indent(n1, "// scope calls 'eval'\n");
|
595
|
-
if (outer_scope_calls_eval_) Indent(n1, "// outer scope calls 'eval'\n");
|
596
|
-
if (inner_scope_calls_eval_) Indent(n1, "// inner scope calls 'eval'\n");
|
597
|
-
if (outer_scope_is_eval_scope_) {
|
598
|
-
Indent(n1, "// outer scope is 'eval' scope\n");
|
599
|
-
}
|
600
|
-
if (num_stack_slots_ > 0) { Indent(n1, "// ");
|
601
|
-
PrintF("%d stack slots\n", num_stack_slots_); }
|
602
|
-
if (num_heap_slots_ > 0) { Indent(n1, "// ");
|
603
|
-
PrintF("%d heap slots\n", num_heap_slots_); }
|
604
|
-
|
605
|
-
// Print locals.
|
606
|
-
PrettyPrinter printer;
|
607
|
-
Indent(n1, "// function var\n");
|
608
|
-
if (function_ != NULL) {
|
609
|
-
PrintVar(&printer, n1, function_);
|
610
|
-
}
|
611
|
-
|
612
|
-
Indent(n1, "// temporary vars\n");
|
613
|
-
for (int i = 0; i < temps_.length(); i++) {
|
614
|
-
PrintVar(&printer, n1, temps_[i]);
|
615
|
-
}
|
616
|
-
|
617
|
-
Indent(n1, "// local vars\n");
|
618
|
-
PrintMap(&printer, n1, &variables_);
|
619
|
-
|
620
|
-
Indent(n1, "// dynamic vars\n");
|
621
|
-
if (dynamics_ != NULL) {
|
622
|
-
PrintMap(&printer, n1, dynamics_->GetMap(Variable::DYNAMIC));
|
623
|
-
PrintMap(&printer, n1, dynamics_->GetMap(Variable::DYNAMIC_LOCAL));
|
624
|
-
PrintMap(&printer, n1, dynamics_->GetMap(Variable::DYNAMIC_GLOBAL));
|
625
|
-
}
|
626
|
-
|
627
|
-
// Print inner scopes (disable by providing negative n).
|
628
|
-
if (n >= 0) {
|
629
|
-
for (int i = 0; i < inner_scopes_.length(); i++) {
|
630
|
-
PrintF("\n");
|
631
|
-
inner_scopes_[i]->Print(n1);
|
632
|
-
}
|
633
|
-
}
|
634
|
-
|
635
|
-
Indent(n0, "}\n");
|
636
|
-
}
|
637
|
-
#endif // DEBUG
|
638
|
-
|
639
|
-
|
640
|
-
Variable* Scope::NonLocal(Handle<String> name, Variable::Mode mode) {
|
641
|
-
if (dynamics_ == NULL) dynamics_ = new DynamicScopePart();
|
642
|
-
VariableMap* map = dynamics_->GetMap(mode);
|
643
|
-
Variable* var = map->Lookup(name);
|
644
|
-
if (var == NULL) {
|
645
|
-
// Declare a new non-local.
|
646
|
-
var = map->Declare(NULL, name, mode, true, Variable::NORMAL);
|
647
|
-
// Allocate it by giving it a dynamic lookup.
|
648
|
-
var->set_rewrite(new Slot(var, Slot::LOOKUP, -1));
|
649
|
-
}
|
650
|
-
return var;
|
651
|
-
}
|
652
|
-
|
653
|
-
|
654
|
-
// Lookup a variable starting with this scope. The result is either
|
655
|
-
// the statically resolved variable belonging to an outer scope, or
|
656
|
-
// NULL. It may be NULL because a) we couldn't find a variable, or b)
|
657
|
-
// because the variable is just a guess (and may be shadowed by
|
658
|
-
// another variable that is introduced dynamically via an 'eval' call
|
659
|
-
// or a 'with' statement).
|
660
|
-
Variable* Scope::LookupRecursive(Handle<String> name,
|
661
|
-
bool inner_lookup,
|
662
|
-
Variable** invalidated_local) {
|
663
|
-
// If we find a variable, but the current scope calls 'eval', the found
|
664
|
-
// variable may not be the correct one (the 'eval' may introduce a
|
665
|
-
// property with the same name). In that case, remember that the variable
|
666
|
-
// found is just a guess.
|
667
|
-
bool guess = scope_calls_eval_;
|
668
|
-
|
669
|
-
// Try to find the variable in this scope.
|
670
|
-
Variable* var = LocalLookup(name);
|
671
|
-
|
672
|
-
if (var != NULL) {
|
673
|
-
// We found a variable. If this is not an inner lookup, we are done.
|
674
|
-
// (Even if there is an 'eval' in this scope which introduces the
|
675
|
-
// same variable again, the resulting variable remains the same.
|
676
|
-
// Note that enclosing 'with' statements are handled at the call site.)
|
677
|
-
if (!inner_lookup)
|
678
|
-
return var;
|
679
|
-
|
680
|
-
} else {
|
681
|
-
// We did not find a variable locally. Check against the function variable,
|
682
|
-
// if any. We can do this for all scopes, since the function variable is
|
683
|
-
// only present - if at all - for function scopes.
|
684
|
-
//
|
685
|
-
// This lookup corresponds to a lookup in the "intermediate" scope sitting
|
686
|
-
// between this scope and the outer scope. (ECMA-262, 3rd., requires that
|
687
|
-
// the name of named function literal is kept in an intermediate scope
|
688
|
-
// in between this scope and the next outer scope.)
|
689
|
-
if (function_ != NULL && function_->name().is_identical_to(name)) {
|
690
|
-
var = function_;
|
691
|
-
|
692
|
-
} else if (outer_scope_ != NULL) {
|
693
|
-
var = outer_scope_->LookupRecursive(name, true, invalidated_local);
|
694
|
-
// We may have found a variable in an outer scope. However, if
|
695
|
-
// the current scope is inside a 'with', the actual variable may
|
696
|
-
// be a property introduced via the 'with' statement. Then, the
|
697
|
-
// variable we may have found is just a guess.
|
698
|
-
if (scope_inside_with_)
|
699
|
-
guess = true;
|
700
|
-
}
|
701
|
-
|
702
|
-
// If we did not find a variable, we are done.
|
703
|
-
if (var == NULL)
|
704
|
-
return NULL;
|
705
|
-
}
|
706
|
-
|
707
|
-
ASSERT(var != NULL);
|
708
|
-
|
709
|
-
// If this is a lookup from an inner scope, mark the variable.
|
710
|
-
if (inner_lookup) {
|
711
|
-
var->MarkAsAccessedFromInnerScope();
|
712
|
-
}
|
713
|
-
|
714
|
-
// If the variable we have found is just a guess, invalidate the
|
715
|
-
// result. If the found variable is local, record that fact so we
|
716
|
-
// can generate fast code to get it if it is not shadowed by eval.
|
717
|
-
if (guess) {
|
718
|
-
if (!var->is_global()) *invalidated_local = var;
|
719
|
-
var = NULL;
|
720
|
-
}
|
721
|
-
|
722
|
-
return var;
|
723
|
-
}
|
724
|
-
|
725
|
-
|
726
|
-
void Scope::ResolveVariable(Scope* global_scope,
|
727
|
-
Handle<Context> context,
|
728
|
-
VariableProxy* proxy) {
|
729
|
-
ASSERT(global_scope == NULL || global_scope->is_global_scope());
|
730
|
-
|
731
|
-
// If the proxy is already resolved there's nothing to do
|
732
|
-
// (functions and consts may be resolved by the parser).
|
733
|
-
if (proxy->var() != NULL) return;
|
734
|
-
|
735
|
-
// Otherwise, try to resolve the variable.
|
736
|
-
Variable* invalidated_local = NULL;
|
737
|
-
Variable* var = LookupRecursive(proxy->name(), false, &invalidated_local);
|
738
|
-
|
739
|
-
if (proxy->inside_with()) {
|
740
|
-
// If we are inside a local 'with' statement, all bets are off
|
741
|
-
// and we cannot resolve the proxy to a local variable even if
|
742
|
-
// we found an outer matching variable.
|
743
|
-
// Note that we must do a lookup anyway, because if we find one,
|
744
|
-
// we must mark that variable as potentially accessed from this
|
745
|
-
// inner scope (the property may not be in the 'with' object).
|
746
|
-
var = NonLocal(proxy->name(), Variable::DYNAMIC);
|
747
|
-
|
748
|
-
} else {
|
749
|
-
// We are not inside a local 'with' statement.
|
750
|
-
|
751
|
-
if (var == NULL) {
|
752
|
-
// We did not find the variable. We have a global variable
|
753
|
-
// if we are in the global scope (we know already that we
|
754
|
-
// are outside a 'with' statement) or if there is no way
|
755
|
-
// that the variable might be introduced dynamically (through
|
756
|
-
// a local or outer eval() call, or an outer 'with' statement),
|
757
|
-
// or we don't know about the outer scope (because we are
|
758
|
-
// in an eval scope).
|
759
|
-
if (is_global_scope() ||
|
760
|
-
!(scope_inside_with_ || outer_scope_is_eval_scope_ ||
|
761
|
-
scope_calls_eval_ || outer_scope_calls_eval_)) {
|
762
|
-
// We must have a global variable.
|
763
|
-
ASSERT(global_scope != NULL);
|
764
|
-
var = global_scope->DeclareGlobal(proxy->name());
|
765
|
-
|
766
|
-
} else if (scope_inside_with_) {
|
767
|
-
// If we are inside a with statement we give up and look up
|
768
|
-
// the variable at runtime.
|
769
|
-
var = NonLocal(proxy->name(), Variable::DYNAMIC);
|
770
|
-
|
771
|
-
} else if (invalidated_local != NULL) {
|
772
|
-
// No with statements are involved and we found a local
|
773
|
-
// variable that might be shadowed by eval introduced
|
774
|
-
// variables.
|
775
|
-
var = NonLocal(proxy->name(), Variable::DYNAMIC_LOCAL);
|
776
|
-
var->set_local_if_not_shadowed(invalidated_local);
|
777
|
-
|
778
|
-
} else if (outer_scope_is_eval_scope_) {
|
779
|
-
// No with statements and we did not find a local and the code
|
780
|
-
// is executed with a call to eval. The context contains
|
781
|
-
// scope information that we can use to determine if the
|
782
|
-
// variable is global if it is not shadowed by eval-introduced
|
783
|
-
// variables.
|
784
|
-
if (context->GlobalIfNotShadowedByEval(proxy->name())) {
|
785
|
-
var = NonLocal(proxy->name(), Variable::DYNAMIC_GLOBAL);
|
786
|
-
|
787
|
-
} else {
|
788
|
-
var = NonLocal(proxy->name(), Variable::DYNAMIC);
|
789
|
-
}
|
790
|
-
|
791
|
-
} else {
|
792
|
-
// No with statements and we did not find a local and the code
|
793
|
-
// is not executed with a call to eval. We know that this
|
794
|
-
// variable is global unless it is shadowed by eval-introduced
|
795
|
-
// variables.
|
796
|
-
var = NonLocal(proxy->name(), Variable::DYNAMIC_GLOBAL);
|
797
|
-
}
|
798
|
-
}
|
799
|
-
}
|
800
|
-
|
801
|
-
proxy->BindTo(var);
|
802
|
-
}
|
803
|
-
|
804
|
-
|
805
|
-
void Scope::ResolveVariablesRecursively(Scope* global_scope,
|
806
|
-
Handle<Context> context) {
|
807
|
-
ASSERT(global_scope == NULL || global_scope->is_global_scope());
|
808
|
-
|
809
|
-
// Resolve unresolved variables for this scope.
|
810
|
-
for (int i = 0; i < unresolved_.length(); i++) {
|
811
|
-
ResolveVariable(global_scope, context, unresolved_[i]);
|
812
|
-
}
|
813
|
-
|
814
|
-
// Resolve unresolved variables for inner scopes.
|
815
|
-
for (int i = 0; i < inner_scopes_.length(); i++) {
|
816
|
-
inner_scopes_[i]->ResolveVariablesRecursively(global_scope, context);
|
817
|
-
}
|
818
|
-
}
|
819
|
-
|
820
|
-
|
821
|
-
bool Scope::PropagateScopeInfo(bool outer_scope_calls_eval,
|
822
|
-
bool outer_scope_is_eval_scope) {
|
823
|
-
if (outer_scope_calls_eval) {
|
824
|
-
outer_scope_calls_eval_ = true;
|
825
|
-
}
|
826
|
-
|
827
|
-
if (outer_scope_is_eval_scope) {
|
828
|
-
outer_scope_is_eval_scope_ = true;
|
829
|
-
}
|
830
|
-
|
831
|
-
bool calls_eval = scope_calls_eval_ || outer_scope_calls_eval_;
|
832
|
-
bool is_eval = is_eval_scope() || outer_scope_is_eval_scope_;
|
833
|
-
for (int i = 0; i < inner_scopes_.length(); i++) {
|
834
|
-
Scope* inner_scope = inner_scopes_[i];
|
835
|
-
if (inner_scope->PropagateScopeInfo(calls_eval, is_eval)) {
|
836
|
-
inner_scope_calls_eval_ = true;
|
837
|
-
}
|
838
|
-
if (inner_scope->force_eager_compilation_) {
|
839
|
-
force_eager_compilation_ = true;
|
840
|
-
}
|
841
|
-
}
|
842
|
-
|
843
|
-
return scope_calls_eval_ || inner_scope_calls_eval_;
|
844
|
-
}
|
845
|
-
|
846
|
-
|
847
|
-
bool Scope::MustAllocate(Variable* var) {
|
848
|
-
// Give var a read/write use if there is a chance it might be accessed
|
849
|
-
// via an eval() call. This is only possible if the variable has a
|
850
|
-
// visible name.
|
851
|
-
if ((var->is_this() || var->name()->length() > 0) &&
|
852
|
-
(var->is_accessed_from_inner_scope() ||
|
853
|
-
scope_calls_eval_ || inner_scope_calls_eval_ ||
|
854
|
-
scope_contains_with_)) {
|
855
|
-
var->set_is_used(true);
|
856
|
-
}
|
857
|
-
// Global variables do not need to be allocated.
|
858
|
-
return !var->is_global() && var->is_used();
|
859
|
-
}
|
860
|
-
|
861
|
-
|
862
|
-
bool Scope::MustAllocateInContext(Variable* var) {
|
863
|
-
// If var is accessed from an inner scope, or if there is a
|
864
|
-
// possibility that it might be accessed from the current or an inner
|
865
|
-
// scope (through an eval() call), it must be allocated in the
|
866
|
-
// context. Exception: temporary variables are not allocated in the
|
867
|
-
// context.
|
868
|
-
return
|
869
|
-
var->mode() != Variable::TEMPORARY &&
|
870
|
-
(var->is_accessed_from_inner_scope() ||
|
871
|
-
scope_calls_eval_ || inner_scope_calls_eval_ ||
|
872
|
-
scope_contains_with_ || var->is_global());
|
873
|
-
}
|
874
|
-
|
875
|
-
|
876
|
-
bool Scope::HasArgumentsParameter() {
|
877
|
-
for (int i = 0; i < params_.length(); i++) {
|
878
|
-
if (params_[i]->name().is_identical_to(FACTORY->arguments_symbol()))
|
879
|
-
return true;
|
880
|
-
}
|
881
|
-
return false;
|
882
|
-
}
|
883
|
-
|
884
|
-
|
885
|
-
void Scope::AllocateStackSlot(Variable* var) {
|
886
|
-
var->set_rewrite(new Slot(var, Slot::LOCAL, num_stack_slots_++));
|
887
|
-
}
|
888
|
-
|
889
|
-
|
890
|
-
void Scope::AllocateHeapSlot(Variable* var) {
|
891
|
-
var->set_rewrite(new Slot(var, Slot::CONTEXT, num_heap_slots_++));
|
892
|
-
}
|
893
|
-
|
894
|
-
|
895
|
-
void Scope::AllocateParameterLocals() {
|
896
|
-
ASSERT(is_function_scope());
|
897
|
-
Variable* arguments = LocalLookup(FACTORY->arguments_symbol());
|
898
|
-
ASSERT(arguments != NULL); // functions have 'arguments' declared implicitly
|
899
|
-
|
900
|
-
// Parameters are rewritten to arguments[i] if 'arguments' is used in
|
901
|
-
// a non-strict mode function. Strict mode code doesn't alias arguments.
|
902
|
-
bool rewrite_parameters = false;
|
903
|
-
|
904
|
-
if (MustAllocate(arguments) && !HasArgumentsParameter()) {
|
905
|
-
// 'arguments' is used. Unless there is also a parameter called
|
906
|
-
// 'arguments', we must be conservative and access all parameters via
|
907
|
-
// the arguments object: The i'th parameter is rewritten into
|
908
|
-
// '.arguments[i]' (*). If we have a parameter named 'arguments', a
|
909
|
-
// (new) value is always assigned to it via the function
|
910
|
-
// invocation. Then 'arguments' denotes that specific parameter value
|
911
|
-
// and cannot be used to access the parameters, which is why we don't
|
912
|
-
// need to rewrite in that case.
|
913
|
-
//
|
914
|
-
// (*) Instead of having a parameter called 'arguments', we may have an
|
915
|
-
// assignment to 'arguments' in the function body, at some arbitrary
|
916
|
-
// point in time (possibly through an 'eval()' call!). After that
|
917
|
-
// assignment any re-write of parameters would be invalid (was bug
|
918
|
-
// 881452). Thus, we introduce a shadow '.arguments'
|
919
|
-
// variable which also points to the arguments object. For rewrites we
|
920
|
-
// use '.arguments' which remains valid even if we assign to
|
921
|
-
// 'arguments'. To summarize: If we need to rewrite, we allocate an
|
922
|
-
// 'arguments' object dynamically upon function invocation. The compiler
|
923
|
-
// introduces 2 local variables 'arguments' and '.arguments', both of
|
924
|
-
// which originally point to the arguments object that was
|
925
|
-
// allocated. All parameters are rewritten into property accesses via
|
926
|
-
// the '.arguments' variable. Thus, any changes to properties of
|
927
|
-
// 'arguments' are reflected in the variables and vice versa. If the
|
928
|
-
// 'arguments' variable is changed, '.arguments' still points to the
|
929
|
-
// correct arguments object and the rewrites still work.
|
930
|
-
|
931
|
-
// We are using 'arguments'. Tell the code generator that is needs to
|
932
|
-
// allocate the arguments object by setting 'arguments_'.
|
933
|
-
arguments_ = arguments;
|
934
|
-
|
935
|
-
// In strict mode 'arguments' does not alias formal parameters.
|
936
|
-
// Therefore in strict mode we allocate parameters as if 'arguments'
|
937
|
-
// were not used.
|
938
|
-
rewrite_parameters = !is_strict_mode();
|
939
|
-
}
|
940
|
-
|
941
|
-
if (rewrite_parameters) {
|
942
|
-
// We also need the '.arguments' shadow variable. Declare it and create
|
943
|
-
// and bind the corresponding proxy. It's ok to declare it only now
|
944
|
-
// because it's a local variable that is allocated after the parameters
|
945
|
-
// have been allocated.
|
946
|
-
//
|
947
|
-
// Note: This is "almost" at temporary variable but we cannot use
|
948
|
-
// NewTemporary() because the mode needs to be INTERNAL since this
|
949
|
-
// variable may be allocated in the heap-allocated context (temporaries
|
950
|
-
// are never allocated in the context).
|
951
|
-
arguments_shadow_ = new Variable(this,
|
952
|
-
FACTORY->arguments_shadow_symbol(),
|
953
|
-
Variable::INTERNAL,
|
954
|
-
true,
|
955
|
-
Variable::ARGUMENTS);
|
956
|
-
arguments_shadow_->set_is_used(true);
|
957
|
-
temps_.Add(arguments_shadow_);
|
958
|
-
|
959
|
-
// Allocate the parameters by rewriting them into '.arguments[i]' accesses.
|
960
|
-
for (int i = 0; i < params_.length(); i++) {
|
961
|
-
Variable* var = params_[i];
|
962
|
-
ASSERT(var->scope() == this);
|
963
|
-
if (MustAllocate(var)) {
|
964
|
-
if (MustAllocateInContext(var)) {
|
965
|
-
// It is ok to set this only now, because arguments is a local
|
966
|
-
// variable that is allocated after the parameters have been
|
967
|
-
// allocated.
|
968
|
-
arguments_shadow_->MarkAsAccessedFromInnerScope();
|
969
|
-
}
|
970
|
-
Property* rewrite =
|
971
|
-
new Property(new VariableProxy(arguments_shadow_),
|
972
|
-
new Literal(Handle<Object>(Smi::FromInt(i))),
|
973
|
-
RelocInfo::kNoPosition,
|
974
|
-
Property::SYNTHETIC);
|
975
|
-
rewrite->set_is_arguments_access(true);
|
976
|
-
var->set_rewrite(rewrite);
|
977
|
-
}
|
978
|
-
}
|
979
|
-
|
980
|
-
} else {
|
981
|
-
// The arguments object is not used, so we can access parameters directly.
|
982
|
-
// The same parameter may occur multiple times in the parameters_ list.
|
983
|
-
// If it does, and if it is not copied into the context object, it must
|
984
|
-
// receive the highest parameter index for that parameter; thus iteration
|
985
|
-
// order is relevant!
|
986
|
-
for (int i = 0; i < params_.length(); i++) {
|
987
|
-
Variable* var = params_[i];
|
988
|
-
ASSERT(var->scope() == this);
|
989
|
-
if (MustAllocate(var)) {
|
990
|
-
if (MustAllocateInContext(var)) {
|
991
|
-
ASSERT(var->rewrite() == NULL ||
|
992
|
-
(var->AsSlot() != NULL &&
|
993
|
-
var->AsSlot()->type() == Slot::CONTEXT));
|
994
|
-
if (var->rewrite() == NULL) {
|
995
|
-
// Only set the heap allocation if the parameter has not
|
996
|
-
// been allocated yet.
|
997
|
-
AllocateHeapSlot(var);
|
998
|
-
}
|
999
|
-
} else {
|
1000
|
-
ASSERT(var->rewrite() == NULL ||
|
1001
|
-
(var->AsSlot() != NULL &&
|
1002
|
-
var->AsSlot()->type() == Slot::PARAMETER));
|
1003
|
-
// Set the parameter index always, even if the parameter
|
1004
|
-
// was seen before! (We need to access the actual parameter
|
1005
|
-
// supplied for the last occurrence of a multiply declared
|
1006
|
-
// parameter.)
|
1007
|
-
var->set_rewrite(new Slot(var, Slot::PARAMETER, i));
|
1008
|
-
}
|
1009
|
-
}
|
1010
|
-
}
|
1011
|
-
}
|
1012
|
-
}
|
1013
|
-
|
1014
|
-
|
1015
|
-
void Scope::AllocateNonParameterLocal(Variable* var) {
|
1016
|
-
ASSERT(var->scope() == this);
|
1017
|
-
ASSERT(var->rewrite() == NULL ||
|
1018
|
-
(!var->IsVariable(FACTORY->result_symbol())) ||
|
1019
|
-
(var->AsSlot() == NULL || var->AsSlot()->type() != Slot::LOCAL));
|
1020
|
-
if (var->rewrite() == NULL && MustAllocate(var)) {
|
1021
|
-
if (MustAllocateInContext(var)) {
|
1022
|
-
AllocateHeapSlot(var);
|
1023
|
-
} else {
|
1024
|
-
AllocateStackSlot(var);
|
1025
|
-
}
|
1026
|
-
}
|
1027
|
-
}
|
1028
|
-
|
1029
|
-
|
1030
|
-
void Scope::AllocateNonParameterLocals() {
|
1031
|
-
// All variables that have no rewrite yet are non-parameter locals.
|
1032
|
-
for (int i = 0; i < temps_.length(); i++) {
|
1033
|
-
AllocateNonParameterLocal(temps_[i]);
|
1034
|
-
}
|
1035
|
-
|
1036
|
-
for (VariableMap::Entry* p = variables_.Start();
|
1037
|
-
p != NULL;
|
1038
|
-
p = variables_.Next(p)) {
|
1039
|
-
Variable* var = reinterpret_cast<Variable*>(p->value);
|
1040
|
-
AllocateNonParameterLocal(var);
|
1041
|
-
}
|
1042
|
-
|
1043
|
-
// For now, function_ must be allocated at the very end. If it gets
|
1044
|
-
// allocated in the context, it must be the last slot in the context,
|
1045
|
-
// because of the current ScopeInfo implementation (see
|
1046
|
-
// ScopeInfo::ScopeInfo(FunctionScope* scope) constructor).
|
1047
|
-
if (function_ != NULL) {
|
1048
|
-
AllocateNonParameterLocal(function_);
|
1049
|
-
}
|
1050
|
-
}
|
1051
|
-
|
1052
|
-
|
1053
|
-
void Scope::AllocateVariablesRecursively() {
|
1054
|
-
// Allocate variables for inner scopes.
|
1055
|
-
for (int i = 0; i < inner_scopes_.length(); i++) {
|
1056
|
-
inner_scopes_[i]->AllocateVariablesRecursively();
|
1057
|
-
}
|
1058
|
-
|
1059
|
-
// If scope is already resolved, we still need to allocate
|
1060
|
-
// variables in inner scopes which might not had been resolved yet.
|
1061
|
-
if (resolved()) return;
|
1062
|
-
// The number of slots required for variables.
|
1063
|
-
num_stack_slots_ = 0;
|
1064
|
-
num_heap_slots_ = Context::MIN_CONTEXT_SLOTS;
|
1065
|
-
|
1066
|
-
// Allocate variables for this scope.
|
1067
|
-
// Parameters must be allocated first, if any.
|
1068
|
-
if (is_function_scope()) AllocateParameterLocals();
|
1069
|
-
AllocateNonParameterLocals();
|
1070
|
-
|
1071
|
-
// Allocate context if necessary.
|
1072
|
-
bool must_have_local_context = false;
|
1073
|
-
if (scope_calls_eval_ || scope_contains_with_) {
|
1074
|
-
// The context for the eval() call or 'with' statement in this scope.
|
1075
|
-
// Unless we are in the global or an eval scope, we need a local
|
1076
|
-
// context even if we didn't statically allocate any locals in it,
|
1077
|
-
// and the compiler will access the context variable. If we are
|
1078
|
-
// not in an inner scope, the scope is provided from the outside.
|
1079
|
-
must_have_local_context = is_function_scope();
|
1080
|
-
}
|
1081
|
-
|
1082
|
-
// If we didn't allocate any locals in the local context, then we only
|
1083
|
-
// need the minimal number of slots if we must have a local context.
|
1084
|
-
if (num_heap_slots_ == Context::MIN_CONTEXT_SLOTS &&
|
1085
|
-
!must_have_local_context) {
|
1086
|
-
num_heap_slots_ = 0;
|
1087
|
-
}
|
1088
|
-
|
1089
|
-
// Allocation done.
|
1090
|
-
ASSERT(num_heap_slots_ == 0 || num_heap_slots_ >= Context::MIN_CONTEXT_SLOTS);
|
1091
|
-
}
|
1092
|
-
|
1093
|
-
} } // namespace v8::internal
|