Files
Mozilla/mozilla/js/src/jsiter.h
brendan%mozilla.org 0a940b7247 JS_1_7_ALPHA_BRANCH landing, mainly destructuring optimizations and let completion (336373, r=mrbkap).
git-svn-id: svn://10.0.0.236/trunk@201636 18797224-902f-48f8-a5cc-f745e15eee43
2006-07-06 01:25:44 +00:00

108 lines
4.1 KiB
C

/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
* vim: set ts=8 sw=4 et tw=80:
*
* ***** BEGIN LICENSE BLOCK *****
* Version: MPL 1.1/GPL 2.0/LGPL 2.1 *
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* The Original Code is Mozilla Communicator client code, released
* March 31, 1998.
*
* The Initial Developer of the Original Code is
* Netscape Communications Corporation.
* Portions created by the Initial Developer are Copyright (C) 1998
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
*
* Alternatively, the contents of this file may be used under the terms of
* either of the GNU General Public License Version 2 or later (the "GPL"),
* or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the MPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the MPL, the GPL or the LGPL.
*
* ***** END LICENSE BLOCK ***** */
#ifndef jsiter_h___
#define jsiter_h___
/*
* JavaScript iterators.
*/
#include "jsprvtd.h"
#include "jspubtd.h"
#define JSITER_FOREACH 0x1 /* return [key, value] pair rather than key */
#define JSITER_COMPAT 0x2 /* compatibility flag for old XDR'd bytecode */
#define JSITER_HIDDEN 0x4 /* internal iterator hidden from user view */
#define JSITER_KEYVALUE 0x8 /* destructuring for-in wants [key, value] */
extern JSBool
js_NewNativeIterator(JSContext *cx, JSObject *obj, uintN flags, jsval *vp);
extern uintN
js_GetNativeIteratorFlags(JSContext *cx, JSObject *iterobj);
extern void
js_CloseNativeIterator(JSContext *cx, JSObject *iterobj);
extern void
js_CloseIteratorState(JSContext *cx, JSObject *iterobj);
extern JSBool
js_DefaultIterator(JSContext *cx, JSObject *obj, uintN argc, jsval *argv,
jsval *rval);
extern JSObject *
js_ValueToIterator(JSContext *cx, jsval v, uintN flags);
/*
* Given iterobj, call iterobj.next().
*
* If idp is non-null, we are enumerating an iterable other than iterobj using
* a for-in or for-each-in loop, so we must return the id of the property being
* enumerated for shadowing and deleted-property checks. In this case, *rval
* will be either the key or the value from a [key, value] pair returned by the
* iterator, depending on whether for-in or for-each-in is being used.
*
* But if idp is null, then we are iterating iterobj itself -- the iterator is
* the right operand of 'in' in the for-in or for-each-in loop -- and we should
* pass its return value back unchanged.
*/
extern JSBool
js_CallIteratorNext(JSContext *cx, JSObject *iterobj, uintN flags,
jsid *idp, jsval *rval);
#define VALUE_IS_STOP_ITERATION(cx,v) \
(!JSVAL_IS_PRIMITIVE(v) && \
OBJ_GET_CLASS(cx, JSVAL_TO_OBJECT(v)) == &js_StopIterationClass)
extern JSBool
js_ThrowStopIteration(JSContext *cx, JSObject *obj);
extern JSObject *
js_NewGenerator(JSContext *cx, JSStackFrame *fp);
extern JSExtendedClass js_GeneratorClass;
extern JSClass js_IteratorClass;
extern JSClass js_StopIterationClass;
extern JSClass js_GeneratorExitClass;
extern JSObject *
js_InitIteratorClasses(JSContext *cx, JSObject *obj);
#endif /* jsiter_h___ */