StorageIndexCellMapping.java
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.tika.parser.microsoft.onenote.fsshttpb.streamobj;
import java.io.IOException;
import java.util.List;
import java.util.concurrent.atomic.AtomicInteger;
import org.apache.tika.exception.TikaException;
import org.apache.tika.parser.microsoft.onenote.fsshttpb.streamobj.basic.BasicObject;
import org.apache.tika.parser.microsoft.onenote.fsshttpb.streamobj.basic.CellID;
import org.apache.tika.parser.microsoft.onenote.fsshttpb.streamobj.basic.ExGuid;
import org.apache.tika.parser.microsoft.onenote.fsshttpb.streamobj.basic.SerialNumber;
/**
* Specifies the storage index cell mappings (with cell identifier, cell mapping extended GUID,
* and cell mapping serial number)
*/
public class StorageIndexCellMapping extends StreamObject {
public org.apache.tika.parser.microsoft.onenote.fsshttpb.streamobj.basic.CellID cellID;
public ExGuid cellMappingExGuid;
public SerialNumber cellMappingSerialNumber;
/**
* Initializes a new instance of the StorageIndexCellMapping class.
*/
public StorageIndexCellMapping() {
super(StreamObjectTypeHeaderStart.StorageIndexCellMapping);
}
/**
* Used to de-serialize the items.
*
* @param byteArray A Byte array
* @param currentIndex Start position
* @param lengthOfItems The length of the items
*/
@Override
protected void deserializeItemsFromByteArray(byte[] byteArray, AtomicInteger currentIndex,
int lengthOfItems)
throws TikaException, IOException {
AtomicInteger index = new AtomicInteger(currentIndex.get());
this.cellID = BasicObject.parse(byteArray, index, CellID.class);
this.cellMappingExGuid = BasicObject.parse(byteArray, index, ExGuid.class);
this.cellMappingSerialNumber = BasicObject.parse(byteArray, index, SerialNumber.class);
if (index.get() - currentIndex.get() != lengthOfItems) {
throw new StreamObjectParseErrorException(currentIndex.get(), "StorageIndexCellMapping",
"Stream object over-parse error", null);
}
currentIndex.set(index.get());
}
/**
* Used to convert the element into a byte List.
*
* @param byteList A Byte list
* @return The length of list
*/
@Override
protected int serializeItemsToByteList(List<Byte> byteList) throws IOException {
int itemsIndex = byteList.size();
byteList.addAll(this.cellID.serializeToByteList());
byteList.addAll(this.cellMappingExGuid.serializeToByteList());
byteList.addAll(this.cellMappingSerialNumber.serializeToByteList());
return byteList.size() - itemsIndex;
}
}