/*
* Copyright 2010-2017 Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file 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 com.amazonaws.jmespath;
import com.fasterxml.jackson.databind.JsonNode;
import java.io.IOException;
/**
* Class definition for literal expression that represents
* the arbitrary JSON objects
*/
public class JmesPathLiteral implements JmesPathExpression {
/**
* Represents the literal value
*/
private final JsonNode value;
public JmesPathLiteral(String value) {
try {
this.value = ObjectMapperSingleton.getObjectMapper().readTree(value);
} catch (IOException e) {
throw new RuntimeException(e);
}
}
public JmesPathLiteral(JsonNode value) {
this.value = value;
}
public JsonNode getValue() {
return value;
}
/**
* Delegates to either the CodeGen visitor(JmesPathLiteral) or
* Evaluation visitor(JmesPathLiteral) based on the type of JmesPath
* visitor
*
* @param visitor CodeGen visitor or Evaluation visitor
* @param input Input expression that needs to be evaluated
* @param <Input> Input type for the visitor
* CodeGen visitor: Void
* Evaluation visitor: JsonNode
* @param <Output> Output type for the visitor
* CodeGen visitor: String
* Evaluation visitor: JsonNode
* @return Corresponding output is returned. Evaluated String
* in the case of CodeGen visitor or an evaluated JsonNode
* in the case of Evaluation visitor
* @throws InvalidTypeException
*/
@Override
public <Input, Output> Output accept(JmesPathVisitor<Input, Output> visitor, Input input) throws InvalidTypeException {
return visitor.visit(this, input);
}
}