summaryrefslogtreecommitdiff
path: root/src/net/sourceforge/plantuml/hector2/layering/Layer.java
diff options
context:
space:
mode:
authorChristopher Hoskin <mans0954@debian.org>2017-09-08 19:57:06 +0100
committerChristopher Hoskin <mans0954@debian.org>2017-09-08 19:57:06 +0100
commit277c886dbbaa9ac62798e87272c7ead5795033f8 (patch)
tree309f666741dddb2f914ab224d98b6ca32d8e228a /src/net/sourceforge/plantuml/hector2/layering/Layer.java
parentf9dab4abce6df0e9b5121895cc6e94823c2dece3 (diff)
New upstream version 1.2017.15
Diffstat (limited to 'src/net/sourceforge/plantuml/hector2/layering/Layer.java')
-rw-r--r--src/net/sourceforge/plantuml/hector2/layering/Layer.java233
1 files changed, 117 insertions, 116 deletions
diff --git a/src/net/sourceforge/plantuml/hector2/layering/Layer.java b/src/net/sourceforge/plantuml/hector2/layering/Layer.java
index 9185467..3402cce 100644
--- a/src/net/sourceforge/plantuml/hector2/layering/Layer.java
+++ b/src/net/sourceforge/plantuml/hector2/layering/Layer.java
@@ -1,116 +1,117 @@
-/* ========================================================================
- * PlantUML : a free UML diagram generator
- * ========================================================================
- *
- * (C) Copyright 2009-2017, Arnaud Roques
- *
- * Project Info: http://plantuml.com
- *
- * This file is part of PlantUML.
- *
- * Licensed under The MIT License (Massachusetts Institute of Technology License)
- *
- * See http://opensource.org/licenses/MIT
- *
- * Permission is hereby granted, free of charge, to any person obtaining
- * a copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included
- * in all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
- * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
- * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR
- * IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- *
- *
- * Original Author: Arnaud Roques
- */
-package net.sourceforge.plantuml.hector2.layering;
-
-import java.util.ArrayList;
-import java.util.Collection;
-import java.util.Collections;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-
-import net.sourceforge.plantuml.cucadiagram.IEntity;
-import net.sourceforge.plantuml.hector2.MinMax;
-import net.sourceforge.plantuml.hector2.mpos.MutationLayer;
-import net.sourceforge.plantuml.hector2.mpos.MutationLayerMove;
-
-public class Layer {
-
- private final int id;
- private final Map<IEntity, Integer> entities = new HashMap<IEntity, Integer>();
-
- public Layer(int id) {
- this.id = id;
- }
-
- public Layer duplicate() {
- final Layer result = new Layer(id);
- result.entities.putAll(this.entities);
- return result;
- }
-
- public List<MutationLayer> getPossibleMutations() {
- final List<MutationLayer> result = new ArrayList<MutationLayer>();
- for (Map.Entry<IEntity, Integer> ent : entities.entrySet()) {
- final IEntity entity = ent.getKey();
- final int longitude = ent.getValue();
- if (isLongitudeFree(longitude + 2)) {
- result.add(new MutationLayerMove(this, entity, longitude + 2));
- }
- if (isLongitudeFree(longitude - 2)) {
- result.add(new MutationLayerMove(this, entity, longitude - 2));
- }
- }
- return Collections.unmodifiableList(result);
- }
-
- private boolean isLongitudeFree(int longitude) {
- return entities.values().contains(longitude) == false;
- }
-
- public void put(IEntity ent, int longitude) {
- if (entities.containsKey(ent) == false) {
- throw new IllegalArgumentException();
- }
- this.entities.put(ent, longitude);
- }
-
- public void add(IEntity ent) {
- final int pos = entities.size() * 2;
- this.entities.put(ent, pos);
- }
-
- public Collection<IEntity> entities() {
- return Collections.unmodifiableCollection(entities.keySet());
- }
-
- public int getLongitude(IEntity ent) {
- return entities.get(ent);
- }
-
- public MinMax getMinMaxLongitudes() {
- return MinMax.from(entities.values());
- }
-
- @Override
- public String toString() {
- return "layer " + id + " " + entities;
- }
-
- public final int getId() {
- return id;
- }
-
-}
+/* ========================================================================
+ * PlantUML : a free UML diagram generator
+ * ========================================================================
+ *
+ * (C) Copyright 2009-2017, Arnaud Roques
+ *
+ * Project Info: http://plantuml.com
+ *
+ * If you like this project or if you find it useful, you can support us at:
+ *
+ * http://plantuml.com/patreon (only 1$ per month!)
+ * http://plantuml.com/paypal
+ *
+ * This file is part of PlantUML.
+ *
+ * PlantUML is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * PlantUML distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
+ * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
+ * License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+ * USA.
+ *
+ *
+ * Original Author: Arnaud Roques
+ *
+ *
+ */
+package net.sourceforge.plantuml.hector2.layering;
+
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import net.sourceforge.plantuml.cucadiagram.IEntity;
+import net.sourceforge.plantuml.hector2.MinMax;
+import net.sourceforge.plantuml.hector2.mpos.MutationLayer;
+import net.sourceforge.plantuml.hector2.mpos.MutationLayerMove;
+
+public class Layer {
+
+ private final int id;
+ private final Map<IEntity, Integer> entities = new HashMap<IEntity, Integer>();
+
+ public Layer(int id) {
+ this.id = id;
+ }
+
+ public Layer duplicate() {
+ final Layer result = new Layer(id);
+ result.entities.putAll(this.entities);
+ return result;
+ }
+
+ public List<MutationLayer> getPossibleMutations() {
+ final List<MutationLayer> result = new ArrayList<MutationLayer>();
+ for (Map.Entry<IEntity, Integer> ent : entities.entrySet()) {
+ final IEntity entity = ent.getKey();
+ final int longitude = ent.getValue();
+ if (isLongitudeFree(longitude + 2)) {
+ result.add(new MutationLayerMove(this, entity, longitude + 2));
+ }
+ if (isLongitudeFree(longitude - 2)) {
+ result.add(new MutationLayerMove(this, entity, longitude - 2));
+ }
+ }
+ return Collections.unmodifiableList(result);
+ }
+
+ private boolean isLongitudeFree(int longitude) {
+ return entities.values().contains(longitude) == false;
+ }
+
+ public void put(IEntity ent, int longitude) {
+ if (entities.containsKey(ent) == false) {
+ throw new IllegalArgumentException();
+ }
+ this.entities.put(ent, longitude);
+ }
+
+ public void add(IEntity ent) {
+ final int pos = entities.size() * 2;
+ this.entities.put(ent, pos);
+ }
+
+ public Collection<IEntity> entities() {
+ return Collections.unmodifiableCollection(entities.keySet());
+ }
+
+ public int getLongitude(IEntity ent) {
+ return entities.get(ent);
+ }
+
+ public MinMax getMinMaxLongitudes() {
+ return MinMax.from(entities.values());
+ }
+
+ @Override
+ public String toString() {
+ return "layer " + id + " " + entities;
+ }
+
+ public final int getId() {
+ return id;
+ }
+
+}