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

io.nosqlbench.nb.api.content.ContentResolver Maven / Gradle / Ivy

package io.nosqlbench.nb.api.content;

import java.net.URI;
import java.nio.file.Path;
import java.util.List;

public interface ContentResolver {

    /**
     * Locate the content referenced by the specified name. Content is any
     * URL or file path which contains data to be loaded.
     * 

* Implementors should take care to ensure the following conditions are met: * *

    *
  • For URL style content, resolution is only successful if a stream to download the content * is acquired.
  • *
  • For file paths, resolution is only successful if the filesystem does a standard access * check for readability of a file that is present.
  • *
* * A content resolver may be given a path which is fundamentally incompatible with the * schemes supported by the resolver implementation. It is * required that the resolver return null for such URI values. * * @param uri The URI of a content location, like a file name or URL. * @return A content element which may then be used to access the content */ List> resolve(URI uri); default List> resolve(String uri) { return resolve(URI.create(uri)); } /** * Return a list of matching directory Paths for the {@link URI} which are accessible under * the scheme of the implementing resolver. It is possible that a logical path can return * more than one physical directory path, such as with jar files. * @param uri * @return A list of accessible paths matching the uri, or an empty list */ List resolveDirectory(URI uri); default List resolveDirectory(String uri) { return resolveDirectory(URI.create(uri)); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy