Eliminate ArrayData::plusEqnightly-2020.07.21
commitd1979de61993b0224c6751e51fab7ceed68400a1
authorShaunak Kishore <kshaunak@fb.com>
Tue, 21 Jul 2020 01:36:04 +0000 (20 18:36 -0700)
committerFacebook GitHub Bot <facebook-github-bot@users.noreply.github.com>
Tue, 21 Jul 2020 01:38:50 +0000 (20 18:38 -0700)
treea663f0182b79d66ed5a37a30b408decf7cd75243
parent68247dd574555e71563556fd48d9ad69b1bafb6b
Eliminate ArrayData::plusEq

Summary:
Another PHPism down. This operation wasn't HAM-safe, and it was a little nuts to boot.

There are two places that C++ code invoked this operator. In the debugger, we maintain the behavior by manual iteration. In ext_soap, we're listing available functions; there's a debugger command that does the same thing and assumes that system and user functions are disjoint, so maybe we can assume that too? Alternatively, I could just raise instead.

Reviewed By: billf, dneiter

Differential Revision: D22627817

fbshipit-source-id: 5a7a3ab3e097fcec8464301905e5d3c175999f48
173 files changed:
hphp/doc/ir.specification
hphp/runtime/base/array-data-defs.h
hphp/runtime/base/array-data.cpp
hphp/runtime/base/array-data.h
hphp/runtime/base/bespoke-array.cpp
hphp/runtime/base/bespoke-array.h
hphp/runtime/base/bespoke/layout.h
hphp/runtime/base/bespoke/logging-array.cpp
hphp/runtime/base/bespoke/logging-array.h
hphp/runtime/base/mixed-array.cpp
hphp/runtime/base/mixed-array.h
hphp/runtime/base/packed-array.cpp
hphp/runtime/base/packed-array.h
hphp/runtime/base/set-array.cpp
hphp/runtime/base/set-array.h
hphp/runtime/base/tv-arith.cpp
hphp/runtime/base/type-array.cpp
hphp/runtime/base/type-array.h
hphp/runtime/debugger/cmd/cmd_info.cpp
hphp/runtime/ext/soap/ext_soap.cpp
hphp/runtime/test/array.cpp
hphp/runtime/vm/jit/dce.cpp
hphp/runtime/vm/jit/ir-opcode.cpp
hphp/runtime/vm/jit/irgen-arith.cpp
hphp/runtime/vm/jit/irlower-array.cpp
hphp/runtime/vm/jit/memory-effects.cpp
hphp/runtime/vm/jit/native-calls.cpp
hphp/runtime/vm/jit/translator-runtime.cpp
hphp/runtime/vm/jit/translator-runtime.h
hphp/test/quick/static-arr.php
hphp/test/slow/array/220.php [deleted file]
hphp/test/slow/array/220.php.expect [deleted file]
hphp/test/slow/array/220.php.hphp_opts [deleted file]
hphp/test/slow/array/220.php.opts [deleted symlink]
hphp/test/slow/array/221.php [deleted file]
hphp/test/slow/array/221.php.expect [deleted file]
hphp/test/slow/array/221.php.hphp_opts [deleted file]
hphp/test/slow/array/221.php.opts [deleted symlink]
hphp/test/slow/array/222.php [deleted file]
hphp/test/slow/array/222.php.expect [deleted file]
hphp/test/slow/array/222.php.hphp_opts [deleted file]
hphp/test/slow/array/222.php.opts [deleted symlink]
hphp/test/slow/array/223.php [deleted file]
hphp/test/slow/array/223.php.expect [deleted file]
hphp/test/slow/array/223.php.hphp_opts [deleted file]
hphp/test/slow/array/223.php.opts [deleted symlink]
hphp/test/slow/array/empty_array_009.php [deleted file]
hphp/test/slow/array/empty_array_009.php.expect [deleted file]
hphp/test/slow/array/internal-cursor-bug.php
hphp/test/slow/array/internal-cursor-bug.php.expect
hphp/test/slow/array_assignment/510.php [deleted file]
hphp/test/slow/array_assignment/510.php.expect [deleted file]
hphp/test/slow/array_escalation/368.php [deleted file]
hphp/test/slow/array_escalation/368.php.expect [deleted file]
hphp/test/slow/array_escalation/369.php [deleted file]
hphp/test/slow/array_escalation/369.php.expect [deleted file]
hphp/test/slow/array_escalation/370.php [deleted file]
hphp/test/slow/array_escalation/370.php.expect [deleted file]
hphp/test/slow/array_escalation/371.php [deleted file]
hphp/test/slow/array_escalation/371.php.expect [deleted file]
hphp/test/slow/array_escalation/372.php [deleted file]
hphp/test/slow/array_escalation/372.php.expect [deleted file]
hphp/test/slow/array_escalation/373.php [deleted file]
hphp/test/slow/array_escalation/373.php.expect [deleted file]
hphp/test/slow/array_escalation/374.php [deleted file]
hphp/test/slow/array_escalation/374.php.expect [deleted file]
hphp/test/slow/array_escalation/375.php [deleted file]
hphp/test/slow/array_escalation/375.php.expect [deleted file]
hphp/test/slow/array_escalation/376.php [deleted file]
hphp/test/slow/array_escalation/376.php.expect [deleted file]
hphp/test/slow/array_escalation/377.php [deleted file]
hphp/test/slow/array_escalation/377.php.expect [deleted file]
hphp/test/slow/array_escalation/378.php [deleted file]
hphp/test/slow/array_escalation/378.php.expect [deleted file]
hphp/test/slow/array_escalation/379.php [deleted file]
hphp/test/slow/array_escalation/379.php.expect [deleted file]
hphp/test/slow/array_escalation/380.php [deleted file]
hphp/test/slow/array_escalation/380.php.expect [deleted file]
hphp/test/slow/array_escalation/381.php [deleted file]
hphp/test/slow/array_escalation/381.php.expect [deleted file]
hphp/test/slow/array_escalation/382.php [deleted file]
hphp/test/slow/array_escalation/382.php.expect [deleted file]
hphp/test/slow/array_escalation/383.php [deleted file]
hphp/test/slow/array_escalation/383.php.expect [deleted file]
hphp/test/slow/array_escalation/384.php [deleted file]
hphp/test/slow/array_escalation/384.php.expect [deleted file]
hphp/test/slow/array_escalation/385.php [deleted file]
hphp/test/slow/array_escalation/385.php.expect [deleted file]
hphp/test/slow/array_escalation/386.php [deleted file]
hphp/test/slow/array_escalation/386.php.expect [deleted file]
hphp/test/slow/array_escalation/387.php [deleted file]
hphp/test/slow/array_escalation/387.php.expect [deleted file]
hphp/test/slow/array_escalation/388.php [deleted file]
hphp/test/slow/array_escalation/388.php.expect [deleted file]
hphp/test/slow/array_escalation/389.php [deleted file]
hphp/test/slow/array_escalation/389.php.expect [deleted file]
hphp/test/slow/array_escalation/390.php [deleted file]
hphp/test/slow/array_escalation/390.php.expect [deleted file]
hphp/test/slow/array_escalation/391.php [deleted file]
hphp/test/slow/array_escalation/391.php.expect [deleted file]
hphp/test/slow/array_escalation/392.php [deleted file]
hphp/test/slow/array_escalation/392.php.expect [deleted file]
hphp/test/slow/array_escalation/393.php [deleted file]
hphp/test/slow/array_escalation/393.php.expect [deleted file]
hphp/test/slow/array_escalation/394.php [deleted file]
hphp/test/slow/array_escalation/394.php.expect [deleted file]
hphp/test/slow/array_escalation/395.php [deleted file]
hphp/test/slow/array_escalation/395.php.expect [deleted file]
hphp/test/slow/array_escalation/396.php [deleted file]
hphp/test/slow/array_escalation/396.php.expect [deleted file]
hphp/test/slow/array_escalation/397.php [deleted file]
hphp/test/slow/array_escalation/397.php.expect [deleted file]
hphp/test/slow/array_escalation/398.php [deleted file]
hphp/test/slow/array_escalation/398.php.expect [deleted file]
hphp/test/slow/array_escalation/399.php [deleted file]
hphp/test/slow/array_escalation/399.php.expect [deleted file]
hphp/test/slow/array_escalation/400.php [deleted file]
hphp/test/slow/array_escalation/400.php.expect [deleted file]
hphp/test/slow/array_escalation/401.php [deleted file]
hphp/test/slow/array_escalation/401.php.expect [deleted file]
hphp/test/slow/array_escalation/402.php [deleted file]
hphp/test/slow/array_escalation/402.php.expect [deleted file]
hphp/test/slow/array_escalation/403.php [deleted file]
hphp/test/slow/array_escalation/403.php.expect [deleted file]
hphp/test/slow/array_escalation/404.php [deleted file]
hphp/test/slow/array_escalation/404.php.expect [deleted file]
hphp/test/slow/array_escalation/405.php [deleted file]
hphp/test/slow/array_escalation/405.php.expect [deleted file]
hphp/test/slow/array_escalation/406.php [deleted file]
hphp/test/slow/array_escalation/406.php.expect [deleted file]
hphp/test/slow/array_escalation/407.php [deleted file]
hphp/test/slow/array_escalation/407.php.expect [deleted file]
hphp/test/slow/array_escalation/408.php [deleted file]
hphp/test/slow/array_escalation/408.php.expect [deleted file]
hphp/test/slow/array_escalation/409.php [deleted file]
hphp/test/slow/array_escalation/409.php.expect [deleted file]
hphp/test/slow/array_escalation/410.php [deleted file]
hphp/test/slow/array_escalation/410.php.expect [deleted file]
hphp/test/slow/array_escalation/411.php [deleted file]
hphp/test/slow/array_escalation/411.php.expect [deleted file]
hphp/test/slow/array_escalation/412.php [deleted file]
hphp/test/slow/array_escalation/412.php.expect [deleted file]
hphp/test/slow/array_escalation/413.php [deleted file]
hphp/test/slow/array_escalation/413.php.expect [deleted file]
hphp/test/slow/array_escalation/414.php [deleted file]
hphp/test/slow/array_escalation/414.php.expect [deleted file]
hphp/test/slow/array_escalation/415.php [deleted file]
hphp/test/slow/array_escalation/415.php.expect [deleted file]
hphp/test/slow/array_escalation/416.php [deleted file]
hphp/test/slow/array_escalation/416.php.expect [deleted file]
hphp/test/slow/compilation/1297.php [deleted file]
hphp/test/slow/compilation/1297.php.expect [deleted file]
hphp/test/slow/ext_apc/4.php
hphp/test/slow/ext_array/array_merge.php
hphp/test/slow/ext_array/array_merge.php.expect
hphp/test/slow/ext_array/array_replace.php
hphp/test/slow/ext_array/array_replace.php.expect
hphp/test/slow/hack_arr_compat/add.php
hphp/test/slow/hack_arr_compat/add.php.expectf
hphp/test/slow/hack_arr_compat/scalars.php
hphp/test/slow/hack_arr_compat/scalars.php.expectf
hphp/test/slow/hack_arr_compat/split_misc_notices.php
hphp/test/slow/hack_arr_compat/split_misc_notices.php.expectf
hphp/test/slow/hack_arr_compat/split_misc_notices_2.php
hphp/test/slow/hack_arr_compat/split_misc_notices_2.php.expectf
hphp/test/slow/hack_array_pluseq.php [deleted file]
hphp/test/slow/hack_array_pluseq.php.expect [deleted file]
hphp/test/slow/ir_inlining/nested-calls-redefsp-1.php
hphp/test/slow/php7_backported/varSyntax/issetOnTemp.php
hphp/test/slow/spec/tests/expressions/additive_operators/array_concatenation.php [deleted file]
hphp/test/slow/spec/tests/expressions/additive_operators/array_concatenation.php.expectf [deleted file]
hphp/test/zend/good/Zend/tests/add_001.php [deleted file]
hphp/test/zend/good/Zend/tests/add_001.php.expectf [deleted file]