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

com.bigdata.io.AllocationData Maven / Gradle / Ivy

/**

Copyright (C) SYSTAP, LLC DBA Blazegraph 2006-2016.  All rights reserved.

Contact:
     SYSTAP, LLC DBA Blazegraph
     2501 Calvert ST NW #106
     Washington, DC 20008
     [email protected]

This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; version 2 of the License.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 */

package com.bigdata.io;

import java.io.ByteArrayOutputStream;
import java.nio.ByteBuffer;
import java.nio.channels.Channel;

import com.bigdata.io.compression.IRecordCompressor;

/**
 * Utility class to handle Compression and Checksums on a ByteArraySlice
 * 
 * The idea is that it would be used as a "state-aware" buffer that could be
 * saved/restored to/from an IDiskStrategy.
 * 
 * @author Martyn Cutcher
 *
 */
public class AllocationData {
	IByteArraySlice slice;
	boolean compressed;
	boolean checksummed;
	int chk;
	
	public AllocationData(IByteArraySlice slice) {
		this.slice = slice;
	}
	
	public AllocationData compress(IRecordCompressor compressor) {
		if (compressed) {
			return this;
		} else {
			ByteArrayOutputStream outstr = new ByteArrayOutputStream();
			compressor.compress(slice.array(), outstr);
			
			return new AllocationData(new SimpleSlice(outstr.toByteArray()));
			
		}
	}
	
	public AllocationData decompress(IRecordCompressor compressor) {
		if (!compressed) {
			return new AllocationData(new SimpleSlice(compressor.decompress(slice.array())));
		} else {
			return null;
		}
	}
	
	public int checksum() {
		if (!checksummed) {
			chk = ChecksumUtility.getCHK().checksum(slice);
		}
		
		return chk;
	}
	
	public void write(Channel channel) {
	}
	
	static public AllocationData read(Channel channel) {
		return null;
	}
	
	private static class SimpleSlice implements IByteArraySlice {
		
	    final private byte[] buf;
		
		SimpleSlice(ByteBuffer bb) {
			buf = bb.array();
		}

		SimpleSlice(byte[] bb) {
			buf = bb;
		}

//		@Override
		public byte[] array() {
			return buf;
		}

//		@Override
		public int len() {
			return buf.length;
		}

//		@Override
		public int off() {
			return 0;
		}
		
		public byte[] toByteArray() {

		    return buf.clone();

		}
		
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy