Skip to content

Commit

Permalink
Merge branch 'master' of https://github.com/rollup/rollup into sync-e…
Browse files Browse the repository at this point in the history
…cb6b0a4
  • Loading branch information
docschina-bot committed Jan 21, 2024
2 parents cd17fee + ecb6b0a commit 85ffcc1
Show file tree
Hide file tree
Showing 9 changed files with 79 additions and 11 deletions.
16 changes: 16 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,21 @@
# rollup changelog

## 4.9.6

_2024-01-21_

### Bug Fixes

- Detect side effects when an element that was pushed into an array is modified via the array (#5352)

### Pull Requests

- [#5337](https://github.com/rollup/rollup/pull/5337): Generate AST transformers from config (@lukastaegert)
- [#5340](https://github.com/rollup/rollup/pull/5340): Also type-check d.ts files (@lukastaegert)
- [#5348](https://github.com/rollup/rollup/pull/5348): chore(deps): lock file maintenance minor/patch updates (@renovate[bot])
- [#5351](https://github.com/rollup/rollup/pull/5351): chore(deps): update dependency vite to v5.0.12 [security] (@renovate[bot])
- [#5352](https://github.com/rollup/rollup/pull/5352): Track mutations of elements pushed into arrays (@lukastaegert)

## 4.9.5

_2024-01-12_
Expand Down
2 changes: 1 addition & 1 deletion browser/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@rollup/browser",
"version": "4.9.5",
"version": "4.9.6",
"description": "Next-generation ES module bundler browser build",
"main": "dist/rollup.browser.js",
"module": "dist/es/rollup.browser.js",
Expand Down
4 changes: 2 additions & 2 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "rollup",
"version": "4.9.5",
"version": "4.9.6",
"description": "Next-generation ES module bundler",
"main": "dist/rollup.js",
"module": "dist/es/rollup.js",
Expand Down
2 changes: 1 addition & 1 deletion rollup.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ export default async function (
addCliEntry(),
esmDynamicImport(),
!command.configTest && collectLicenses(),
!command.configTest && copyNodeTypes()
copyNodeTypes()
],
strictDeprecations: true,
treeshake
Expand Down
17 changes: 14 additions & 3 deletions src/ast/nodes/shared/ArrayPrototype.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ const NEW_ARRAY_PROPERTIES: ObjectProperty[] = [
const METHOD_CALLS_ARG_DEOPTS_SELF_RETURNS_BOOLEAN: [ExpressionEntity] = [
new Method({
callsArgs: [0],
mutatesArgs: false,
mutatesSelfAsArray: 'deopt-only',
returns: null,
returnsPrimitive: UNKNOWN_LITERAL_BOOLEAN
Expand All @@ -28,6 +29,7 @@ const METHOD_CALLS_ARG_DEOPTS_SELF_RETURNS_BOOLEAN: [ExpressionEntity] = [
const METHOD_CALLS_ARG_DEOPTS_SELF_RETURNS_NUMBER: [ExpressionEntity] = [
new Method({
callsArgs: [0],
mutatesArgs: false,
mutatesSelfAsArray: 'deopt-only',
returns: null,
returnsPrimitive: UNKNOWN_LITERAL_NUMBER
Expand All @@ -37,6 +39,7 @@ const METHOD_CALLS_ARG_DEOPTS_SELF_RETURNS_NUMBER: [ExpressionEntity] = [
const METHOD_MUTATES_SELF_RETURNS_NEW_ARRAY: [ExpressionEntity] = [
new Method({
callsArgs: null,
mutatesArgs: false,
mutatesSelfAsArray: true,
returns: () => new ObjectEntity(NEW_ARRAY_PROPERTIES, ARRAY_PROTOTYPE),
returnsPrimitive: null
Expand All @@ -46,6 +49,7 @@ const METHOD_MUTATES_SELF_RETURNS_NEW_ARRAY: [ExpressionEntity] = [
const METHOD_DEOPTS_SELF_RETURNS_NEW_ARRAY: [ExpressionEntity] = [
new Method({
callsArgs: null,
mutatesArgs: false,
mutatesSelfAsArray: 'deopt-only',
returns: () => new ObjectEntity(NEW_ARRAY_PROPERTIES, ARRAY_PROTOTYPE),
returnsPrimitive: null
Expand All @@ -55,15 +59,17 @@ const METHOD_DEOPTS_SELF_RETURNS_NEW_ARRAY: [ExpressionEntity] = [
const METHOD_CALLS_ARG_DEOPTS_SELF_RETURNS_NEW_ARRAY: [ExpressionEntity] = [
new Method({
callsArgs: [0],
mutatesArgs: false,
mutatesSelfAsArray: 'deopt-only',
returns: () => new ObjectEntity(NEW_ARRAY_PROPERTIES, ARRAY_PROTOTYPE),
returnsPrimitive: null
})
];

const METHOD_MUTATES_SELF_RETURNS_NUMBER: [ExpressionEntity] = [
const METHOD_MUTATES_SELF_AND_ARGS_RETURNS_NUMBER: [ExpressionEntity] = [
new Method({
callsArgs: null,
mutatesArgs: true,
mutatesSelfAsArray: true,
returns: null,
returnsPrimitive: UNKNOWN_LITERAL_NUMBER
Expand All @@ -73,6 +79,7 @@ const METHOD_MUTATES_SELF_RETURNS_NUMBER: [ExpressionEntity] = [
const METHOD_MUTATES_SELF_RETURNS_UNKNOWN: [ExpressionEntity] = [
new Method({
callsArgs: null,
mutatesArgs: false,
mutatesSelfAsArray: true,
returns: null,
returnsPrimitive: UNKNOWN_EXPRESSION
Expand All @@ -82,6 +89,7 @@ const METHOD_MUTATES_SELF_RETURNS_UNKNOWN: [ExpressionEntity] = [
const METHOD_DEOPTS_SELF_RETURNS_UNKNOWN: [ExpressionEntity] = [
new Method({
callsArgs: null,
mutatesArgs: false,
mutatesSelfAsArray: 'deopt-only',
returns: null,
returnsPrimitive: UNKNOWN_EXPRESSION
Expand All @@ -91,6 +99,7 @@ const METHOD_DEOPTS_SELF_RETURNS_UNKNOWN: [ExpressionEntity] = [
const METHOD_CALLS_ARG_DEOPTS_SELF_RETURNS_UNKNOWN: [ExpressionEntity] = [
new Method({
callsArgs: [0],
mutatesArgs: false,
mutatesSelfAsArray: 'deopt-only',
returns: null,
returnsPrimitive: UNKNOWN_EXPRESSION
Expand All @@ -100,6 +109,7 @@ const METHOD_CALLS_ARG_DEOPTS_SELF_RETURNS_UNKNOWN: [ExpressionEntity] = [
const METHOD_MUTATES_SELF_RETURNS_SELF: [ExpressionEntity] = [
new Method({
callsArgs: null,
mutatesArgs: false,
mutatesSelfAsArray: true,
returns: 'self',
returnsPrimitive: null
Expand All @@ -109,6 +119,7 @@ const METHOD_MUTATES_SELF_RETURNS_SELF: [ExpressionEntity] = [
const METHOD_CALLS_ARG_MUTATES_SELF_RETURNS_SELF: [ExpressionEntity] = [
new Method({
callsArgs: [0],
mutatesArgs: false,
mutatesSelfAsArray: true,
returns: 'self',
returnsPrimitive: null
Expand Down Expand Up @@ -140,7 +151,7 @@ export const ARRAY_PROTOTYPE = new ObjectEntity(
lastIndexOf: METHOD_RETURNS_NUMBER,
map: METHOD_CALLS_ARG_DEOPTS_SELF_RETURNS_NEW_ARRAY,
pop: METHOD_MUTATES_SELF_RETURNS_UNKNOWN,
push: METHOD_MUTATES_SELF_RETURNS_NUMBER,
push: METHOD_MUTATES_SELF_AND_ARGS_RETURNS_NUMBER,
reduce: METHOD_CALLS_ARG_DEOPTS_SELF_RETURNS_UNKNOWN,
reduceRight: METHOD_CALLS_ARG_DEOPTS_SELF_RETURNS_UNKNOWN,
reverse: METHOD_MUTATES_SELF_RETURNS_SELF,
Expand All @@ -151,7 +162,7 @@ export const ARRAY_PROTOTYPE = new ObjectEntity(
splice: METHOD_MUTATES_SELF_RETURNS_NEW_ARRAY,
toLocaleString: METHOD_RETURNS_STRING,
toString: METHOD_RETURNS_STRING,
unshift: METHOD_MUTATES_SELF_RETURNS_NUMBER,
unshift: METHOD_MUTATES_SELF_AND_ARGS_RETURNS_NUMBER,
values: METHOD_DEOPTS_SELF_RETURNS_UNKNOWN
} as unknown as PropertyMap,
OBJECT_PROTOTYPE,
Expand Down
23 changes: 20 additions & 3 deletions src/ast/nodes/shared/MethodTypes.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,12 @@ import {
NODE_INTERACTION_UNKNOWN_ASSIGNMENT,
NODE_INTERACTION_UNKNOWN_CALL
} from '../../NodeInteractions';
import { EMPTY_PATH, type ObjectPath, UNKNOWN_INTEGER_PATH } from '../../utils/PathTracker';
import {
EMPTY_PATH,
type ObjectPath,
UNKNOWN_INTEGER_PATH,
UNKNOWN_PATH
} from '../../utils/PathTracker';
import {
UNKNOWN_LITERAL_BOOLEAN,
UNKNOWN_LITERAL_NUMBER,
Expand All @@ -17,6 +22,7 @@ import { ExpressionEntity, UNKNOWN_EXPRESSION, UNKNOWN_RETURN_EXPRESSION } from
type MethodDescription = {
callsArgs: number[] | null;
mutatesSelfAsArray: boolean | 'deopt-only';
mutatesArgs: boolean;
} & (
| {
returns: 'self' | (() => ExpressionEntity);
Expand All @@ -34,8 +40,15 @@ export class Method extends ExpressionEntity {
}

deoptimizeArgumentsOnInteractionAtPath({ args, type }: NodeInteraction, path: ObjectPath): void {
if (type === INTERACTION_CALLED && path.length === 0 && this.description.mutatesSelfAsArray) {
args[0]?.deoptimizePath(UNKNOWN_INTEGER_PATH);
if (type === INTERACTION_CALLED && path.length === 0) {
if (this.description.mutatesSelfAsArray) {
args[0]?.deoptimizePath(UNKNOWN_INTEGER_PATH);
}
if (this.description.mutatesArgs) {
for (let index = 1; index < args.length; index++) {
args[index]!.deoptimizePath(UNKNOWN_PATH);
}
}
}
}

Expand Down Expand Up @@ -97,6 +110,7 @@ export class Method extends ExpressionEntity {
export const METHOD_RETURNS_BOOLEAN = [
new Method({
callsArgs: null,
mutatesArgs: false,
mutatesSelfAsArray: false,
returns: null,
returnsPrimitive: UNKNOWN_LITERAL_BOOLEAN
Expand All @@ -106,6 +120,7 @@ export const METHOD_RETURNS_BOOLEAN = [
export const METHOD_RETURNS_STRING = [
new Method({
callsArgs: null,
mutatesArgs: false,
mutatesSelfAsArray: false,
returns: null,
returnsPrimitive: UNKNOWN_LITERAL_STRING
Expand All @@ -115,6 +130,7 @@ export const METHOD_RETURNS_STRING = [
export const METHOD_RETURNS_NUMBER = [
new Method({
callsArgs: null,
mutatesArgs: false,
mutatesSelfAsArray: false,
returns: null,
returnsPrimitive: UNKNOWN_LITERAL_NUMBER
Expand All @@ -124,6 +140,7 @@ export const METHOD_RETURNS_NUMBER = [
export const METHOD_RETURNS_UNKNOWN = [
new Method({
callsArgs: null,
mutatesArgs: false,
mutatesSelfAsArray: false,
returns: null,
returnsPrimitive: UNKNOWN_EXPRESSION
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
module.exports = defineTest({
description: 'deoptimizes elements pushed into an array'
});
21 changes: 21 additions & 0 deletions test/function/samples/deoptimize-pushed-array-element/main.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
let mutated1 = false;
const state1 = {
foo: undefined
};

let mutated2 = false;
const state2 = {
foo: undefined
};

const stack = [];
stack.push(state1, state2);
stack[0].foo = () => (mutated1 = true);
stack.at(-1).foo = () => (mutated2 = true);

state1.foo?.();
assert.ok(mutated1, '1');

state2.foo?.();
assert.ok(mutated2, '2');

1 comment on commit 85ffcc1

@vercel
Copy link

@vercel vercel bot commented on 85ffcc1 Jan 21, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please sign in to comment.