Skip to content
This repository has been archived by the owner on Apr 22, 2023. It is now read-only.

Breaking v8 change in v0.12.3 #25324

Closed
ljharb opened this issue May 14, 2015 · 16 comments
Closed

Breaking v8 change in v0.12.3 #25324

ljharb opened this issue May 14, 2015 · 16 comments
Assignees
Labels
Milestone

Comments

@ljharb
Copy link
Member

ljharb commented May 14, 2015

https://twitter.com/ljharb/status/598917863433342976

Array.prototype.values no longer exists in v0.12.3; it exists in v0.12.2. This will break any code relying on it.

@misterdjules misterdjules added this to the 0.12.4 milestone May 14, 2015
@misterdjules misterdjules self-assigned this May 14, 2015
@misterdjules
Copy link

Thanks @ljharb for the heads up, I failed to catch that during code review for #18206, my apologies for the problems caused. I'm working on a fix that I'll post asap.

@cjihrig
Copy link

cjihrig commented May 14, 2015

@misterdjules I think we just need to restore this line.

@misterdjules
Copy link

@ljharb In https://twitter.com/ljharb/status/598936102674702336 you mentioned "I think you'd have to shim the JS or downgrade v8". Could you please elaborate? Do you see any problem with reverting https://codereview.chromium.org/647703003 instead?

@misterdjules
Copy link

@cjihrig Same as above, what do you think about reverting https://codereview.chromium.org/647703003 entirely?

@cjihrig
Copy link

cjihrig commented May 14, 2015

@misterdjules My only concern is that Array.prototype.values() was removed from a few engines for a good reason, and that Node would be susceptible to the same issue (granted, the issue is related to Outlook, so we'd probably be fine). However, reverting seems like it would be most in line with Node's philosophy on changes between versions. It's a tough call, but I think I'd say revert.

Can we get opinions from other members of @joyent/node-coreteam?

@ljharb
Copy link
Member Author

ljharb commented May 14, 2015

It was removed because it breaks web compat. node has no such concern. In addition, you could shim it easily by doing Object.defineProperty(Array.prototype, 'values', { enumerable: false, value: Array.prototype[Symbol.iterator] }) if there's any node hooks to do that.

The function is in the spec, so v8 will have to add it back eventually.

As for reverting that specific commit, that should work fine! Wouldn't that revert it for all consumers of v8, or would it be a node-specific fork of v8?

@misterdjules
Copy link

@ljharb We would revert that commit only in deps/v8, so only for node, binary add-ons authors, and other consumers of V8 from node.

@cjihrig
Copy link

cjihrig commented May 14, 2015

Right, the specific problem was related to Outlook. There could be a Node user that is doing something similar. But since we already launched 0.12 with that feature, I think we should revert that commit.

@ljharb
Copy link
Member Author

ljharb commented May 14, 2015

+1, I think that "web compatibility" reverts in v8 should always be reversed for node, since it doesn't apply :-)

@misterdjules
Copy link

@cjihrig That's my current position too.

If you have some time to put together a PR that reverts that change, that would be great, otherwise I'll get that done before tomorrow morning. I would think that the best way to revert that would be to completely revert https://codereview.chromium.org/647703003.

You might want to consult https://github.com/joyent/node/wiki/V8-upgrade-process#how-to-land-a-patch-from-upstream-v8 to do that.

@cjihrig
Copy link

cjihrig commented May 14, 2015

@misterdjules I'd like to work on this one.

@misterdjules
Copy link

@cjihrig Please go ahead :)

@misterdjules
Copy link

Fixed by 6157697 and e23450f. Thank you!

@ljharb
Copy link
Member Author

ljharb commented May 23, 2015

Yay, thanks! Looking forward to the release :-)

@misterdjules
Copy link

@ljharb There's a new candidate release for v0.12.4 at http://nodejs.org/dist/v0.12.4/. Could you please give it a try and let us know if that fixes the problem? Thank you!

@ljharb
Copy link
Member Author

ljharb commented May 23, 2015

Yep, confirmed, it works!

As I said in IRC tho, the instant it appears on nodejs.org/dist, it's 100% fully publicly released, so heads up.

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
Projects
None yet
Development

No branches or pull requests

4 participants