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

thredds.inventory.partition.IndexReader Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 1998-2018 University Corporation for Atmospheric Research/Unidata
 * See LICENSE for license information.
 */
package thredds.inventory.partition;

import thredds.inventory.MFile;
import java.io.IOException;
import java.nio.file.Path;
import java.util.List;

/**
 * Knows how to read ncx Index files, to decouple eg from GRIB
 *
 * @author caron
 * @since 11/10/13
 */
public interface IndexReader {

  /**
   * Open a Partition ncx file and read children indexes
   * 
   * @param indexFile the Partition ncx index file to open
   * @param callback for each child index, call this back
   * @return true if indexFile is a partition collection
   * @throws IOException on bad things
   */
  boolean readChildren(Path indexFile, AddChildCallback callback) throws IOException;

  interface AddChildCallback {
    /**
     * Callback for readChildren
     * 
     * @param topDir the directory of the child collection
     * @param filename the index filename of the child collection
     * @param lastModified last modified for child collection
     * @throws IOException on bad
     */
    void addChild(String topDir, String filename, long lastModified) throws IOException;
  }

  /**
   * Open an ncx file and find out what type it is
   * 
   * @param indexFile the ncx index file to open
   * @return true if its a partition type index
   * @throws IOException on bad
   */
  boolean isPartition(Path indexFile) throws IOException;

  /**
   * Read the MFiles from a GribCollection index file
   * 
   * @param indexFile the Partition ncx index file to open
   * @param result put results in this list
   * @return true if indexFile is a GribCollection collection, and read ok
   */
  boolean readMFiles(Path indexFile, List result) throws IOException;


}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy