class java.util.stream.DistinctOps$1 extends java.util.stream.ReferencePipeline$StatefulOp<T, T>
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: java.util.stream.DistinctOps$1
  super_class: java.util.stream.ReferencePipeline$StatefulOp
{
  void <init>(java.util.stream.AbstractPipeline, java.util.stream.StreamShape, int);
    descriptor: (Ljava/util/stream/AbstractPipeline;Ljava/util/stream/StreamShape;I)V
    flags: (0x0000) 
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // java.util.stream.DistinctOps$1 this
        start local 1 // java.util.stream.AbstractPipeline $anonymous0
        start local 2 // java.util.stream.StreamShape $anonymous1
        start local 3 // int $anonymous2
         0: .line 55
            aload 0 /* this */
            aload 1 /* $anonymous0 */
            aload 2 /* $anonymous1 */
            iload 3 /* $anonymous2 */
            invokespecial java.util.stream.ReferencePipeline$StatefulOp.<init>:(Ljava/util/stream/AbstractPipeline;Ljava/util/stream/StreamShape;I)V
            return
        end local 3 // int $anonymous2
        end local 2 // java.util.stream.StreamShape $anonymous1
        end local 1 // java.util.stream.AbstractPipeline $anonymous0
        end local 0 // java.util.stream.DistinctOps$1 this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    1     0         this  Ljava/util/stream/DistinctOps$1;
            0    1     1  $anonymous0  Ljava/util/stream/AbstractPipeline<*TT;*>;
            0    1     2  $anonymous1  Ljava/util/stream/StreamShape;
            0    1     3  $anonymous2  I
    MethodParameters:
             Name  Flags
      $anonymous0  
      $anonymous1  
      $anonymous2  

  <P_IN> java.util.stream.Node<T> reduce(java.util.stream.PipelineHelper<T>, java.util.Spliterator<P_IN>);
    descriptor: (Ljava/util/stream/PipelineHelper;Ljava/util/Spliterator;)Ljava/util/stream/Node;
    flags: (0x0000) 
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // java.util.stream.DistinctOps$1 this
        start local 1 // java.util.stream.PipelineHelper helper
        start local 2 // java.util.Spliterator spliterator
         0: .line 62
            invokedynamic get()Ljava/util/function/Supplier;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ()Ljava/lang/Object;
                  java/util/LinkedHashSet.<init>()V (8)
                  ()Ljava/util/LinkedHashSet;
            invokedynamic accept()Ljava/util/function/BiConsumer;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;Ljava/lang/Object;)V
                  java/util/HashSet.add(Ljava/lang/Object;)Z (5)
                  (Ljava/util/LinkedHashSet;Ljava/lang/Object;)V
         1: .line 63
            invokedynamic accept()Ljava/util/function/BiConsumer;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;Ljava/lang/Object;)V
                  java/util/AbstractCollection.addAll(Ljava/util/Collection;)Z (5)
                  (Ljava/util/LinkedHashSet;Ljava/util/LinkedHashSet;)V
         2: .line 62
            invokestatic java.util.stream.ReduceOps.makeRef:(Ljava/util/function/Supplier;Ljava/util/function/BiConsumer;Ljava/util/function/BiConsumer;)Ljava/util/stream/TerminalOp;
         3: .line 61
            astore 3 /* reduceOp */
        start local 3 // java.util.stream.TerminalOp reduceOp
         4: .line 64
            aload 3 /* reduceOp */
            aload 1 /* helper */
            aload 2 /* spliterator */
            invokeinterface java.util.stream.TerminalOp.evaluateParallel:(Ljava/util/stream/PipelineHelper;Ljava/util/Spliterator;)Ljava/lang/Object;
            checkcast java.util.Collection
            invokestatic java.util.stream.Nodes.node:(Ljava/util/Collection;)Ljava/util/stream/Node;
            areturn
        end local 3 // java.util.stream.TerminalOp reduceOp
        end local 2 // java.util.Spliterator spliterator
        end local 1 // java.util.stream.PipelineHelper helper
        end local 0 // java.util.stream.DistinctOps$1 this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    5     0         this  Ljava/util/stream/DistinctOps$1;
            0    5     1       helper  Ljava/util/stream/PipelineHelper<TT;>;
            0    5     2  spliterator  Ljava/util/Spliterator<TP_IN;>;
            4    5     3     reduceOp  Ljava/util/stream/TerminalOp<TT;Ljava/util/LinkedHashSet<TT;>;>;
    Signature: <P_IN:Ljava/lang/Object;>(Ljava/util/stream/PipelineHelper<TT;>;Ljava/util/Spliterator<TP_IN;>;)Ljava/util/stream/Node<TT;>;
    MethodParameters:
             Name  Flags
      helper       
      spliterator  

  <P_IN> java.util.stream.Node<T> opEvaluateParallel(java.util.stream.PipelineHelper<T>, java.util.Spliterator<P_IN>, java.util.function.IntFunction<T[]>);
    descriptor: (Ljava/util/stream/PipelineHelper;Ljava/util/Spliterator;Ljava/util/function/IntFunction;)Ljava/util/stream/Node;
    flags: (0x0000) 
    Code:
      stack=4, locals=8, args_size=4
        start local 0 // java.util.stream.DistinctOps$1 this
        start local 1 // java.util.stream.PipelineHelper helper
        start local 2 // java.util.Spliterator spliterator
        start local 3 // java.util.function.IntFunction generator
         0: .line 71
            getstatic java.util.stream.StreamOpFlag.DISTINCT:Ljava/util/stream/StreamOpFlag;
            aload 1 /* helper */
            invokevirtual java.util.stream.PipelineHelper.getStreamAndOpFlags:()I
            invokevirtual java.util.stream.StreamOpFlag.isKnown:(I)Z
            ifeq 2
         1: .line 73
            aload 1 /* helper */
            aload 2 /* spliterator */
            iconst_0
            aload 3 /* generator */
            invokevirtual java.util.stream.PipelineHelper.evaluate:(Ljava/util/Spliterator;ZLjava/util/function/IntFunction;)Ljava/util/stream/Node;
            areturn
         2: .line 75
      StackMap locals:
      StackMap stack:
            getstatic java.util.stream.StreamOpFlag.ORDERED:Ljava/util/stream/StreamOpFlag;
            aload 1 /* helper */
            invokevirtual java.util.stream.PipelineHelper.getStreamAndOpFlags:()I
            invokevirtual java.util.stream.StreamOpFlag.isKnown:(I)Z
            ifeq 4
         3: .line 76
            aload 0 /* this */
            aload 1 /* helper */
            aload 2 /* spliterator */
            invokevirtual java.util.stream.DistinctOps$1.reduce:(Ljava/util/stream/PipelineHelper;Ljava/util/Spliterator;)Ljava/util/stream/Node;
            areturn
         4: .line 80
      StackMap locals:
      StackMap stack:
            new java.util.concurrent.atomic.AtomicBoolean
            dup
            iconst_0
            invokespecial java.util.concurrent.atomic.AtomicBoolean.<init>:(Z)V
            astore 4 /* seenNull */
        start local 4 // java.util.concurrent.atomic.AtomicBoolean seenNull
         5: .line 81
            new java.util.concurrent.ConcurrentHashMap
            dup
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
            astore 5 /* map */
        start local 5 // java.util.concurrent.ConcurrentHashMap map
         6: .line 82
            aload 4 /* seenNull */
            aload 5 /* map */
            invokedynamic accept(Ljava/util/concurrent/atomic/AtomicBoolean;Ljava/util/concurrent/ConcurrentHashMap;)Ljava/util/function/Consumer;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;)V
                  java/util/stream/DistinctOps$1.lambda$3(Ljava/util/concurrent/atomic/AtomicBoolean;Ljava/util/concurrent/ConcurrentHashMap;Ljava/lang/Object;)V (6)
                  (Ljava/lang/Object;)V
         7: .line 87
            iconst_0
         8: .line 82
            invokestatic java.util.stream.ForEachOps.makeRef:(Ljava/util/function/Consumer;Z)Ljava/util/stream/TerminalOp;
            astore 6 /* forEachOp */
        start local 6 // java.util.stream.TerminalOp forEachOp
         9: .line 88
            aload 6 /* forEachOp */
            aload 1 /* helper */
            aload 2 /* spliterator */
            invokeinterface java.util.stream.TerminalOp.evaluateParallel:(Ljava/util/stream/PipelineHelper;Ljava/util/Spliterator;)Ljava/lang/Object;
            pop
        10: .line 92
            aload 5 /* map */
            invokevirtual java.util.concurrent.ConcurrentHashMap.keySet:()Ljava/util/concurrent/ConcurrentHashMap$KeySetView;
            astore 7 /* keys */
        start local 7 // java.util.Set keys
        11: .line 93
            aload 4 /* seenNull */
            invokevirtual java.util.concurrent.atomic.AtomicBoolean.get:()Z
            ifeq 14
        12: .line 95
            new java.util.HashSet
            dup
            aload 7 /* keys */
            invokespecial java.util.HashSet.<init>:(Ljava/util/Collection;)V
            astore 7 /* keys */
        13: .line 96
            aload 7 /* keys */
            aconst_null
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        14: .line 98
      StackMap locals: java.util.stream.DistinctOps$1 java.util.stream.PipelineHelper java.util.Spliterator java.util.function.IntFunction java.util.concurrent.atomic.AtomicBoolean java.util.concurrent.ConcurrentHashMap java.util.stream.TerminalOp java.util.Set
      StackMap stack:
            aload 7 /* keys */
            invokestatic java.util.stream.Nodes.node:(Ljava/util/Collection;)Ljava/util/stream/Node;
            areturn
        end local 7 // java.util.Set keys
        end local 6 // java.util.stream.TerminalOp forEachOp
        end local 5 // java.util.concurrent.ConcurrentHashMap map
        end local 4 // java.util.concurrent.atomic.AtomicBoolean seenNull
        end local 3 // java.util.function.IntFunction generator
        end local 2 // java.util.Spliterator spliterator
        end local 1 // java.util.stream.PipelineHelper helper
        end local 0 // java.util.stream.DistinctOps$1 this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   15     0         this  Ljava/util/stream/DistinctOps$1;
            0   15     1       helper  Ljava/util/stream/PipelineHelper<TT;>;
            0   15     2  spliterator  Ljava/util/Spliterator<TP_IN;>;
            0   15     3    generator  Ljava/util/function/IntFunction<[TT;>;
            5   15     4     seenNull  Ljava/util/concurrent/atomic/AtomicBoolean;
            6   15     5          map  Ljava/util/concurrent/ConcurrentHashMap<TT;Ljava/lang/Boolean;>;
            9   15     6    forEachOp  Ljava/util/stream/TerminalOp<TT;Ljava/lang/Void;>;
           11   15     7         keys  Ljava/util/Set<TT;>;
    Signature: <P_IN:Ljava/lang/Object;>(Ljava/util/stream/PipelineHelper<TT;>;Ljava/util/Spliterator<TP_IN;>;Ljava/util/function/IntFunction<[TT;>;)Ljava/util/stream/Node<TT;>;
    MethodParameters:
             Name  Flags
      helper       
      spliterator  
      generator    

  <P_IN> java.util.Spliterator<T> opEvaluateParallelLazy(java.util.stream.PipelineHelper<T>, java.util.Spliterator<P_IN>);
    descriptor: (Ljava/util/stream/PipelineHelper;Ljava/util/Spliterator;)Ljava/util/Spliterator;
    flags: (0x0000) 
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // java.util.stream.DistinctOps$1 this
        start local 1 // java.util.stream.PipelineHelper helper
        start local 2 // java.util.Spliterator spliterator
         0: .line 104
            getstatic java.util.stream.StreamOpFlag.DISTINCT:Ljava/util/stream/StreamOpFlag;
            aload 1 /* helper */
            invokevirtual java.util.stream.PipelineHelper.getStreamAndOpFlags:()I
            invokevirtual java.util.stream.StreamOpFlag.isKnown:(I)Z
            ifeq 2
         1: .line 106
            aload 1 /* helper */
            aload 2 /* spliterator */
            invokevirtual java.util.stream.PipelineHelper.wrapSpliterator:(Ljava/util/Spliterator;)Ljava/util/Spliterator;
            areturn
         2: .line 108
      StackMap locals:
      StackMap stack:
            getstatic java.util.stream.StreamOpFlag.ORDERED:Ljava/util/stream/StreamOpFlag;
            aload 1 /* helper */
            invokevirtual java.util.stream.PipelineHelper.getStreamAndOpFlags:()I
            invokevirtual java.util.stream.StreamOpFlag.isKnown:(I)Z
            ifeq 4
         3: .line 110
            aload 0 /* this */
            aload 1 /* helper */
            aload 2 /* spliterator */
            invokevirtual java.util.stream.DistinctOps$1.reduce:(Ljava/util/stream/PipelineHelper;Ljava/util/Spliterator;)Ljava/util/stream/Node;
            invokeinterface java.util.stream.Node.spliterator:()Ljava/util/Spliterator;
            areturn
         4: .line 114
      StackMap locals:
      StackMap stack:
            new java.util.stream.StreamSpliterators$DistinctSpliterator
            dup
            aload 1 /* helper */
            aload 2 /* spliterator */
            invokevirtual java.util.stream.PipelineHelper.wrapSpliterator:(Ljava/util/Spliterator;)Ljava/util/Spliterator;
            invokespecial java.util.stream.StreamSpliterators$DistinctSpliterator.<init>:(Ljava/util/Spliterator;)V
            areturn
        end local 2 // java.util.Spliterator spliterator
        end local 1 // java.util.stream.PipelineHelper helper
        end local 0 // java.util.stream.DistinctOps$1 this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    5     0         this  Ljava/util/stream/DistinctOps$1;
            0    5     1       helper  Ljava/util/stream/PipelineHelper<TT;>;
            0    5     2  spliterator  Ljava/util/Spliterator<TP_IN;>;
    Signature: <P_IN:Ljava/lang/Object;>(Ljava/util/stream/PipelineHelper<TT;>;Ljava/util/Spliterator<TP_IN;>;)Ljava/util/Spliterator<TT;>;
    MethodParameters:
             Name  Flags
      helper       
      spliterator  

  java.util.stream.Sink<T> opWrapSink(int, java.util.stream.Sink<T>);
    descriptor: (ILjava/util/stream/Sink;)Ljava/util/stream/Sink;
    flags: (0x0000) 
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // java.util.stream.DistinctOps$1 this
        start local 1 // int flags
        start local 2 // java.util.stream.Sink sink
         0: .line 120
            aload 2 /* sink */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 122
            getstatic java.util.stream.StreamOpFlag.DISTINCT:Ljava/util/stream/StreamOpFlag;
            iload 1 /* flags */
            invokevirtual java.util.stream.StreamOpFlag.isKnown:(I)Z
            ifeq 3
         2: .line 123
            aload 2 /* sink */
            areturn
         3: .line 124
      StackMap locals:
      StackMap stack:
            getstatic java.util.stream.StreamOpFlag.SORTED:Ljava/util/stream/StreamOpFlag;
            iload 1 /* flags */
            invokevirtual java.util.stream.StreamOpFlag.isKnown:(I)Z
            ifeq 5
         4: .line 125
            new java.util.stream.DistinctOps$1$1
            dup
            aload 0 /* this */
            aload 2 /* sink */
            invokespecial java.util.stream.DistinctOps$1$1.<init>:(Ljava/util/stream/DistinctOps$1;Ljava/util/stream/Sink;)V
            areturn
         5: .line 156
      StackMap locals:
      StackMap stack:
            new java.util.stream.DistinctOps$1$2
            dup
            aload 0 /* this */
            aload 2 /* sink */
            invokespecial java.util.stream.DistinctOps$1$2.<init>:(Ljava/util/stream/DistinctOps$1;Ljava/util/stream/Sink;)V
            areturn
        end local 2 // java.util.stream.Sink sink
        end local 1 // int flags
        end local 0 // java.util.stream.DistinctOps$1 this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    6     0   this  Ljava/util/stream/DistinctOps$1;
            0    6     1  flags  I
            0    6     2   sink  Ljava/util/stream/Sink<TT;>;
    Signature: (ILjava/util/stream/Sink<TT;>;)Ljava/util/stream/Sink<TT;>;
    MethodParameters:
       Name  Flags
      flags  
      sink   

  private static void lambda$3(java.util.concurrent.atomic.AtomicBoolean, java.util.concurrent.ConcurrentHashMap, java.lang.Object);
    descriptor: (Ljava/util/concurrent/atomic/AtomicBoolean;Ljava/util/concurrent/ConcurrentHashMap;Ljava/lang/Object;)V
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=3, locals=3, args_size=3
        start local 2 // java.lang.Object t
         0: .line 83
            aload 2 /* t */
            ifnonnull 2
         1: .line 84
            aload 0
            iconst_1
            invokevirtual java.util.concurrent.atomic.AtomicBoolean.set:(Z)V
            goto 3
         2: .line 86
      StackMap locals:
      StackMap stack:
            aload 1
            aload 2 /* t */
            getstatic java.lang.Boolean.TRUE:Ljava/lang/Boolean;
            invokevirtual java.util.concurrent.ConcurrentHashMap.putIfAbsent:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         3: .line 87
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.Object t
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     2     t  TT;
}
Signature: Ljava/util/stream/ReferencePipeline$StatefulOp<TT;TT;>;
SourceFile: "DistinctOps.java"
EnclosingMethod: java.util.stream.DistinctOps.makeRef:(Ljava/util/stream/AbstractPipeline;)Ljava/util/stream/ReferencePipeline;
NestHost: java.util.stream.DistinctOps
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  public KeySetView = java.util.concurrent.ConcurrentHashMap$KeySetView of java.util.concurrent.ConcurrentHashMap
  java.util.stream.DistinctOps$1
  java.util.stream.DistinctOps$1$1
  java.util.stream.DistinctOps$1$2
  abstract StatefulOp = java.util.stream.ReferencePipeline$StatefulOp of java.util.stream.ReferencePipeline
  final DistinctSpliterator = java.util.stream.StreamSpliterators$DistinctSpliterator of java.util.stream.StreamSpliterators