com.bazaarvoice.jolt.common.PathEvaluatingTraversal Maven / Gradle / Ivy
/*
* Copyright 2014 Bazaarvoice, Inc.
*
* 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.bazaarvoice.jolt.common;
import com.bazaarvoice.jolt.common.pathelement.EvaluatablePathElement;
import com.bazaarvoice.jolt.common.pathelement.PathElement;
import com.bazaarvoice.jolt.common.tree.WalkedPath;
import com.bazaarvoice.jolt.exception.SpecException;
import com.bazaarvoice.jolt.traversr.Traversr;
import com.bazaarvoice.jolt.utils.StringTools;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import static com.bazaarvoice.jolt.common.PathElementBuilder.parseDotNotationRHS;
/**
* Combines a Traversr with the ability to evaluate References against a WalkedPath.
*
* Convenience class for path based off a single dot notation String,
* like "rating.&1(2).&.value".
*
* This processes the dot notation path into internal data structures, so
* that the String processing only happens once.
*/
public abstract class PathEvaluatingTraversal {
private final List elements;
private final Traversr traversr;
public PathEvaluatingTraversal( String dotNotation ) {
if ( ( dotNotation.contains("*") && ! dotNotation.contains( "\\*" ) ) ||
( dotNotation.contains("$") && ! dotNotation.contains( "\\$" ) ) ) {
throw new SpecException("DotNotation (write key) can not contain '*' or '$' : write key: " + dotNotation );
}
List paths;
Traversr trav;
if ( StringTools.isNotBlank( dotNotation ) ) {
// Compute the path elements.
paths = parseDotNotationRHS( dotNotation );
// Use the canonical versions of the path elements to create the Traversr
List traversrPaths = new ArrayList<>( paths.size() );
for ( PathElement pe : paths ) {
traversrPaths.add( pe.getCanonicalForm() );
}
trav = createTraversr( traversrPaths );
}
else {
paths = Collections.emptyList();
trav = createTraversr( Arrays.asList( "" ) );
}
List evalPaths = new ArrayList<>( paths.size() );
for( PathElement pe : paths ) {
if ( ! ( pe instanceof EvaluatablePathElement ) ) {
throw new SpecException( "RHS key=" + pe.getRawKey() + " is not a valid RHS key." );
}
evalPaths.add( (EvaluatablePathElement) pe );
}
this.elements = Collections.unmodifiableList( evalPaths );
this.traversr = trav;
}
protected abstract Traversr createTraversr(List paths);
/**
* Use the supplied WalkedPath, in the evaluation of each of our PathElements to
* build a concrete output path. Then use that output path to write the given
* data to the output.
*
* @param data data to write
* @param output data structure we are going to write the data to
* @param walkedPath reference used to lookup reference values like "&1(2)"
*/
public void write( Object data, Map output, WalkedPath walkedPath ) {
List evaledPaths = evaluate( walkedPath );
if ( evaledPaths != null ) {
traversr.set( output, evaledPaths, data );
}
}
public Optional
© 2015 - 2025 Weber Informatics LLC | Privacy Policy