summaryrefslogtreecommitdiff
path: root/src/net/sourceforge/plantuml/hector/SkeletonBuilder.java
diff options
context:
space:
mode:
authorAndrew Shadura <andrew@shadura.me>2015-07-21 14:52:03 +0200
committerAndrew Shadura <andrew@shadura.me>2015-07-21 14:52:03 +0200
commit26b872bb194ec7622997914bba53309a94b64d20 (patch)
treea79b966bf55dd61702b900b8ba40be4d2b3403db /src/net/sourceforge/plantuml/hector/SkeletonBuilder.java
Imported Upstream version 8024
Diffstat (limited to 'src/net/sourceforge/plantuml/hector/SkeletonBuilder.java')
-rw-r--r--src/net/sourceforge/plantuml/hector/SkeletonBuilder.java84
1 files changed, 84 insertions, 0 deletions
diff --git a/src/net/sourceforge/plantuml/hector/SkeletonBuilder.java b/src/net/sourceforge/plantuml/hector/SkeletonBuilder.java
new file mode 100644
index 0000000..e682eb5
--- /dev/null
+++ b/src/net/sourceforge/plantuml/hector/SkeletonBuilder.java
@@ -0,0 +1,84 @@
+/* ========================================================================
+ * PlantUML : a free UML diagram generator
+ * ========================================================================
+ *
+ * (C) Copyright 2009-2014, Arnaud Roques
+ *
+ * Project Info: http://plantuml.sourceforge.net
+ *
+ * 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.hector;
+
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.List;
+
+public class SkeletonBuilder {
+
+ private List<PinLinksContinuousSet> sets = new ArrayList<PinLinksContinuousSet>();
+
+ public void add(PinLink pinLink) {
+ addInternal(pinLink);
+ merge();
+
+ }
+
+ private void merge() {
+ for (int i = 0; i < sets.size() - 1; i++) {
+ for (int j = i + 1; j < sets.size(); j++) {
+ if (sets.get(i).doesTouch(sets.get(j))) {
+ sets.get(i).addAll(sets.get(j));
+ sets.remove(j);
+ return;
+ }
+ }
+ }
+ }
+
+ private void addInternal(PinLink pinLink) {
+ for (PinLinksContinuousSet set : sets) {
+ if (set.doesTouch(pinLink)) {
+ set.add(pinLink);
+ return;
+ }
+ }
+ final PinLinksContinuousSet newSet = new PinLinksContinuousSet();
+ newSet.add(pinLink);
+ sets.add(newSet);
+ }
+
+ public List<Skeleton> createSkeletons() {
+ final List<Skeleton> result = new ArrayList<Skeleton>();
+
+ for (PinLinksContinuousSet set : sets) {
+ result.add(set.createSkeleton());
+ }
+
+ return Collections.unmodifiableList(result);
+ }
+}