// 
// Decompiled by Procyon v0.6.0
// 

package io.sentry.protocol;

import java.util.concurrent.ConcurrentHashMap;
import io.sentry.util.CollectionUtils;
import io.sentry.vendor.gson.stream.JsonToken;
import io.sentry.ObjectReader;
import io.sentry.JsonDeserializer;
import java.io.IOException;
import java.util.Iterator;
import io.sentry.ILogger;
import org.jetbrains.annotations.NotNull;
import io.sentry.ObjectWriter;
import java.util.Map;
import org.jetbrains.annotations.Nullable;
import java.util.List;
import io.sentry.JsonSerializable;
import io.sentry.JsonUnknown;

public final class SentryStackTrace implements JsonUnknown, JsonSerializable
{
    @Nullable
    private List<SentryStackFrame> frames;
    @Nullable
    private Map<String, String> registers;
    @Nullable
    private Boolean snapshot;
    @Nullable
    private Map<String, Object> unknown;
    
    public SentryStackTrace() {
    }
    
    public SentryStackTrace(@Nullable final List<SentryStackFrame> frames) {
        this.frames = frames;
    }
    
    @Nullable
    public List<SentryStackFrame> getFrames() {
        return this.frames;
    }
    
    public void setFrames(@Nullable final List<SentryStackFrame> frames) {
        this.frames = frames;
    }
    
    @Nullable
    public Map<String, String> getRegisters() {
        return this.registers;
    }
    
    public void setRegisters(@Nullable final Map<String, String> registers) {
        this.registers = registers;
    }
    
    @Nullable
    public Boolean getSnapshot() {
        return this.snapshot;
    }
    
    public void setSnapshot(@Nullable final Boolean snapshot) {
        this.snapshot = snapshot;
    }
    
    @Nullable
    @Override
    public Map<String, Object> getUnknown() {
        return this.unknown;
    }
    
    @Override
    public void setUnknown(@Nullable final Map<String, Object> unknown) {
        this.unknown = unknown;
    }
    
    @Override
    public void serialize(@NotNull final ObjectWriter writer, @NotNull final ILogger logger) throws IOException {
        writer.beginObject();
        if (this.frames != null) {
            writer.name("frames").value(logger, this.frames);
        }
        if (this.registers != null) {
            writer.name("registers").value(logger, this.registers);
        }
        if (this.snapshot != null) {
            writer.name("snapshot").value(this.snapshot);
        }
        if (this.unknown != null) {
            for (final String key : this.unknown.keySet()) {
                final Object value = this.unknown.get(key);
                writer.name(key);
                writer.value(logger, value);
            }
        }
        writer.endObject();
    }
    
    public static final class JsonKeys
    {
        public static final String FRAMES = "frames";
        public static final String REGISTERS = "registers";
        public static final String SNAPSHOT = "snapshot";
    }
    
    public static final class Deserializer implements JsonDeserializer<SentryStackTrace>
    {
        @NotNull
        @Override
        public SentryStackTrace deserialize(@NotNull final ObjectReader reader, @NotNull final ILogger logger) throws Exception {
            final SentryStackTrace sentryStackTrace = new SentryStackTrace();
            Map<String, Object> unknown = null;
            reader.beginObject();
            while (reader.peek() == JsonToken.NAME) {
                final String nextName2;
                final String nextName = nextName2 = reader.nextName();
                switch (nextName2) {
                    case "frames": {
                        sentryStackTrace.frames = (List<SentryStackFrame>)reader.nextListOrNull(logger, (JsonDeserializer<Object>)new SentryStackFrame.Deserializer());
                        continue;
                    }
                    case "registers": {
                        sentryStackTrace.registers = (Map<String, String>)CollectionUtils.newConcurrentHashMap((Map<Object, Object>)reader.nextObjectOrNull());
                        continue;
                    }
                    case "snapshot": {
                        sentryStackTrace.snapshot = reader.nextBooleanOrNull();
                        continue;
                    }
                    default: {
                        if (unknown == null) {
                            unknown = new ConcurrentHashMap<String, Object>();
                        }
                        reader.nextUnknown(logger, unknown, nextName);
                        continue;
                    }
                }
            }
            sentryStackTrace.setUnknown(unknown);
            reader.endObject();
            return sentryStackTrace;
        }
    }
}
