jdk/src/share/classes/java/util/stream/Streams.java
author briangoetz
Sat, 20 Apr 2013 18:53:26 -0400
changeset 17195 e897ad52979e
child 18153 644df1dfb3be
permissions -rw-r--r--
8012650: Arrays streams methods 8011918: java.util.stream.Streams Reviewed-by: alanb, mduigou, darcy, henryjen Contributed-by: brian.goetz@oracle.com, paul.sandoz@oracle.com
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
17195
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
     1
/*
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
     2
 * Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
     4
 *
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    10
 *
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    15
 * accompanied this code).
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    16
 *
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    20
 *
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    23
 * questions.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    24
 */
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    25
package java.util.stream;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    26
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    27
import java.util.Comparator;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    28
import java.util.Iterator;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    29
import java.util.Objects;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    30
import java.util.Spliterator;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    31
import java.util.Spliterators;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    32
import java.util.function.BiFunction;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    33
import java.util.function.Consumer;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    34
import java.util.function.DoubleConsumer;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    35
import java.util.function.IntConsumer;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    36
import java.util.function.LongConsumer;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    37
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    38
/**
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    39
 * Utility methods for operating on and creating streams.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    40
 *
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    41
 * <p>Unless otherwise stated, streams are created as sequential streams.  A
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    42
 * sequential stream can be transformed into a parallel stream by calling the
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    43
 * {@code parallel()} method on the created stream.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    44
 *
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    45
 * @since 1.8
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    46
 */
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    47
class Streams {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    48
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    49
    private Streams() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    50
        throw new Error("no instances");
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    51
    }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    52
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    53
    /**
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    54
     * An object instance representing no value, that cannot be an actual
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    55
     * data element of a stream.  Used when processing streams that can contain
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    56
     * {@code null} elements to distinguish between a {@code null} value and no
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    57
     * value.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    58
     */
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    59
    static final Object NONE = new Object();
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    60
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    61
    /**
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    62
     * An {@code int} range spliterator.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    63
     */
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    64
    static final class RangeIntSpliterator implements Spliterator.OfInt {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    65
        private int from;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    66
        private final int upTo;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    67
        private final int step;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    68
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    69
        RangeIntSpliterator(int from, int upTo, int step) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    70
            this.from = from;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    71
            this.upTo = upTo;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    72
            this.step = step;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    73
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    74
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    75
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    76
        public boolean tryAdvance(IntConsumer consumer) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    77
            boolean hasNext = from < upTo;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    78
            if (hasNext) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    79
                consumer.accept(from);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    80
                from += step;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    81
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    82
            return hasNext;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    83
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    84
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    85
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    86
        public void forEachRemaining(IntConsumer consumer) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    87
            int hUpTo = upTo;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    88
            int hStep = step; // hoist accesses and checks from loop
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    89
            for (int i = from; i < hUpTo; i += hStep)
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    90
                consumer.accept(i);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    91
            from = upTo;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    92
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    93
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    94
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    95
        public long estimateSize() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    96
            int d = upTo - from;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    97
            return (d / step) + ((d % step == 0) ? 0 : 1);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    98
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
    99
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   100
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   101
        public int characteristics() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   102
            return Spliterator.ORDERED | Spliterator.SIZED | Spliterator.SUBSIZED |
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   103
                   Spliterator.IMMUTABLE | Spliterator.NONNULL |
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   104
                   Spliterator.DISTINCT | Spliterator.SORTED;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   105
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   106
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   107
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   108
        public Comparator<? super Integer> getComparator() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   109
            return null;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   110
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   111
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   112
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   113
        public Spliterator.OfInt trySplit() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   114
            return estimateSize() <= 1
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   115
                   ? null
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   116
                   : new RangeIntSpliterator(from, from = from + midPoint(), step);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   117
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   118
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   119
        private int midPoint() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   120
            // Size is known to be >= 2
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   121
            int bisection = (upTo - from) / 2;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   122
            // If bisection > step then round down to nearest multiple of step
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   123
            // otherwise round up to step
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   124
            return bisection > step ? bisection - bisection % step : step;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   125
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   126
    }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   127
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   128
    /**
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   129
     * A {@code long} range spliterator.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   130
     */
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   131
    static final class RangeLongSpliterator implements Spliterator.OfLong {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   132
        private long from;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   133
        private final long upTo;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   134
        private final long step;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   135
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   136
        RangeLongSpliterator(long from, long upTo, long step) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   137
            this.from = from;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   138
            this.upTo = upTo;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   139
            this.step = step;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   140
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   141
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   142
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   143
        public boolean tryAdvance(LongConsumer consumer) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   144
            boolean hasNext = from < upTo;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   145
            if (hasNext) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   146
                consumer.accept(from);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   147
                from += step;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   148
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   149
            return hasNext;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   150
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   151
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   152
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   153
        public void forEachRemaining(LongConsumer consumer) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   154
            long hUpTo = upTo;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   155
            long hStep = step; // hoist accesses and checks from loop
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   156
            for (long i = from; i < hUpTo; i += hStep)
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   157
                consumer.accept(i);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   158
            from = upTo;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   159
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   160
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   161
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   162
        public long estimateSize() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   163
            long d = upTo - from;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   164
            return (d / step) + ((d % step == 0) ? 0 : 1);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   165
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   166
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   167
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   168
        public int characteristics() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   169
            return Spliterator.ORDERED | Spliterator.SIZED | Spliterator.SUBSIZED |
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   170
                   Spliterator.IMMUTABLE | Spliterator.NONNULL |
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   171
                   Spliterator.DISTINCT | Spliterator.SORTED;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   172
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   173
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   174
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   175
        public Comparator<? super Long> getComparator() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   176
            return null;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   177
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   178
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   179
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   180
        public Spliterator.OfLong trySplit() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   181
            return estimateSize() <= 1
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   182
                   ? null
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   183
                   : new RangeLongSpliterator(from, from = from + midPoint(), step);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   184
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   185
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   186
        private long midPoint() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   187
            // Size is known to be >= 2
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   188
            long bisection = (upTo - from) / 2;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   189
            // If bisection > step then round down to nearest multiple of step
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   190
            // otherwise round up to step
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   191
            return bisection > step ? bisection - bisection % step : step;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   192
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   193
    }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   194
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   195
    /**
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   196
     * A {@code double} range spliterator.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   197
     *
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   198
     * <p>The traversing and splitting logic is equivalent to that of
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   199
     * {@code RangeLongSpliterator} for increasing values with a {@code step} of
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   200
     * {@code 1}.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   201
     *
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   202
     *  <p>A {@code double} value is calculated from the function
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   203
     * {@code start + i * step} where {@code i} is the absolute position of the
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   204
     * value when traversing an instance of this class that has not been split.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   205
     * This ensures the same values are produced at the same absolute positions
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   206
     * regardless of how an instance of this class is split or traversed.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   207
     */
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   208
    static final class RangeDoubleSpliterator implements Spliterator.OfDouble {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   209
        private final double from;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   210
        private final double upTo;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   211
        private final double step;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   212
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   213
        private long lFrom;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   214
        private final long lUpTo;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   215
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   216
        RangeDoubleSpliterator(double from, double upTo, double step, long lFrom, long lUpTo) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   217
            this.from = from;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   218
            this.upTo = upTo;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   219
            this.step = step;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   220
            this.lFrom = lFrom;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   221
            this.lUpTo = lUpTo;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   222
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   223
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   224
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   225
        public boolean tryAdvance(DoubleConsumer consumer) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   226
            boolean hasNext = lFrom < lUpTo;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   227
            if (hasNext) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   228
                consumer.accept(from + lFrom * step);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   229
                lFrom++;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   230
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   231
            return hasNext;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   232
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   233
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   234
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   235
        public void forEachRemaining(DoubleConsumer consumer) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   236
            double hOrigin = from;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   237
            double hStep = step;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   238
            long hLUpTo = lUpTo;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   239
            long i = lFrom;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   240
            for (; i < hLUpTo; i++) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   241
                consumer.accept(hOrigin + i * hStep);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   242
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   243
            lFrom = i;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   244
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   245
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   246
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   247
        public long estimateSize() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   248
            return lUpTo - lFrom;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   249
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   250
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   251
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   252
        public int characteristics() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   253
            return Spliterator.ORDERED | Spliterator.SIZED | Spliterator.SUBSIZED |
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   254
                   Spliterator.IMMUTABLE | Spliterator.NONNULL |
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   255
                   Spliterator.DISTINCT | Spliterator.SORTED;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   256
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   257
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   258
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   259
        public Comparator<? super Double> getComparator() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   260
            return null;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   261
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   262
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   263
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   264
        public Spliterator.OfDouble trySplit() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   265
            return estimateSize() <= 1
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   266
                   ? null
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   267
                   : new RangeDoubleSpliterator(from, upTo, step, lFrom, lFrom = lFrom + midPoint());
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   268
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   269
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   270
        private long midPoint() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   271
            // Size is known to be >= 2
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   272
            return (lUpTo - lFrom) / 2;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   273
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   274
    }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   275
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   276
    private static abstract class AbstractStreamBuilderImpl<T, S extends Spliterator<T>> implements Spliterator<T> {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   277
        // >= 0 when building, < 0 when built
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   278
        // -1 == no elements
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   279
        // -2 == one element, held by first
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   280
        // -3 == two or more elements, held by buffer
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   281
        int count;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   282
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   283
        // Spliterator implementation for 0 or 1 element
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   284
        // count == -1 for no elements
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   285
        // count == -2 for one element held by first
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   286
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   287
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   288
        public S trySplit() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   289
            return null;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   290
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   291
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   292
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   293
        public long estimateSize() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   294
            return -count - 1;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   295
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   296
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   297
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   298
        public int characteristics() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   299
            return Spliterator.SIZED | Spliterator.SUBSIZED |
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   300
                   Spliterator.ORDERED | Spliterator.IMMUTABLE;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   301
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   302
    }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   303
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   304
    static final class StreamBuilderImpl<T>
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   305
            extends AbstractStreamBuilderImpl<T, Spliterator<T>>
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   306
            implements StreamBuilder<T> {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   307
        // The first element in the stream
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   308
        // valid if count == 1
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   309
        T first;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   310
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   311
        // The first and subsequent elements in the stream
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   312
        // non-null if count == 2
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   313
        SpinedBuffer<T> buffer;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   314
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   315
        /**
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   316
         * Constructor for building a stream of 0 or more elements.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   317
         */
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   318
        StreamBuilderImpl() { }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   319
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   320
        /**
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   321
         * Constructor for a singleton stream.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   322
         *
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   323
         * @param t the single element
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   324
         */
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   325
        StreamBuilderImpl(T t) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   326
            first = t;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   327
            count = -2;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   328
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   329
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   330
        // StreamBuilder implementation
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   331
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   332
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   333
        public void accept(T t) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   334
            if (count == 0) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   335
                first = t;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   336
                count++;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   337
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   338
            else if (count > 0) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   339
                if (buffer == null) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   340
                    buffer = new SpinedBuffer<>();
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   341
                    buffer.accept(first);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   342
                    count++;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   343
                }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   344
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   345
                buffer.accept(t);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   346
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   347
            else {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   348
                throw new IllegalStateException();
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   349
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   350
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   351
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   352
        public StreamBuilder<T> add(T t) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   353
            accept(t);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   354
            return this;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   355
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   356
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   357
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   358
        public Stream<T> build() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   359
            int c = count;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   360
            if (c >= 0) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   361
                // Switch count to negative value signalling the builder is built
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   362
                count = -count - 1;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   363
                // Use this spliterator if 0 or 1 elements, otherwise use
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   364
                // the spliterator of the spined buffer
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   365
                return (c < 2) ? StreamSupport.stream(this) : StreamSupport.stream(buffer.spliterator());
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   366
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   367
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   368
            throw new IllegalStateException();
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   369
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   370
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   371
        // Spliterator implementation for 0 or 1 element
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   372
        // count == -1 for no elements
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   373
        // count == -2 for one element held by first
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   374
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   375
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   376
        public boolean tryAdvance(Consumer<? super T> action) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   377
            if (count == -2) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   378
                action.accept(first);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   379
                count = -1;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   380
                return true;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   381
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   382
            else {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   383
                return false;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   384
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   385
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   386
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   387
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   388
        public void forEachRemaining(Consumer<? super T> action) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   389
            if (count == -2) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   390
                action.accept(first);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   391
                count = -1;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   392
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   393
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   394
    }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   395
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   396
    static final class IntStreamBuilderImpl
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   397
            extends AbstractStreamBuilderImpl<Integer, Spliterator.OfInt>
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   398
            implements StreamBuilder.OfInt, Spliterator.OfInt {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   399
        // The first element in the stream
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   400
        // valid if count == 1
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   401
        int first;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   402
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   403
        // The first and subsequent elements in the stream
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   404
        // non-null if count == 2
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   405
        SpinedBuffer.OfInt buffer;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   406
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   407
        /**
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   408
         * Constructor for building a stream of 0 or more elements.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   409
         */
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   410
        IntStreamBuilderImpl() { }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   411
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   412
        /**
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   413
         * Constructor for a singleton stream.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   414
         *
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   415
         * @param t the single element
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   416
         */
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   417
        IntStreamBuilderImpl(int t) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   418
            first = t;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   419
            count = -2;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   420
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   421
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   422
        // StreamBuilder implementation
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   423
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   424
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   425
        public void accept(int t) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   426
            if (count == 0) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   427
                first = t;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   428
                count++;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   429
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   430
            else if (count > 0) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   431
                if (buffer == null) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   432
                    buffer = new SpinedBuffer.OfInt();
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   433
                    buffer.accept(first);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   434
                    count++;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   435
                }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   436
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   437
                buffer.accept(t);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   438
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   439
            else {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   440
                throw new IllegalStateException();
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   441
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   442
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   443
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   444
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   445
        public IntStream build() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   446
            int c = count;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   447
            if (c >= 0) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   448
                // Switch count to negative value signalling the builder is built
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   449
                count = -count - 1;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   450
                // Use this spliterator if 0 or 1 elements, otherwise use
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   451
                // the spliterator of the spined buffer
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   452
                return (c < 2) ? StreamSupport.intStream(this) : StreamSupport.intStream(buffer.spliterator());
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   453
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   454
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   455
            throw new IllegalStateException();
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   456
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   457
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   458
        // Spliterator implementation for 0 or 1 element
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   459
        // count == -1 for no elements
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   460
        // count == -2 for one element held by first
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   461
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   462
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   463
        public boolean tryAdvance(IntConsumer action) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   464
            if (count == -2) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   465
                action.accept(first);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   466
                count = -1;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   467
                return true;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   468
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   469
            else {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   470
                return false;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   471
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   472
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   473
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   474
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   475
        public void forEachRemaining(IntConsumer action) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   476
            if (count == -2) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   477
                action.accept(first);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   478
                count = -1;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   479
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   480
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   481
    }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   482
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   483
    static final class LongStreamBuilderImpl
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   484
            extends AbstractStreamBuilderImpl<Long, Spliterator.OfLong>
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   485
            implements StreamBuilder.OfLong, Spliterator.OfLong {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   486
        // The first element in the stream
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   487
        // valid if count == 1
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   488
        long first;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   489
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   490
        // The first and subsequent elements in the stream
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   491
        // non-null if count == 2
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   492
        SpinedBuffer.OfLong buffer;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   493
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   494
        /**
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   495
         * Constructor for building a stream of 0 or more elements.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   496
         */
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   497
        LongStreamBuilderImpl() { }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   498
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   499
        /**
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   500
         * Constructor for a singleton stream.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   501
         *
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   502
         * @param t the single element
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   503
         */
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   504
        LongStreamBuilderImpl(long t) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   505
            first = t;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   506
            count = -2;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   507
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   508
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   509
        // StreamBuilder implementation
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   510
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   511
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   512
        public void accept(long t) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   513
            if (count == 0) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   514
                first = t;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   515
                count++;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   516
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   517
            else if (count > 0) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   518
                if (buffer == null) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   519
                    buffer = new SpinedBuffer.OfLong();
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   520
                    buffer.accept(first);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   521
                    count++;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   522
                }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   523
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   524
                buffer.accept(t);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   525
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   526
            else {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   527
                throw new IllegalStateException();
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   528
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   529
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   530
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   531
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   532
        public LongStream build() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   533
            int c = count;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   534
            if (c >= 0) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   535
                // Switch count to negative value signalling the builder is built
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   536
                count = -count - 1;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   537
                // Use this spliterator if 0 or 1 elements, otherwise use
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   538
                // the spliterator of the spined buffer
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   539
                return (c < 2) ? StreamSupport.longStream(this) : StreamSupport.longStream(buffer.spliterator());
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   540
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   541
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   542
            throw new IllegalStateException();
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   543
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   544
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   545
        // Spliterator implementation for 0 or 1 element
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   546
        // count == -1 for no elements
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   547
        // count == -2 for one element held by first
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   548
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   549
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   550
        public boolean tryAdvance(LongConsumer action) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   551
            if (count == -2) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   552
                action.accept(first);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   553
                count = -1;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   554
                return true;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   555
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   556
            else {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   557
                return false;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   558
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   559
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   560
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   561
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   562
        public void forEachRemaining(LongConsumer action) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   563
            if (count == -2) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   564
                action.accept(first);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   565
                count = -1;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   566
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   567
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   568
    }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   569
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   570
    static final class DoubleStreamBuilderImpl
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   571
            extends AbstractStreamBuilderImpl<Double, Spliterator.OfDouble>
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   572
            implements StreamBuilder.OfDouble, Spliterator.OfDouble {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   573
        // The first element in the stream
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   574
        // valid if count == 1
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   575
        double first;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   576
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   577
        // The first and subsequent elements in the stream
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   578
        // non-null if count == 2
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   579
        SpinedBuffer.OfDouble buffer;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   580
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   581
        /**
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   582
         * Constructor for building a stream of 0 or more elements.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   583
         */
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   584
        DoubleStreamBuilderImpl() { }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   585
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   586
        /**
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   587
         * Constructor for a singleton stream.
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   588
         *
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   589
         * @param t the single element
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   590
         */
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   591
        DoubleStreamBuilderImpl(double t) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   592
            first = t;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   593
            count = -2;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   594
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   595
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   596
        // StreamBuilder implementation
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   597
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   598
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   599
        public void accept(double t) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   600
            if (count == 0) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   601
                first = t;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   602
                count++;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   603
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   604
            else if (count > 0) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   605
                if (buffer == null) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   606
                    buffer = new SpinedBuffer.OfDouble();
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   607
                    buffer.accept(first);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   608
                    count++;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   609
                }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   610
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   611
                buffer.accept(t);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   612
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   613
            else {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   614
                throw new IllegalStateException();
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   615
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   616
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   617
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   618
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   619
        public DoubleStream build() {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   620
            int c = count;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   621
            if (c >= 0) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   622
                // Switch count to negative value signalling the builder is built
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   623
                count = -count - 1;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   624
                // Use this spliterator if 0 or 1 elements, otherwise use
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   625
                // the spliterator of the spined buffer
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   626
                return (c < 2) ? StreamSupport.doubleStream(this) : StreamSupport.doubleStream(buffer.spliterator());
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   627
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   628
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   629
            throw new IllegalStateException();
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   630
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   631
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   632
        // Spliterator implementation for 0 or 1 element
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   633
        // count == -1 for no elements
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   634
        // count == -2 for one element held by first
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   635
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   636
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   637
        public boolean tryAdvance(DoubleConsumer action) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   638
            if (count == -2) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   639
                action.accept(first);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   640
                count = -1;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   641
                return true;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   642
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   643
            else {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   644
                return false;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   645
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   646
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   647
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   648
        @Override
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   649
        public void forEachRemaining(DoubleConsumer action) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   650
            if (count == -2) {
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   651
                action.accept(first);
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   652
                count = -1;
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   653
            }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   654
        }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   655
    }
e897ad52979e 8012650: Arrays streams methods
briangoetz
parents:
diff changeset
   656
}