/*
 * Copyright 2011 the original author or authors.
 * 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 com.jayway.jsonpath;

public enum Option {

    
returns null for missing leaf.
[
     {
        "foo" : "foo1",
        "bar" : "bar1"
     }
     {
        "foo" : "foo2"
     }
]
the path : "$[*].bar" Without flag ["bar1"] is returned With flag ["bar1", null] is returned
/** * returns <code>null</code> for missing leaf. * * <pre> * [ * { * "foo" : "foo1", * "bar" : "bar1" * } * { * "foo" : "foo2" * } * ] *</pre> * * the path : * * "$[*].bar" * * Without flag ["bar1"] is returned * With flag ["bar1", null] is returned * * */
DEFAULT_PATH_LEAF_TO_NULL,
Makes this implementation more compliant to the Goessner spec. All results are returned as Lists.
/** * Makes this implementation more compliant to the Goessner spec. All results are returned as Lists. */
ALWAYS_RETURN_LIST,
Returns a list of path strings representing the path of the evaluation hits
/** * Returns a list of path strings representing the path of the evaluation hits */
AS_PATH_LIST,
Suppress all exceptions when evaluating path.
If an exception is thrown and the option ALWAYS_RETURN_LIST an empty list is returned. If an exception is thrown and the option ALWAYS_RETURN_LIST is not present null is returned.
/** * Suppress all exceptions when evaluating path. * <br/> * If an exception is thrown and the option {@link Option#ALWAYS_RETURN_LIST} an empty list is returned. * If an exception is thrown and the option {@link Option#ALWAYS_RETURN_LIST} is not present null is returned. */
SUPPRESS_EXCEPTIONS,
Configures JsonPath to require properties defined in path when an indefinite path is evaluated. Given:
[
    {
        "a" : "a-val",
        "b" : "b-val"
    },
    {
        "a" : "a-val",
    }
]
evaluating the path "$[*].b" If REQUIRE_PROPERTIES option is present PathNotFoundException is thrown. If REQUIRE_PROPERTIES option is not present ["b-val"] is returned.
/** * Configures JsonPath to require properties defined in path when an <bold>indefinite</bold> path is evaluated. * * * Given: * * <pre> * [ * { * "a" : "a-val", * "b" : "b-val" * }, * { * "a" : "a-val", * } * ] * </pre> * * evaluating the path "$[*].b" * * If REQUIRE_PROPERTIES option is present PathNotFoundException is thrown. * If REQUIRE_PROPERTIES option is not present ["b-val"] is returned. */
REQUIRE_PROPERTIES }