abstract class java.util.stream.ReduceOps$ReduceOp<T, R, S extends java.util.stream.ReduceOps$AccumulatingSink<T, R, S>> implements java.util.stream.TerminalOp<T, R>
  minor version: 0
  major version: 59
  flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
  this_class: java.util.stream.ReduceOps$ReduceOp
  super_class: java.lang.Object
{
  private final java.util.stream.StreamShape inputShape;
    descriptor: Ljava/util/stream/StreamShape;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  void <init>(java.util.stream.StreamShape);
    descriptor: (Ljava/util/stream/StreamShape;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.util.stream.ReduceOps$ReduceOp this
        start local 1 // java.util.stream.StreamShape shape
         0: .line 694
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 695
            aload 0 /* this */
            aload 1 /* shape */
            putfield java.util.stream.ReduceOps$ReduceOp.inputShape:Ljava/util/stream/StreamShape;
         2: .line 696
            return
        end local 1 // java.util.stream.StreamShape shape
        end local 0 // java.util.stream.ReduceOps$ReduceOp this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    3     0   this  Ljava/util/stream/ReduceOps$ReduceOp<TT;TR;TS;>;
            0    3     1  shape  Ljava/util/stream/StreamShape;
    MethodParameters:
       Name  Flags
      shape  

  public abstract S makeSink();
    descriptor: ()Ljava/util/stream/ReduceOps$AccumulatingSink;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Signature: ()TS;

  public java.util.stream.StreamShape inputShape();
    descriptor: ()Ljava/util/stream/StreamShape;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.util.stream.ReduceOps$ReduceOp this
         0: .line 702
            aload 0 /* this */
            getfield java.util.stream.ReduceOps$ReduceOp.inputShape:Ljava/util/stream/StreamShape;
            areturn
        end local 0 // java.util.stream.ReduceOps$ReduceOp this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/util/stream/ReduceOps$ReduceOp<TT;TR;TS;>;

  public <P_IN> R evaluateSequential(java.util.stream.PipelineHelper<T>, java.util.Spliterator<P_IN>);
    descriptor: (Ljava/util/stream/PipelineHelper;Ljava/util/Spliterator;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // java.util.stream.ReduceOps$ReduceOp this
        start local 1 // java.util.stream.PipelineHelper helper
        start local 2 // java.util.Spliterator spliterator
         0: .line 708
            aload 1 /* helper */
            aload 0 /* this */
            invokevirtual java.util.stream.ReduceOps$ReduceOp.makeSink:()Ljava/util/stream/ReduceOps$AccumulatingSink;
            aload 2 /* spliterator */
            invokevirtual java.util.stream.PipelineHelper.wrapAndCopyInto:(Ljava/util/stream/Sink;Ljava/util/Spliterator;)Ljava/util/stream/Sink;
            checkcast java.util.stream.ReduceOps$AccumulatingSink
            invokeinterface java.util.stream.ReduceOps$AccumulatingSink.get:()Ljava/lang/Object;
            areturn
        end local 2 // java.util.Spliterator spliterator
        end local 1 // java.util.stream.PipelineHelper helper
        end local 0 // java.util.stream.ReduceOps$ReduceOp this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    1     0         this  Ljava/util/stream/ReduceOps$ReduceOp<TT;TR;TS;>;
            0    1     1       helper  Ljava/util/stream/PipelineHelper<TT;>;
            0    1     2  spliterator  Ljava/util/Spliterator<TP_IN;>;
    Signature: <P_IN:Ljava/lang/Object;>(Ljava/util/stream/PipelineHelper<TT;>;Ljava/util/Spliterator<TP_IN;>;)TR;
    MethodParameters:
             Name  Flags
      helper       
      spliterator  

  public <P_IN> R evaluateParallel(java.util.stream.PipelineHelper<T>, java.util.Spliterator<P_IN>);
    descriptor: (Ljava/util/stream/PipelineHelper;Ljava/util/Spliterator;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // java.util.stream.ReduceOps$ReduceOp this
        start local 1 // java.util.stream.PipelineHelper helper
        start local 2 // java.util.Spliterator spliterator
         0: .line 714
            new java.util.stream.ReduceOps$ReduceTask
            dup
            aload 0 /* this */
            aload 1 /* helper */
            aload 2 /* spliterator */
            invokespecial java.util.stream.ReduceOps$ReduceTask.<init>:(Ljava/util/stream/ReduceOps$ReduceOp;Ljava/util/stream/PipelineHelper;Ljava/util/Spliterator;)V
            invokevirtual java.util.stream.ReduceOps$ReduceTask.invoke:()Ljava/lang/Object;
            checkcast java.util.stream.ReduceOps$AccumulatingSink
            invokeinterface java.util.stream.ReduceOps$AccumulatingSink.get:()Ljava/lang/Object;
            areturn
        end local 2 // java.util.Spliterator spliterator
        end local 1 // java.util.stream.PipelineHelper helper
        end local 0 // java.util.stream.ReduceOps$ReduceOp this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    1     0         this  Ljava/util/stream/ReduceOps$ReduceOp<TT;TR;TS;>;
            0    1     1       helper  Ljava/util/stream/PipelineHelper<TT;>;
            0    1     2  spliterator  Ljava/util/Spliterator<TP_IN;>;
    Signature: <P_IN:Ljava/lang/Object;>(Ljava/util/stream/PipelineHelper<TT;>;Ljava/util/Spliterator<TP_IN;>;)TR;
    MethodParameters:
             Name  Flags
      helper       
      spliterator  
}
Signature: <T:Ljava/lang/Object;R:Ljava/lang/Object;S::Ljava/util/stream/ReduceOps$AccumulatingSink<TT;TR;TS;>;>Ljava/lang/Object;Ljava/util/stream/TerminalOp<TT;TR;>;
SourceFile: "ReduceOps.java"
NestHost: java.util.stream.ReduceOps
InnerClasses:
  private abstract AccumulatingSink = java.util.stream.ReduceOps$AccumulatingSink of java.util.stream.ReduceOps
  private abstract ReduceOp = java.util.stream.ReduceOps$ReduceOp of java.util.stream.ReduceOps
  private final ReduceTask = java.util.stream.ReduceOps$ReduceTask of java.util.stream.ReduceOps