- 
                Notifications
    You must be signed in to change notification settings 
- Fork 471
Add Iterator.prototype bindings #7506
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
| rescript
 @rescript/darwin-arm64
 @rescript/darwin-x64
 @rescript/linux-arm64
 @rescript/linux-x64
 @rescript/win32-x64
 commit:  | 
| external toArray: t<'a> => array<'a> = "toArray" | ||
| external toArrayWithMapper: (t<'a>, 'a => 'b) => array<'b> = "Array.from" | ||
|  | ||
| let forEach = (iterator, f) => { | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm for this change 👍
Iterator.forEach's behaviour was different to Iterator.prototype.forEach as the latter only calls its callback with yielded values, not the iterator's final return value.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Great stuff, thanks a lot!
But could you use tests (using assertEqual) instead of doing Console.logs in the doc strings?
| 
 Yep, will do! I'm less familiar with that part of the codebase. | 
Co-authored-by: Christoph Knittel <christoph@knittel.cc>
| This one seems to fail on Linux: rescript/tests/tests/src/js_re_test.res Lines 5 to 19 in 97a81e5 
 No clue why, or how it could be related to my changes. | 
| As suggested by @shulhi we should just add docstrings with information about the JS runtimes that are required to use this. | 
| I'm tempted to remove  We can stick to the actual MDN-listed method names instead of an alias. | 
| 
 I don't think I added it originally, I just moved it from the Core repo to the compiler repo. I have no issue with removing it as long as you add a deprecation message explaining what to use instead. | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This looks good to me, but I don't have strong opinions on this. So if people think this is fine then I'm also fine with it.
| }; | ||
|  | ||
| Stdlib_Iterator.forEach(iterator, v => { | ||
| iterator.forEach(v => { | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can't do make test locally anymore after this:
file:///Users/cristianocalcagno/GitHub/rescript-compiler/tests/tests/src/core/Core_IteratorTests.mjs:19
iterator.forEach(v => {
         ^
TypeError: iterator.forEach is not a function
    at file:///Users/cristianocalcagno/GitHub/rescript-compiler/tests/tests/src/core/Core_IteratorTests.mjs:19:10
    at ModuleJob.run (node:internal/modules/esm/module_job:263:25)
    at async ModuleLoader.import (node:internal/modules/esm/loader:540:24)
    at async asyncRunEntryPointWithESMLoader (node:internal/modules/run_main:117:5)
Node.js v20.19.0
file:///Users/cristianocalcagno/GitHub/rescript-compiler/tests/tests/src/core/Core_IteratorTests.mjs:19
iterator.forEach(v => {
^
TypeError: iterator.forEach is not a function
at file:///Users/cristianocalcagno/GitHub/rescript-compiler/tests/tests/src/core/Core_IteratorTests.mjs:19:10
at ModuleJob.run (node:internal/modules/esm/module_job:263:25)
at async ModuleLoader.import (node:internal/modules/esm/loader:540:24)
at async asyncRunEntryPointWithESMLoader (node:internal/modules/run_main:117:5)
Node.js v20.19.0
And node `v20.x` I believe is the recommended version but this might require a newer version?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@cristianoc to run the unit tests, you'll need to update to node.js v22, which supports Iterator.prototype.forEach.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
looks like CONTRIBUTING.md needs updating
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've made a PR for updating CONTRIBUTING.md here: #7558
This may be a bit controversial, but I've added bindings for Iterators and Generators and corrected some bindings, resulting in a minor breaking change.