com.github.jessemull.microflexbiginteger.io.StackXML Maven / Gradle / Ivy
/**
* 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 Declaration ----------------------------*/
package com.github.jessemull.microflexbiginteger.io;
/*------------------------------- Dependencies -------------------------------*/
import java.util.ArrayList;
import java.util.List;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlElementWrapper;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.bind.annotation.XmlType;
import com.github.jessemull.microflexbiginteger.plate.Plate;
import com.github.jessemull.microflexbiginteger.plate.Stack;
/**
* This is a wrapper class used to marshal/unmarshal an XML encoded stack object.
*
* @author Jesse L. Mull
* @update Updated Oct 17, 2016
* @address http://www.jessemull.com
* @email [email protected]
*/
@XmlRootElement(name="stack")
@XmlType (propOrder={"type", "label", "rows", "columns", "size", "plates"})
public class StackXML {
/*---------------------------- Private fields ----------------------------*/
private String type; // Data set numerical type
private String label; // Stack label
private int rows; // Stack row number
private int columns; // Stack column number
private int size; // Number of plates in the stack
private List plates =
new ArrayList(); // List of plates in the stack
/*----------------------------- Constructors -----------------------------*/
public StackXML(){}
/**
* Creates an XML stack from a stack object.
* @param Stack the stack object
*/
public StackXML(Stack stack) {
this.type = "BigInteger";
this.label = stack.label();
this.rows = stack.rows();
this.columns = stack.columns();
this.size = stack.size();
for(Plate plate : stack) {
plates.add(new PlateXML(plate));
}
}
/*------------------------- Getters and setters --------------------------*/
/**
* Sets the data type.
* @param String type the data set numerical type
*/
@XmlElement
public void setType(String type) {
this.type = type;
}
/**
* Sets the stack label.
* @param String label the stack label
*/
@XmlElement
public void setLabel(String label) {
this.label = label;
}
/**
* Sets the row number.
* @param int rows number of rows
*/
@XmlElement
public void setRows(int rows) {
this.rows = rows;
}
/**
* Sets the column number.
* @param int columns number of columns
*/
@XmlElement
public void setColumns(int columns) {
this.columns = columns;
}
/**
* Sets the size.
* @param int size number of plates in the stack
*/
@XmlElement
public void setSize(int size) {
this.size = size;
}
/**
* Sets the list of plates in the stack.
* @param List plates the plates
*/
@XmlElement(name="plate")
@XmlElementWrapper(name="plates")
public void setPlates(List plates) {
this.plates = plates;
}
/**
* Returns the data type.
* @return String the data set numerical type
*/
public String getType() {
return this.type;
}
/**
* Returns the stack label.
* @return String the stack label
*/
public String getLabel() {
return this.label;
}
/**
* Returns the row number.
* @return int number of rows
*/
public int getRows() {
return rows;
}
/**
* Returns the column number.
* @return int number of columns
*/
public int getColumns() {
return this.columns;
}
/**
* Returns the size.
* @return int number of plates in the stack
*/
public int getSize() {
return this.size;
}
/**
* Returns the list of plates in the stack.
* @return List the list of plates
*/
public List getPlates() {
return this.plates;
}
/**
* Returns a StackBigInteger object.
* @return StackBigInteger the stack
*/
public Stack toStackObject() {
Stack stack = new Stack(this.rows, this.columns, this.label);
for(PlateXML plate : plates) {
stack.add(plate.toPlateObject());
}
return stack;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy