Rabbit-R1/android (non root)/java/sources/kotlin/io/FileTreeWalk.java
2024-05-21 17:08:36 -04:00

388 lines
24 KiB
Java

package kotlin.io;
import io.sentry.protocol.SentryStackFrame;
import io.sentry.protocol.SentryThread;
import java.io.File;
import java.io.IOException;
import java.util.ArrayDeque;
import java.util.Iterator;
import kotlin.Metadata;
import kotlin.NoWhenBranchMatchedException;
import kotlin.Unit;
import kotlin.collections.AbstractIterator;
import kotlin.jvm.functions.Function1;
import kotlin.jvm.functions.Function2;
import kotlin.jvm.internal.DefaultConstructorMarker;
import kotlin.jvm.internal.Intrinsics;
import kotlin.sequences.Sequence;
/* compiled from: FileTreeWalk.kt */
@Metadata(d1 = {"\u0000L\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0018\u0002\n\u0002\u0010\u000b\n\u0000\n\u0002\u0010\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\b\n\u0002\b\u0002\n\u0002\u0010(\n\u0002\b\u0006\u0018\u00002\b\u0012\u0004\u0012\u00020\u00020\u0001:\u0003\u001a\u001b\u001cB\u0019\b\u0010\u0012\u0006\u0010\u0003\u001a\u00020\u0002\u0012\b\b\u0002\u0010\u0004\u001a\u00020\u0005¢\u0006\u0002\u0010\u0006B\u0089\u0001\b\u0002\u0012\u0006\u0010\u0003\u001a\u00020\u0002\u0012\b\b\u0002\u0010\u0004\u001a\u00020\u0005\u0012\u0014\u0010\u0007\u001a\u0010\u0012\u0004\u0012\u00020\u0002\u0012\u0004\u0012\u00020\t\u0018\u00010\b\u0012\u0014\u0010\n\u001a\u0010\u0012\u0004\u0012\u00020\u0002\u0012\u0004\u0012\u00020\u000b\u0018\u00010\b\u00128\u0010\f\u001a4\u0012\u0013\u0012\u00110\u0002¢\u0006\f\b\u000e\u0012\b\b\u000f\u0012\u0004\b\b(\u0010\u0012\u0013\u0012\u00110\u0011¢\u0006\f\b\u000e\u0012\b\b\u000f\u0012\u0004\b\b(\u0012\u0012\u0004\u0012\u00020\u000b\u0018\u00010\r\u0012\b\b\u0002\u0010\u0013\u001a\u00020\u0014¢\u0006\u0002\u0010\u0015J\u000f\u0010\u0016\u001a\b\u0012\u0004\u0012\u00020\u00020\u0017H\u0096\u0002J\u000e\u0010\u0013\u001a\u00020\u00002\u0006\u0010\u0018\u001a\u00020\u0014J\u001a\u0010\u0007\u001a\u00020\u00002\u0012\u0010\u0019\u001a\u000e\u0012\u0004\u0012\u00020\u0002\u0012\u0004\u0012\u00020\t0\bJ \u0010\f\u001a\u00020\u00002\u0018\u0010\u0019\u001a\u0014\u0012\u0004\u0012\u00020\u0002\u0012\u0004\u0012\u00020\u0011\u0012\u0004\u0012\u00020\u000b0\rJ\u001a\u0010\n\u001a\u00020\u00002\u0012\u0010\u0019\u001a\u000e\u0012\u0004\u0012\u00020\u0002\u0012\u0004\u0012\u00020\u000b0\bR\u000e\u0010\u0004\u001a\u00020\u0005X\u0082\u0004¢\u0006\u0002\n\u0000R\u000e\u0010\u0013\u001a\u00020\u0014X\u0082\u0004¢\u0006\u0002\n\u0000R\u001c\u0010\u0007\u001a\u0010\u0012\u0004\u0012\u00020\u0002\u0012\u0004\u0012\u00020\t\u0018\u00010\bX\u0082\u0004¢\u0006\u0002\n\u0000R@\u0010\f\u001a4\u0012\u0013\u0012\u00110\u0002¢\u0006\f\b\u000e\u0012\b\b\u000f\u0012\u0004\b\b(\u0010\u0012\u0013\u0012\u00110\u0011¢\u0006\f\b\u000e\u0012\b\b\u000f\u0012\u0004\b\b(\u0012\u0012\u0004\u0012\u00020\u000b\u0018\u00010\rX\u0082\u0004¢\u0006\u0002\n\u0000R\u001c\u0010\n\u001a\u0010\u0012\u0004\u0012\u00020\u0002\u0012\u0004\u0012\u00020\u000b\u0018\u00010\bX\u0082\u0004¢\u0006\u0002\n\u0000R\u000e\u0010\u0003\u001a\u00020\u0002X\u0082\u0004¢\u0006\u0002\n\u0000¨\u0006\u001d"}, d2 = {"Lkotlin/io/FileTreeWalk;", "Lkotlin/sequences/Sequence;", "Ljava/io/File;", "start", "direction", "Lkotlin/io/FileWalkDirection;", "(Ljava/io/File;Lkotlin/io/FileWalkDirection;)V", "onEnter", "Lkotlin/Function1;", "", "onLeave", "", "onFail", "Lkotlin/Function2;", "Lkotlin/ParameterName;", "name", "f", "Ljava/io/IOException;", "e", "maxDepth", "", "(Ljava/io/File;Lkotlin/io/FileWalkDirection;Lkotlin/jvm/functions/Function1;Lkotlin/jvm/functions/Function1;Lkotlin/jvm/functions/Function2;I)V", "iterator", "", "depth", SentryStackFrame.JsonKeys.FUNCTION, "DirectoryState", "FileTreeWalkIterator", "WalkState", "kotlin-stdlib"}, k = 1, mv = {1, 9, 0}, xi = 48)
/* loaded from: classes3.dex */
public final class FileTreeWalk implements Sequence<File> {
private final FileWalkDirection direction;
private final int maxDepth;
private final Function1<File, Boolean> onEnter;
private final Function2<File, IOException, Unit> onFail;
private final Function1<File, Unit> onLeave;
private final File start;
/* JADX WARN: Multi-variable type inference failed */
private FileTreeWalk(File file, FileWalkDirection fileWalkDirection, Function1<? super File, Boolean> function1, Function1<? super File, Unit> function12, Function2<? super File, ? super IOException, Unit> function2, int i) {
this.start = file;
this.direction = fileWalkDirection;
this.onEnter = function1;
this.onLeave = function12;
this.onFail = function2;
this.maxDepth = i;
}
/* synthetic */ FileTreeWalk(File file, FileWalkDirection fileWalkDirection, Function1 function1, Function1 function12, Function2 function2, int i, int i2, DefaultConstructorMarker defaultConstructorMarker) {
this(file, (i2 & 2) != 0 ? FileWalkDirection.TOP_DOWN : fileWalkDirection, function1, function12, function2, (i2 & 32) != 0 ? Integer.MAX_VALUE : i);
}
/* JADX WARN: 'this' call moved to the top of the method (can break code semantics) */
public FileTreeWalk(File start, FileWalkDirection direction) {
this(start, direction, null, null, null, 0, 32, null);
Intrinsics.checkNotNullParameter(start, "start");
Intrinsics.checkNotNullParameter(direction, "direction");
}
public /* synthetic */ FileTreeWalk(File file, FileWalkDirection fileWalkDirection, int i, DefaultConstructorMarker defaultConstructorMarker) {
this(file, (i & 2) != 0 ? FileWalkDirection.TOP_DOWN : fileWalkDirection);
}
@Override // kotlin.sequences.Sequence
public Iterator<File> iterator() {
return new FileTreeWalkIterator();
}
/* JADX INFO: Access modifiers changed from: private */
/* compiled from: FileTreeWalk.kt */
@Metadata(d1 = {"\u0000\u0012\n\u0002\u0018\u0002\n\u0002\u0010\u0000\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0005\b\"\u0018\u00002\u00020\u0001B\r\u0012\u0006\u0010\u0002\u001a\u00020\u0003¢\u0006\u0002\u0010\u0004J\n\u0010\u0007\u001a\u0004\u0018\u00010\u0003H&R\u0011\u0010\u0002\u001a\u00020\u0003¢\u0006\b\n\u0000\u001a\u0004\b\u0005\u0010\u0006¨\u0006\b"}, d2 = {"Lkotlin/io/FileTreeWalk$WalkState;", "", "root", "Ljava/io/File;", "(Ljava/io/File;)V", "getRoot", "()Ljava/io/File;", "step", "kotlin-stdlib"}, k = 1, mv = {1, 9, 0}, xi = 48)
/* loaded from: classes3.dex */
public static abstract class WalkState {
private final File root;
public final File getRoot() {
return this.root;
}
public abstract File step();
public WalkState(File root) {
Intrinsics.checkNotNullParameter(root, "root");
this.root = root;
}
}
/* JADX INFO: Access modifiers changed from: private */
/* compiled from: FileTreeWalk.kt */
@Metadata(d1 = {"\u0000\u0012\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0002\b\"\u0018\u00002\u00020\u0001B\r\u0012\u0006\u0010\u0002\u001a\u00020\u0003¢\u0006\u0002\u0010\u0004¨\u0006\u0005"}, d2 = {"Lkotlin/io/FileTreeWalk$DirectoryState;", "Lkotlin/io/FileTreeWalk$WalkState;", "rootDir", "Ljava/io/File;", "(Ljava/io/File;)V", "kotlin-stdlib"}, k = 1, mv = {1, 9, 0}, xi = 48)
/* loaded from: classes3.dex */
public static abstract class DirectoryState extends WalkState {
/* JADX WARN: 'super' call moved to the top of the method (can break code semantics) */
public DirectoryState(File rootDir) {
super(rootDir);
Intrinsics.checkNotNullParameter(rootDir, "rootDir");
}
}
/* compiled from: FileTreeWalk.kt */
@Metadata(d1 = {"\u0000(\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0000\n\u0002\u0010\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0006\b\u0082\u0004\u0018\u00002\b\u0012\u0004\u0012\u00020\u00020\u0001:\u0003\r\u000e\u000fB\u0005¢\u0006\u0002\u0010\u0003J\b\u0010\u0007\u001a\u00020\bH\u0014J\u0010\u0010\t\u001a\u00020\n2\u0006\u0010\u000b\u001a\u00020\u0002H\u0002J\u000b\u0010\f\u001a\u0004\u0018\u00010\u0002H\u0082\u0010R\u0014\u0010\u0004\u001a\b\u0012\u0004\u0012\u00020\u00060\u0005X\u0082\u0004¢\u0006\u0002\n\u0000¨\u0006\u0010"}, d2 = {"Lkotlin/io/FileTreeWalk$FileTreeWalkIterator;", "Lkotlin/collections/AbstractIterator;", "Ljava/io/File;", "(Lkotlin/io/FileTreeWalk;)V", SentryThread.JsonKeys.STATE, "Ljava/util/ArrayDeque;", "Lkotlin/io/FileTreeWalk$WalkState;", "computeNext", "", "directoryState", "Lkotlin/io/FileTreeWalk$DirectoryState;", "root", "gotoNext", "BottomUpDirectoryState", "SingleFileState", "TopDownDirectoryState", "kotlin-stdlib"}, k = 1, mv = {1, 9, 0}, xi = 48)
/* loaded from: classes3.dex */
private final class FileTreeWalkIterator extends AbstractIterator<File> {
private final ArrayDeque<WalkState> state;
/* compiled from: FileTreeWalk.kt */
@Metadata(k = 3, mv = {1, 9, 0}, xi = 48)
/* loaded from: classes3.dex */
public /* synthetic */ class WhenMappings {
public static final /* synthetic */ int[] $EnumSwitchMapping$0;
static {
int[] iArr = new int[FileWalkDirection.values().length];
try {
iArr[FileWalkDirection.TOP_DOWN.ordinal()] = 1;
} catch (NoSuchFieldError unused) {
}
try {
iArr[FileWalkDirection.BOTTOM_UP.ordinal()] = 2;
} catch (NoSuchFieldError unused2) {
}
$EnumSwitchMapping$0 = iArr;
}
}
public FileTreeWalkIterator() {
ArrayDeque<WalkState> arrayDeque = new ArrayDeque<>();
this.state = arrayDeque;
if (FileTreeWalk.this.start.isDirectory()) {
arrayDeque.push(directoryState(FileTreeWalk.this.start));
} else if (FileTreeWalk.this.start.isFile()) {
arrayDeque.push(new SingleFileState(this, FileTreeWalk.this.start));
} else {
done();
}
}
@Override // kotlin.collections.AbstractIterator
protected void computeNext() {
File gotoNext = gotoNext();
if (gotoNext != null) {
setNext(gotoNext);
} else {
done();
}
}
private final DirectoryState directoryState(File root) {
int i = WhenMappings.$EnumSwitchMapping$0[FileTreeWalk.this.direction.ordinal()];
if (i == 1) {
return new TopDownDirectoryState(this, root);
}
if (i == 2) {
return new BottomUpDirectoryState(this, root);
}
throw new NoWhenBranchMatchedException();
}
private final File gotoNext() {
File step;
while (true) {
WalkState peek = this.state.peek();
if (peek == null) {
return null;
}
step = peek.step();
if (step == null) {
this.state.pop();
} else {
if (Intrinsics.areEqual(step, peek.getRoot()) || !step.isDirectory() || this.state.size() >= FileTreeWalk.this.maxDepth) {
break;
}
this.state.push(directoryState(step));
}
}
return step;
}
/* JADX INFO: Access modifiers changed from: private */
/* compiled from: FileTreeWalk.kt */
@Metadata(d1 = {"\u0000&\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\u000b\n\u0000\n\u0002\u0010\b\n\u0000\n\u0002\u0010\u0011\n\u0002\b\u0004\b\u0082\u0004\u0018\u00002\u00020\u0001B\r\u0012\u0006\u0010\u0002\u001a\u00020\u0003¢\u0006\u0002\u0010\u0004J\n\u0010\r\u001a\u0004\u0018\u00010\u0003H\u0016R\u000e\u0010\u0005\u001a\u00020\u0006X\u0082\u000e¢\u0006\u0002\n\u0000R\u000e\u0010\u0007\u001a\u00020\bX\u0082\u000e¢\u0006\u0002\n\u0000R\u0018\u0010\t\u001a\n\u0012\u0004\u0012\u00020\u0003\u0018\u00010\nX\u0082\u000e¢\u0006\u0004\n\u0002\u0010\u000bR\u000e\u0010\f\u001a\u00020\u0006X\u0082\u000e¢\u0006\u0002\n\u0000¨\u0006\u000e"}, d2 = {"Lkotlin/io/FileTreeWalk$FileTreeWalkIterator$BottomUpDirectoryState;", "Lkotlin/io/FileTreeWalk$DirectoryState;", "rootDir", "Ljava/io/File;", "(Lkotlin/io/FileTreeWalk$FileTreeWalkIterator;Ljava/io/File;)V", "failed", "", "fileIndex", "", "fileList", "", "[Ljava/io/File;", "rootVisited", "step", "kotlin-stdlib"}, k = 1, mv = {1, 9, 0}, xi = 48)
/* loaded from: classes3.dex */
public final class BottomUpDirectoryState extends DirectoryState {
private boolean failed;
private int fileIndex;
private File[] fileList;
private boolean rootVisited;
final /* synthetic */ FileTreeWalkIterator this$0;
/* JADX WARN: 'super' call moved to the top of the method (can break code semantics) */
public BottomUpDirectoryState(FileTreeWalkIterator fileTreeWalkIterator, File rootDir) {
super(rootDir);
Intrinsics.checkNotNullParameter(rootDir, "rootDir");
this.this$0 = fileTreeWalkIterator;
}
@Override // kotlin.io.FileTreeWalk.WalkState
public File step() {
if (!this.failed && this.fileList == null) {
Function1 function1 = FileTreeWalk.this.onEnter;
if (function1 != null && !((Boolean) function1.invoke(getRoot())).booleanValue()) {
return null;
}
File[] listFiles = getRoot().listFiles();
this.fileList = listFiles;
if (listFiles == null) {
Function2 function2 = FileTreeWalk.this.onFail;
if (function2 != null) {
function2.invoke(getRoot(), new AccessDeniedException(getRoot(), null, "Cannot list files in a directory", 2, null));
}
this.failed = true;
}
}
File[] fileArr = this.fileList;
if (fileArr != null) {
int i = this.fileIndex;
Intrinsics.checkNotNull(fileArr);
if (i < fileArr.length) {
File[] fileArr2 = this.fileList;
Intrinsics.checkNotNull(fileArr2);
int i2 = this.fileIndex;
this.fileIndex = i2 + 1;
return fileArr2[i2];
}
}
if (this.rootVisited) {
Function1 function12 = FileTreeWalk.this.onLeave;
if (function12 != null) {
function12.invoke(getRoot());
}
return null;
}
this.rootVisited = true;
return getRoot();
}
}
/* JADX INFO: Access modifiers changed from: private */
/* compiled from: FileTreeWalk.kt */
@Metadata(d1 = {"\u0000(\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\b\n\u0000\n\u0002\u0010\u0011\n\u0002\b\u0002\n\u0002\u0010\u000b\n\u0002\b\u0002\b\u0082\u0004\u0018\u00002\u00020\u0001B\r\u0012\u0006\u0010\u0002\u001a\u00020\u0003¢\u0006\u0002\u0010\u0004J\n\u0010\f\u001a\u0004\u0018\u00010\u0003H\u0016R\u000e\u0010\u0005\u001a\u00020\u0006X\u0082\u000e¢\u0006\u0002\n\u0000R\u0018\u0010\u0007\u001a\n\u0012\u0004\u0012\u00020\u0003\u0018\u00010\bX\u0082\u000e¢\u0006\u0004\n\u0002\u0010\tR\u000e\u0010\n\u001a\u00020\u000bX\u0082\u000e¢\u0006\u0002\n\u0000¨\u0006\r"}, d2 = {"Lkotlin/io/FileTreeWalk$FileTreeWalkIterator$TopDownDirectoryState;", "Lkotlin/io/FileTreeWalk$DirectoryState;", "rootDir", "Ljava/io/File;", "(Lkotlin/io/FileTreeWalk$FileTreeWalkIterator;Ljava/io/File;)V", "fileIndex", "", "fileList", "", "[Ljava/io/File;", "rootVisited", "", "step", "kotlin-stdlib"}, k = 1, mv = {1, 9, 0}, xi = 48)
/* loaded from: classes3.dex */
public final class TopDownDirectoryState extends DirectoryState {
private int fileIndex;
private File[] fileList;
private boolean rootVisited;
final /* synthetic */ FileTreeWalkIterator this$0;
/* JADX WARN: 'super' call moved to the top of the method (can break code semantics) */
public TopDownDirectoryState(FileTreeWalkIterator fileTreeWalkIterator, File rootDir) {
super(rootDir);
Intrinsics.checkNotNullParameter(rootDir, "rootDir");
this.this$0 = fileTreeWalkIterator;
}
/* JADX WARN: Code restructure failed: missing block: B:29:0x007f, code lost:
if (r0.length == 0) goto L31;
*/
@Override // kotlin.io.FileTreeWalk.WalkState
/*
Code decompiled incorrectly, please refer to instructions dump.
To view partially-correct add '--show-bad-code' argument
*/
public java.io.File step() {
/*
r10 = this;
boolean r0 = r10.rootVisited
r1 = 0
if (r0 != 0) goto L28
kotlin.io.FileTreeWalk$FileTreeWalkIterator r0 = r10.this$0
kotlin.io.FileTreeWalk r0 = kotlin.io.FileTreeWalk.this
kotlin.jvm.functions.Function1 r0 = kotlin.io.FileTreeWalk.access$getOnEnter$p(r0)
if (r0 == 0) goto L20
java.io.File r2 = r10.getRoot()
java.lang.Object r0 = r0.invoke(r2)
java.lang.Boolean r0 = (java.lang.Boolean) r0
boolean r0 = r0.booleanValue()
if (r0 != 0) goto L20
return r1
L20:
r0 = 1
r10.rootVisited = r0
java.io.File r10 = r10.getRoot()
return r10
L28:
java.io.File[] r0 = r10.fileList
if (r0 == 0) goto L47
int r2 = r10.fileIndex
kotlin.jvm.internal.Intrinsics.checkNotNull(r0)
int r0 = r0.length
if (r2 >= r0) goto L35
goto L47
L35:
kotlin.io.FileTreeWalk$FileTreeWalkIterator r0 = r10.this$0
kotlin.io.FileTreeWalk r0 = kotlin.io.FileTreeWalk.this
kotlin.jvm.functions.Function1 r0 = kotlin.io.FileTreeWalk.access$getOnLeave$p(r0)
if (r0 == 0) goto L46
java.io.File r10 = r10.getRoot()
r0.invoke(r10)
L46:
return r1
L47:
java.io.File[] r0 = r10.fileList
if (r0 != 0) goto L93
java.io.File r0 = r10.getRoot()
java.io.File[] r0 = r0.listFiles()
r10.fileList = r0
if (r0 != 0) goto L77
kotlin.io.FileTreeWalk$FileTreeWalkIterator r0 = r10.this$0
kotlin.io.FileTreeWalk r0 = kotlin.io.FileTreeWalk.this
kotlin.jvm.functions.Function2 r0 = kotlin.io.FileTreeWalk.access$getOnFail$p(r0)
if (r0 == 0) goto L77
java.io.File r2 = r10.getRoot()
kotlin.io.AccessDeniedException r9 = new kotlin.io.AccessDeniedException
java.io.File r4 = r10.getRoot()
r5 = 0
java.lang.String r6 = "Cannot list files in a directory"
r7 = 2
r8 = 0
r3 = r9
r3.<init>(r4, r5, r6, r7, r8)
r0.invoke(r2, r9)
L77:
java.io.File[] r0 = r10.fileList
if (r0 == 0) goto L81
kotlin.jvm.internal.Intrinsics.checkNotNull(r0)
int r0 = r0.length
if (r0 != 0) goto L93
L81:
kotlin.io.FileTreeWalk$FileTreeWalkIterator r0 = r10.this$0
kotlin.io.FileTreeWalk r0 = kotlin.io.FileTreeWalk.this
kotlin.jvm.functions.Function1 r0 = kotlin.io.FileTreeWalk.access$getOnLeave$p(r0)
if (r0 == 0) goto L92
java.io.File r10 = r10.getRoot()
r0.invoke(r10)
L92:
return r1
L93:
java.io.File[] r0 = r10.fileList
kotlin.jvm.internal.Intrinsics.checkNotNull(r0)
int r1 = r10.fileIndex
int r2 = r1 + 1
r10.fileIndex = r2
r10 = r0[r1]
return r10
*/
throw new UnsupportedOperationException("Method not decompiled: kotlin.io.FileTreeWalk.FileTreeWalkIterator.TopDownDirectoryState.step():java.io.File");
}
}
/* compiled from: FileTreeWalk.kt */
@Metadata(d1 = {"\u0000\u001a\n\u0002\u0018\u0002\n\u0002\u0018\u0002\n\u0000\n\u0002\u0018\u0002\n\u0002\b\u0002\n\u0002\u0010\u000b\n\u0002\b\u0002\b\u0082\u0004\u0018\u00002\u00020\u0001B\r\u0012\u0006\u0010\u0002\u001a\u00020\u0003¢\u0006\u0002\u0010\u0004J\n\u0010\u0007\u001a\u0004\u0018\u00010\u0003H\u0016R\u000e\u0010\u0005\u001a\u00020\u0006X\u0082\u000e¢\u0006\u0002\n\u0000¨\u0006\b"}, d2 = {"Lkotlin/io/FileTreeWalk$FileTreeWalkIterator$SingleFileState;", "Lkotlin/io/FileTreeWalk$WalkState;", "rootFile", "Ljava/io/File;", "(Lkotlin/io/FileTreeWalk$FileTreeWalkIterator;Ljava/io/File;)V", "visited", "", "step", "kotlin-stdlib"}, k = 1, mv = {1, 9, 0}, xi = 48)
/* loaded from: classes3.dex */
private final class SingleFileState extends WalkState {
final /* synthetic */ FileTreeWalkIterator this$0;
private boolean visited;
/* JADX WARN: 'super' call moved to the top of the method (can break code semantics) */
public SingleFileState(FileTreeWalkIterator fileTreeWalkIterator, File rootFile) {
super(rootFile);
Intrinsics.checkNotNullParameter(rootFile, "rootFile");
this.this$0 = fileTreeWalkIterator;
}
@Override // kotlin.io.FileTreeWalk.WalkState
public File step() {
if (this.visited) {
return null;
}
this.visited = true;
return getRoot();
}
}
}
public final FileTreeWalk onEnter(Function1<? super File, Boolean> function) {
Intrinsics.checkNotNullParameter(function, "function");
return new FileTreeWalk(this.start, this.direction, function, this.onLeave, this.onFail, this.maxDepth);
}
public final FileTreeWalk onLeave(Function1<? super File, Unit> function) {
Intrinsics.checkNotNullParameter(function, "function");
return new FileTreeWalk(this.start, this.direction, this.onEnter, function, this.onFail, this.maxDepth);
}
public final FileTreeWalk onFail(Function2<? super File, ? super IOException, Unit> function) {
Intrinsics.checkNotNullParameter(function, "function");
return new FileTreeWalk(this.start, this.direction, this.onEnter, this.onLeave, function, this.maxDepth);
}
public final FileTreeWalk maxDepth(int depth) {
if (depth <= 0) {
throw new IllegalArgumentException("depth must be positive, but was " + depth + '.');
}
return new FileTreeWalk(this.start, this.direction, this.onEnter, this.onLeave, this.onFail, depth);
}
}