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

tech.tablesaw.io.saw.SawMetadata Maven / Gradle / Ivy

There is a newer version: 0.43.3
Show newest version
package tech.tablesaw.io.saw;

import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.google.common.base.Objects;
import java.io.IOException;
import java.io.UncheckedIOException;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Path;
import java.util.List;
import tech.tablesaw.api.Table;

/** All metadata used in the storage of one table */
public class SawMetadata {

  // The name of the file that this data is written to
  static final String METADATA_FILE_NAME = "Metadata.json";

  // The version of the Saw Storage system used to write the file
  private static final int SAW_VERSION = 2;

  private static final ObjectMapper objectMapper = new ObjectMapper();

  private TableMetadata tableMetadata;
  private int version;
  private CompressionType compressionType;
  private EncryptionType encryptionType;

  /**
   * Returns a SawMetadata instance derived from the json-formatted Metadata.json file in the
   * directory specified by sawPath
   *
   * @param sawPath The path to the folder containing the Saw metadata file and table data
   */
  static SawMetadata readMetadata(Path sawPath) {

    Path resolvePath = sawPath.resolve(METADATA_FILE_NAME);
    byte[] encoded;
    try {
      encoded = Files.readAllBytes(resolvePath);
    } catch (IOException e) {
      throw new UncheckedIOException(
          "Unable to read Saw Metadata file at " + resolvePath.toString(), e);
    }
    return SawMetadata.fromJson(new String(encoded, StandardCharsets.UTF_8));
  }

  public SawMetadata(Table table, WriteOptions options) {
    this.tableMetadata = new TableMetadata(table);
    this.version = SAW_VERSION;
    this.compressionType = options.getCompressionType();
    this.encryptionType = options.getEncryptionType();
  }

  /** Default constructor for Jackson json serialization */
  protected SawMetadata() {}

  /**
   * Returns an instance of TableMetadata constructed from the provided json string
   *
   * @param jsonString A json-formatted String consistent with those output by the toJson() method
   */
  static SawMetadata fromJson(String jsonString) {
    try {
      return objectMapper.readValue(jsonString, SawMetadata.class);
    } catch (IOException e) {
      throw new UncheckedIOException(e);
    }
  }

  /**
   * Returns a JSON string that represents this object
   *
   * @see static methdod fromJson() which constructs a SawMetadata object from this JSON output
   */
  String toJson() {
    try {
      return objectMapper.writeValueAsString(this);
    } catch (JsonProcessingException e) {
      throw new UncheckedIOException(e);
    }
  }

  public TableMetadata getTableMetadata() {
    return tableMetadata;
  }

  /** Returns the saw file format version used to create this file */
  public int getVersion() {
    return version;
  }

  public CompressionType getCompressionType() {
    return compressionType;
  }

  public EncryptionType getEncryptionType() {
    return encryptionType;
  }

  @JsonIgnore
  public List getColumnMetadataList() {
    return tableMetadata.getColumnMetadataList();
  }

  @JsonIgnore
  public Table structure() {
    return tableMetadata.structure();
  }

  @JsonIgnore
  public String getTableName() {
    return tableMetadata.getName();
  }

  @JsonIgnore
  public List columnNames() {
    return tableMetadata.columnNames();
  }

  @JsonIgnore
  public int getRowCount() {
    return tableMetadata.getRowCount();
  }

  public int columnCount() {
    return tableMetadata.columnCount();
  }

  public String shape() {
    return tableMetadata.shape();
  }

  @Override
  public boolean equals(Object o) {
    if (this == o) return true;
    if (o == null || getClass() != o.getClass()) return false;
    SawMetadata that = (SawMetadata) o;
    return getVersion() == that.getVersion()
        && Objects.equal(getTableMetadata(), that.getTableMetadata())
        && getCompressionType() == that.getCompressionType();
  }

  @Override
  public int hashCode() {
    return Objects.hashCode(getTableMetadata(), getVersion(), getCompressionType());
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy