1 /** 2 * Copyright 2005-2015 The Kuali Foundation 3 * 4 * Licensed under the Educational Community License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.opensource.org/licenses/ecl2.php 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 package org.kuali.rice.krad.util.documentserializer; 17 18 import java.util.ArrayList; 19 import java.util.List; 20 21 22 /** 23 * This object keeps track of most of the open tags while a document is serialized. Note that instances of this class 24 * may not necessarily hold all open tags of a document while it is being serialized. For example, tags enclosing list elements 25 * and map entries are not contained within here. See DocumentSerializerServiceImpl, in krad-service-impl, to determine when 26 * this object's state is modified. 27 * 28 * This class's manipulators behave much like a stack, but it has random access characteristics like an array. 29 */ 30 public class SerializationState { 31 protected class SerializationPropertyElement { 32 private String elementName; 33 private PropertyType propertyType; 34 35 public SerializationPropertyElement(String elementName, PropertyType propertyType) { 36 this.elementName = elementName; 37 this.propertyType = propertyType; 38 } 39 40 public String getElementName() { 41 return this.elementName; 42 } 43 44 public PropertyType getPropertyType() { 45 return this.propertyType; 46 } 47 } 48 49 private List<SerializationPropertyElement> pathElements; 50 51 public SerializationState(){ 52 pathElements = new ArrayList<SerializationPropertyElement>(); 53 } 54 55 /** 56 * The number of property elements in this state object. 57 * 58 * @return 59 */ 60 public int numPropertyElements() { 61 return pathElements.size(); 62 } 63 64 /** 65 * Adds an additional state element into this object. 66 * 67 * @param elementName 68 * @param propertyType the type of the property when it was serialized 69 */ 70 public void addSerializedProperty(String elementName, PropertyType propertyType) { 71 SerializationPropertyElement serializationPropertyElement = new SerializationPropertyElement(elementName, propertyType); 72 pathElements.add(serializationPropertyElement); 73 } 74 75 /** 76 * Removes the last added serialized property 77 * 78 */ 79 public void removeSerializedProperty() { 80 pathElements.remove(pathElements.size() - 1); 81 } 82 83 /** 84 * Retrieves the element name of the state element. A parameter value of 0 represents the first element that was added 85 * by calling {@link #addSerializedProperty(String, PropertyType)} that hasn't been removed, and a value of 86 * {@link #numPropertyElements()} - 1 represents the element last added that hasn't been removed. 87 * 88 * @param propertyIndex most be between 0 and the value returned by {@link #numPropertyElements()} - 1 89 * @return 90 */ 91 public String getElementName(int propertyIndex) { 92 return pathElements.get(propertyIndex).getElementName(); 93 } 94 95 /** 96 * Retrieves the property type of the state element. A parameter value of 0 represents the first element that was added 97 * by calling {@link #addSerializedProperty(String, PropertyType)} that hasn't been removed, and a value of 98 * {@link #numPropertyElements()} - 1 represents the element last added that hasn't been removed. 99 * 100 * @param propertyIndex most be between 0 and the value returned by {@link #numPropertyElements()} - 1 101 * @return 102 */ 103 public PropertyType getPropertyType(int propertyIndex) { 104 return pathElements.get(propertyIndex).getPropertyType(); 105 } 106 }