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

alluxio.util.compression.NoCompressionMarshaller Maven / Gradle / Ivy

There is a newer version: 313
Show newest version
/*
 * The Alluxio Open Foundation licenses this work under the Apache License, version 2.0
 * (the "License"). You may not use this work except in compliance with the License, which is
 * available at www.apache.org/licenses/LICENSE-2.0
 *
 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
 * either express or implied, as more fully set forth in the License.
 *
 * See the NOTICE file distributed with this work for information regarding copyright ownership.
 */

package alluxio.util.compression;

import org.apache.commons.io.FileUtils;
import org.apache.commons.io.IOUtils;

import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.nio.file.Files;
import java.nio.file.Path;
import java.util.stream.Collectors;
import java.util.stream.Stream;

/**
 * Simple marshaller that applies no compression.
 */
public class NoCompressionMarshaller implements DirectoryMarshaller {
  private static final char DIR_CHAR = 'd';
  private static final char FILE_CHAR = 'f';

  @Override
  public long write(Path path, OutputStream outputStream) throws IOException, InterruptedException {
    long totalBytesCopied = 0;
    try (final Stream stream = Files.walk(path);
        DataOutputStream dataOS = new DataOutputStream(outputStream)) {
      for (Path subpath : stream.collect(Collectors.toList())) {
        byte[] relativePath = path.relativize(subpath).toString().getBytes();
        dataOS.write(relativePath.length);
        dataOS.write(relativePath);
        if (subpath.toFile().isDirectory()) {
          dataOS.writeChar(DIR_CHAR);
        } else {
          dataOS.writeChar(FILE_CHAR);
          dataOS.writeLong(FileUtils.sizeOf(subpath.toFile()));
          try (InputStream fileIn = new BufferedInputStream(Files.newInputStream(subpath))) {
            totalBytesCopied += IOUtils.copyLarge(fileIn, dataOS);
          }
        }
      }
    }
    return totalBytesCopied;
  }

  @Override
  public long read(Path path, InputStream inputStream) throws IOException {
    path.toFile().mkdirs();
    long totalBytesRead = 0;
    try (DataInputStream dataIS = new DataInputStream(inputStream)) {
      int pathSize;
      while ((pathSize = dataIS.read()) != -1) {
        byte[] relativePath = new byte[pathSize];
        dataIS.read(relativePath);
        File filePath = new File(path.toFile(), new String(relativePath));
        char c = dataIS.readChar();
        if (c == DIR_CHAR) {
          filePath.mkdirs();
        } else {
          filePath.getParentFile().mkdirs();
          long fileSize = dataIS.readLong();
          try (OutputStream fileOut =
                   new BufferedOutputStream(Files.newOutputStream(filePath.toPath()))) {
            totalBytesRead += IOUtils.copyLarge(dataIS, fileOut, 0, fileSize);
          }
        }
      }
    }
    return totalBytesRead;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy