All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.trino.sql.planner.planprinter.JsonRenderer Maven / Gradle / Ivy

There is a newer version: 465
Show newest version
/*
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package io.trino.sql.planner.planprinter;

import com.fasterxml.jackson.annotation.JsonProperty;
import io.airlift.json.JsonCodec;
import io.trino.cost.PlanNodeStatsAndCostSummary;

import java.util.List;
import java.util.Map;
import java.util.Optional;

import static com.google.common.collect.ImmutableList.toImmutableList;
import static io.trino.sql.planner.planprinter.NodeRepresentation.TypedSymbol;
import static java.util.Objects.requireNonNull;

public class JsonRenderer
        implements Renderer
{
    private static final JsonCodec CODEC = JsonCodec.jsonCodec(JsonRenderedNode.class);

    @Override
    public String render(PlanRepresentation plan)
    {
        return CODEC.toJson(renderJson(plan, plan.getRoot()));
    }

    protected JsonRenderedNode renderJson(PlanRepresentation plan, NodeRepresentation node)
    {
        List children = node.getChildren().stream()
                .map(plan::getNode)
                .filter(Optional::isPresent)
                .map(Optional::get)
                .map(n -> renderJson(plan, n))
                .collect(toImmutableList());

        return new JsonRenderedNode(
                node.getId().toString(),
                node.getName(),
                node.getDescriptor(),
                node.getOutputs(),
                node.getDetails(),
                node.getEstimates(plan.getTypes()),
                children);
    }

    public static class JsonRenderedNode
    {
        private final String id;
        private final String name;
        private final Map descriptor;
        private final List outputs;
        private final List details;
        private final List estimates;
        private final List children;

        public JsonRenderedNode(
                String id,
                String name,
                Map descriptor,
                List outputs,
                List details,
                List estimates,
                List children)
        {
            this.id = requireNonNull(id, "id is null");
            this.name = requireNonNull(name, "name is null");
            this.descriptor = requireNonNull(descriptor, "descriptor is null");
            this.outputs = requireNonNull(outputs, "outputs is null");
            this.details = requireNonNull(details, "details is null");
            this.estimates = requireNonNull(estimates, "estimates is null");
            this.children = requireNonNull(children, "children is null");
        }

        @JsonProperty
        public String getId()
        {
            return id;
        }

        @JsonProperty
        public String getName()
        {
            return name;
        }

        @JsonProperty
        public Map getDescriptor()
        {
            return descriptor;
        }

        @JsonProperty
        public List getOutputs()
        {
            return outputs;
        }

        @JsonProperty
        public List getDetails()
        {
            return details;
        }

        @JsonProperty
        public List getEstimates()
        {
            return estimates;
        }

        @JsonProperty
        public List getChildren()
        {
            return children;
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy