001 /* This file is part of the project "Hilbert II" - http://www.qedeq.org
002 *
003 * Copyright 2000-2013, Michael Meyling <mime@qedeq.org>.
004 *
005 * "Hilbert II" is free software; you can redistribute
006 * it and/or modify it under the terms of the GNU General Public
007 * License as published by the Free Software Foundation; either
008 * version 2 of the License, or (at your option) any later version.
009 *
010 * This program is distributed in the hope that it will be useful,
011 * but WITHOUT ANY WARRANTY; without even the implied warranty of
012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
013 * GNU General Public License for more details.
014 */
015
016 package org.qedeq.kernel.se.dto.module;
017
018 import org.apache.commons.lang.ArrayUtils;
019 import org.qedeq.base.utility.EqualsUtility;
020 import org.qedeq.kernel.se.base.list.Element;
021 import org.qedeq.kernel.se.base.module.Rename;
022
023
024 /**
025 * Usage of rule for rename bound subject variable.
026 *
027 * @author Michael Meyling
028 */
029 public class RenameVo implements Rename {
030
031 /** Reference to previously proven formula. */
032 private String reference;
033
034 /** Bound subject variable that will be replaced. */
035 private Element originalSubjectVariable;
036
037 /** Replacement subject variable. */
038 private Element replacementSubjectVariable;
039
040 /** This bound occurrence should be replaced. If this value is 0, the replacement position
041 * is not specified. */
042 private int occurrence;
043
044 /**
045 * Constructs an addition argument.
046 *
047 * @param reference Reference to a valid formula.
048 * @param originalSubjectVariable Bound subject variable that will be replaced.
049 * @param replacementSubjectVariable Replacement subject variable.
050 * @param occurrence This bound occurrence should be replaced. If this
051 * value is 0, the replacement position
052 * is not specified. */
053
054 public RenameVo(final String reference, final Element originalSubjectVariable,
055 final Element replacementSubjectVariable, final int occurrence) {
056 this.reference = reference;
057 this.originalSubjectVariable = originalSubjectVariable;
058 this.replacementSubjectVariable = replacementSubjectVariable;
059 this.occurrence = occurrence;
060 }
061
062 /**
063 * Default constructor.
064 */
065 public RenameVo() {
066 // nothing to do
067 }
068
069 public Rename getRename() {
070 return this;
071 }
072
073 public String getReference() {
074 return reference;
075 }
076
077 /**
078 * Set formula reference.
079 *
080 * @param reference Reference to formula.
081 */
082 public void setReference(final String reference) {
083 this.reference = reference;
084 }
085
086 public String[] getReferences() {
087 if (reference == null) {
088 return ArrayUtils.EMPTY_STRING_ARRAY;
089 }
090 return new String[] {reference };
091 }
092
093 public int getOccurrence() {
094 return occurrence;
095 }
096
097 /**
098 * Set occurrence of bound subject variable that should be renamed.
099 *
100 * @param occurrence This occurrence should be renamed.
101 */
102 public void setOccurrence(final int occurrence) {
103 this.occurrence = occurrence;
104 }
105
106 public Element getOriginalSubjectVariable() {
107 return originalSubjectVariable;
108 }
109
110 /**
111 * Set original subject variable, which will be replaced.
112 *
113 * @param originalSubjectVariable Subject variable.
114 */
115 public void setOriginalSubjectVariable(final Element originalSubjectVariable) {
116 this.originalSubjectVariable = originalSubjectVariable;
117 }
118
119 public Element getReplacementSubjectVariable() {
120 return replacementSubjectVariable;
121 }
122
123 /**
124 * Set new subject variable subject variable.
125 *
126 * @param replacementSubjectVariable New subject variable.
127 */
128 public void setReplacementSubjectVariable(final Element replacementSubjectVariable) {
129 this.replacementSubjectVariable = replacementSubjectVariable;
130 }
131
132 public String getName() {
133 return "Rename";
134 }
135
136 public boolean equals(final Object obj) {
137 if (!(obj instanceof RenameVo)) {
138 return false;
139 }
140 final RenameVo other = (RenameVo) obj;
141 return EqualsUtility.equals(reference, other.reference)
142 && EqualsUtility.equals(originalSubjectVariable, other.originalSubjectVariable)
143 && EqualsUtility.equals(replacementSubjectVariable, other.replacementSubjectVariable)
144 && (occurrence == other.occurrence);
145 }
146
147 public int hashCode() {
148 return (reference != null ? reference.hashCode() : 0)
149 ^ (originalSubjectVariable != null ? 2 ^ originalSubjectVariable.hashCode() : 0)
150 ^ (replacementSubjectVariable != null ? 3 ^ replacementSubjectVariable.hashCode() : 0)
151 ^ (4 ^ occurrence);
152 }
153
154 public String toString() {
155 StringBuffer result = new StringBuffer();
156 result.append(getName());
157 if (reference != null || originalSubjectVariable != null
158 || replacementSubjectVariable != null
159 || occurrence != 0) {
160 result.append(" (");
161 boolean w = false;
162 if (reference != null) {
163 result.append(reference);
164 w = true;
165 }
166 if (originalSubjectVariable != null) {
167 if (w) {
168 result.append(", ");
169 }
170 result.append(originalSubjectVariable);
171 w = true;
172 }
173 if (replacementSubjectVariable != null) {
174 if (w) {
175 result.append(", ");
176 }
177 result.append("by ");
178 result.append(replacementSubjectVariable);
179 w = true;
180 }
181 if (occurrence != 0) {
182 if (w) {
183 result.append(", ");
184 }
185 result.append("occurrence: ");
186 result.append(occurrence);
187 w = true;
188 }
189 result.append(")");
190 }
191 return result.toString();
192 }
193
194 }
|