blob: 8c72f7858d8d1eb95df9b534b4f8e36075f7230a [file] [log] [blame]
Jorge Canizalese8304d52015-02-17 19:50:51 -08001/*
2 *
Jan Tattermusch7897ae92017-06-07 22:57:36 +02003 * Copyright 2015 gRPC authors.
Jorge Canizalese8304d52015-02-17 19:50:51 -08004 *
Jan Tattermusch7897ae92017-06-07 22:57:36 +02005 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
Jorge Canizalese8304d52015-02-17 19:50:51 -08008 *
Jan Tattermusch7897ae92017-06-07 22:57:36 +02009 * http://www.apache.org/licenses/LICENSE-2.0
Jorge Canizalese8304d52015-02-17 19:50:51 -080010 *
Jan Tattermusch7897ae92017-06-07 22:57:36 +020011 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
Jorge Canizalese8304d52015-02-17 19:50:51 -080016 *
17 */
18
Jorge Canizales30697c92015-02-17 17:09:14 -080019#import <Foundation/Foundation.h>
20
21@interface NSEnumerator (GRXUtil)
22
Jorge Canizalesb10776c2015-10-26 10:44:55 -070023/**
24 * Returns a NSEnumerator instance that iterates through the elements of the passed container that
25 * supports fast enumeration. Note that this negates the speed benefits of fast enumeration over
26 * NSEnumerator. It's only intended for the rare cases when one needs the latter and only has the
27 * former, e.g. for iteration that needs to be paused and resumed later.
28 */
Jorge Canizales30697c92015-02-17 17:09:14 -080029+ (NSEnumerator *)grx_enumeratorWithContainer:(id<NSFastEnumeration>)container;
30
Jorge Canizalesb10776c2015-10-26 10:44:55 -070031/**
32 * Returns a NSEnumerator instance that provides a single object before finishing. The value is then
33 * released.
34 */
Jorge Canizales30697c92015-02-17 17:09:14 -080035+ (NSEnumerator *)grx_enumeratorWithSingleValue:(id)value;
36
Jorge Canizalesb10776c2015-10-26 10:44:55 -070037/**
38 * Returns a NSEnumerator instance that delegates the invocations of nextObject to the passed block.
39 * When the block first returns nil, it is released.
40 */
Jorge Canizales30697c92015-02-17 17:09:14 -080041+ (NSEnumerator *)grx_enumeratorWithValueSupplier:(id (^)())block;
42@end