View Javadoc

1   /*
2    * Copyright 2007-2008 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.kns.util.documentserializer;
17  
18  import java.util.ArrayList;
19  import java.util.Collection;
20  import java.util.List;
21  
22  import org.kuali.rice.kns.bo.BusinessObject;
23  import org.kuali.rice.kns.service.impl.DocumentSerializerServiceImpl;
24  
25  /**
26   * This object keeps track of most of the open tags while a document is serialized.  Note that instances of this class
27   * may not necessarily hold all open tags of a document while it is being serialized.  For example, tags enclosing list elements
28   * and map entries are not contained within here.  See {@link DocumentSerializerServiceImpl} to determine when this object's state
29   * is modified.
30   * 
31   * This class's manipulators behave much like a stack, but it has random access characteristics like an array. 
32   */
33  public class DocumentSerializationState {
34      protected class SerializationPropertyElement {
35          private String elementName;
36          private PropertyType propertyType;
37          
38          public SerializationPropertyElement(String elementName, PropertyType propertyType) {
39              this.elementName = elementName;
40              this.propertyType = propertyType;
41          }
42          
43          public String getElementName() {
44              return this.elementName;
45          }
46          
47          public PropertyType getPropertyType() {
48              return this.propertyType;
49          }
50      }
51      
52      private List<SerializationPropertyElement> pathElements;
53      
54      public DocumentSerializationState() {
55          pathElements = new ArrayList<SerializationPropertyElement>();
56      }
57      
58      /**
59       * The number of property elements in this state object.
60       * 
61       * @return
62       */
63      public int numPropertyElements() {
64          return pathElements.size();
65      }
66      
67      /**
68       * Adds an additional state element into this object.
69       * 
70       * @param elementName
71       * @param propertyType the type of the property when it was serialized
72       */
73      public void addSerializedProperty(String elementName, PropertyType propertyType) {
74          SerializationPropertyElement serializationPropertyElement = new SerializationPropertyElement(elementName, propertyType);
75          pathElements.add(serializationPropertyElement);
76      }
77      
78      /**
79       * Removes the last added serialized property
80       * 
81       */
82      public void removeSerializedProperty() {
83          pathElements.remove(pathElements.size() - 1);
84      }
85      
86      /**
87       * Retrieves the element name of the state element.  A parameter value of 0 represents the first element that was added
88       * by calling {@link #addSerializedProperty(String, PropertyType)} that hasn't been removed, and a value of 
89       * {@link #numPropertyElements()} - 1 represents the element last added that hasn't been removed. 
90       * 
91       * @param propertyIndex most be between 0 and the value returned by {@link #numPropertyElements()} - 1
92       * @return
93       */
94      public String getElementName(int propertyIndex) {
95          return pathElements.get(propertyIndex).getElementName();
96      }
97      
98      /**
99       * Retrieves the property type of the state element.  A parameter value of 0 represents the first element that was added
100      * by calling {@link #addSerializedProperty(String, PropertyType)} that hasn't been removed, and a value of 
101      * {@link #numPropertyElements()} - 1 represents the element last added that hasn't been removed.
102      * 
103      * @param propertyIndex most be between 0 and the value returned by {@link #numPropertyElements()} - 1
104      * @return
105      */
106     public PropertyType getPropertyType(int propertyIndex) {
107         return pathElements.get(propertyIndex).getPropertyType();
108     }
109 }