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

com.dimajix.shaded.everit.schema.loader.internal.ReferenceResolver Maven / Gradle / Ivy

There is a newer version: 1.2.0-synapse3.3-spark3.3-hadoop3.3
Show newest version
package com.dimajix.shaded.everit.schema.loader.internal;

import java.net.URI;
import java.net.URISyntaxException;

/**
 * Resolves an {@code id} or {@code ref} against a parent scope.
 * 

* Used by TypeBasedMultiplexer (for handling ids) and by SchemaLoader (for handling * refs). */ public final class ReferenceResolver { /** * Creates an absolute JSON pointer string based on a parent scope and a newly encountered pointer * segment ({@code id} or {@code ref} value). * * @param parentScope * the most immediate parent scope that the resolution should be performed against * @param encounteredSegment * the new segment (complete URI, path, fragment etc) which must be resolved * @return the resolved URI */ public static URI resolve(final URI parentScope, final String encounteredSegment) { try { return new URI(resolve(parentScope == null ? null : parentScope.toString(), encounteredSegment)); } catch (URISyntaxException e) { throw new RuntimeException(e); } } /** * Creates an absolute JSON pointer string based on a parent scope and a newly encountered pointer * segment ({@code id} or {@code ref} value). * * @param parentScope * the most immediate parent scope that the resolution should be performed against * @param encounteredSegment * the new segment (complete URI, path, fragment etc) which must be resolved * @return the resolved URI */ public static String resolve(String parentScope, final String encounteredSegment) { try { if (parentScope == null) { return encounteredSegment; } return new URI(parentScope).resolve(encounteredSegment).toString(); } catch (URISyntaxException e) { throw new RuntimeException(e); } } private ReferenceResolver() { } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy