79a63204a53c838e26dacc368394f26a57186dae
[WebKit.git] / Source / JavaScriptCore / builtins / MapPrototype.js
1 /*
2  * Copyright (C) 2016 Yusuke Suzuki <utatane.tea@gmail.com>.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
14  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE INC. OR
17  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24  */
25
26 function forEach(callback /*, thisArg */)
27 {
28     "use strict";
29
30     if (!@isMap(this))
31         @throwTypeError("Map operation called on non-Map object");
32
33     if (typeof callback !== 'function')
34         @throwTypeError("Map.prototype.forEach callback must be a function");
35
36     var thisArg = arguments.length > 1 ? arguments[1] : @undefined;
37     var iterator = @MapIterator(this);
38
39     // To avoid object allocations for iterator result objects, we pass the placeholder to the special "next" function in order to fill the results.
40     var value = [ @undefined, @undefined ];
41     for (;;) {
42         if (@mapIteratorNext.@call(iterator, value))
43             break;
44         callback.@call(thisArg, value[1], value[0], this);
45     }
46 }