net.sourceforge.plantuml.sequencediagram.AbstractMessage Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of plantuml-gplv2 Show documentation
Show all versions of plantuml-gplv2 Show documentation
PlantUML is a component that allows to quickly write diagrams from text.
// THIS FILE HAS BEEN GENERATED BY A PREPROCESSOR.
/* +=======================================================================
* |
* | PlantUML : a free UML diagram generator
* |
* +=======================================================================
*
* (C) Copyright 2009-2024, Arnaud Roques
*
* Project Info: https://plantuml.com
*
* If you like this project or if you find it useful, you can support us at:
*
* https://plantuml.com/patreon (only 1$ per month!)
* https://plantuml.com/liberapay (only 1€ per month!)
* https://plantuml.com/paypal
*
*
* PlantUML is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License V2.
*
* THE ACCOMPANYING PROGRAM IS PROVIDED UNDER THE TERMS OF THIS ECLIPSE PUBLIC
* LICENSE ("AGREEMENT"). [GNU General Public License V2]
*
* ANY USE, REPRODUCTION OR DISTRIBUTION OF THE PROGRAM CONSTITUTES
* RECIPIENT'S ACCEPTANCE OF THIS AGREEMENT.
*
* You may obtain a copy of the License at
*
* https://www.gnu.org/licenses/old-licenses/gpl-2.0.html
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* PlantUML can occasionally display sponsored or advertising messages. Those
* messages are usually generated on welcome or error images and never on
* functional diagrams.
* See https://plantuml.com/professional if you want to remove them
*
* Images (whatever their format : PNG, SVG, EPS...) generated by running PlantUML
* are owned by the author of their corresponding sources code (that is, their
* textual description in PlantUML language). Those images are not covered by
* this GPL v2 license.
*
* The generated images can then be used without any reference to the GPL v2 license.
* It is not even necessary to stipulate that they have been generated with PlantUML,
* although this will be appreciated by the PlantUML team.
*
* There is an exception : if the textual description in PlantUML language is also covered
* by any license, then the generated images are logically covered
* by the very same license.
*
* This is the IGY distribution (Install GraphViz by Yourself).
* You have to install GraphViz and to setup the GRAPHVIZ_DOT environment variable
* (see https://plantuml.com/graphviz-dot )
*
* Icons provided by OpenIconic : https://useiconic.com/open
* Archimate sprites provided by Archi : http://www.archimatetool.com
* Stdlib AWS provided by https://github.com/milo-minderbinder/AWS-PlantUML
* Stdlib Icons provided https://github.com/tupadr3/plantuml-icon-font-sprites
* ASCIIMathML (c) Peter Jipsen http://www.chapman.edu/~jipsen
* ASCIIMathML (c) David Lippman http://www.pierce.ctc.edu/dlippman
* CafeUndZopfli ported by Eugene Klyuchnikov https://github.com/eustas/CafeUndZopfli
* Brotli (c) by the Brotli Authors https://github.com/google/brotli
* Themes (c) by Brett Schwarz https://github.com/bschwarz/puml-themes
* Twemoji (c) by Twitter at https://twemoji.twitter.com/
*
*/
package net.sourceforge.plantuml.sequencediagram;
import java.util.ArrayList;
import java.util.EnumSet;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import net.sourceforge.plantuml.klimt.creole.Display;
import net.sourceforge.plantuml.skin.ArrowConfiguration;
import net.sourceforge.plantuml.stereo.Stereotype;
import net.sourceforge.plantuml.style.PName;
import net.sourceforge.plantuml.style.SName;
import net.sourceforge.plantuml.style.Style;
import net.sourceforge.plantuml.style.StyleBuilder;
import net.sourceforge.plantuml.style.StyleSignature;
import net.sourceforge.plantuml.style.StyleSignatureBasic;
import net.sourceforge.plantuml.style.WithStyle;
import net.sourceforge.plantuml.url.Url;
public abstract class AbstractMessage extends AbstractEvent implements EventWithDeactivate, WithStyle, EventWithNote {
private Stereotype stereotype;
public void getStereotype(Stereotype stereotype) {
this.stereotype = stereotype;
}
final public Style[] getUsedStyles() {
Style style = getStyleSignature().getMergedStyle(styleBuilder);
if (style != null && arrowConfiguration.getColor() != null)
style = style.eventuallyOverride(PName.LineColor, arrowConfiguration.getColor());
return new Style[] { style };
}
public StyleSignature getStyleSignature() {
return StyleSignatureBasic.of(SName.root, SName.element, SName.sequenceDiagram, SName.arrow)
.withTOBECHANGED(stereotype);
}
private final Display label;
private final ArrowConfiguration arrowConfiguration;
private final Set lifeEventsType = EnumSet.noneOf(LifeEventType.class);
private Url url;
private final String messageNumber;
private boolean parallel = false;
private AbstractMessage parallelBrother;
private final StyleBuilder styleBuilder;
private List noteOnMessages = new ArrayList<>();
public AbstractMessage(StyleBuilder styleBuilder, Display label, ArrowConfiguration arrowConfiguration,
String messageNumber) {
this.styleBuilder = styleBuilder;
this.url = null;
this.label = label;
this.arrowConfiguration = arrowConfiguration;
this.messageNumber = messageNumber;
}
public final void setUrl(Url url) {
this.url = url;
}
public void goParallel() {
this.parallel = true;
}
public void setParallelBrother(AbstractMessage brother) {
this.parallelBrother = brother;
}
public boolean isParallel() {
return parallel;
}
public boolean isParallelWith(AbstractMessage message) {
boolean hasParallelBrother = parallelBrother != null;
return (this == message)
|| (hasParallelBrother && parallelBrother == message)
|| (hasParallelBrother && parallelBrother.isParallelWith(message));
}
final public Url getUrl() {
if (url == null)
for (Note n : noteOnMessages)
if (n.getUrl() != null)
return n.getUrl();
return url;
}
public boolean hasUrl() {
for (Note n : noteOnMessages)
if (n.hasUrl())
return true;
if (label != null && label.hasUrl())
return true;
return getUrl() != null;
}
private boolean firstIsActivate = false;
private final Set noActivationAuthorized2 = new HashSet<>();
public final boolean addLifeEvent(LifeEvent lifeEvent) {
lifeEvent.setMessage(this);
if (this.isSelfMessage()) {
if (lifeEvent.getParticipant() != this.getParticipant1())
return true;
}
lifeEventsType.add(lifeEvent.getType());
if (lifeEventsType.size() == 1 && isActivate())
firstIsActivate = true;
if (lifeEvent.getType() == LifeEventType.ACTIVATE
&& noActivationAuthorized2.contains(lifeEvent.getParticipant()))
return false;
if (lifeEvent.getType() == LifeEventType.DEACTIVATE || lifeEvent.getType() == LifeEventType.DESTROY)
noActivationAuthorized2.add(lifeEvent.getParticipant());
return true;
}
public final boolean isCreate() {
return lifeEventsType.contains(LifeEventType.CREATE);
}
@Deprecated
public boolean isActivate() {
return lifeEventsType.contains(LifeEventType.ACTIVATE);
}
@Deprecated
public boolean isDeactivate() {
return lifeEventsType.contains(LifeEventType.DEACTIVATE);
}
public boolean isDestroy() {
return lifeEventsType.contains(LifeEventType.DESTROY);
}
@Deprecated
private boolean isDeactivateOrDestroy() {
return isDeactivate() || isDestroy();
}
public final boolean isActivateAndDeactive() {
return firstIsActivate && isDeactivateOrDestroy();
}
public final Display getLabel() {
return label;
}
public final Display getLabelNumbered() {
if (getMessageNumber() == null)
return getLabel();
Display result = Display.empty();
result = result.add(new MessageNumber(getMessageNumber()));
result = result.addAll(getLabel());
return result;
}
public final ArrowConfiguration getArrowConfiguration() {
return arrowConfiguration;
}
public final List getNoteOnMessages() {
return noteOnMessages;
}
@Override
public final void addNote(Note note) {
if (note.getPosition() != NotePosition.LEFT && note.getPosition() != NotePosition.RIGHT
&& note.getPosition() != NotePosition.BOTTOM && note.getPosition() != NotePosition.TOP)
throw new IllegalArgumentException();
note = note.withPosition(overrideNotePosition(note.getPosition()));
this.noteOnMessages.add(note);
}
protected NotePosition overrideNotePosition(NotePosition notePosition) {
return notePosition;
}
public final String getMessageNumber() {
return messageNumber;
}
public abstract boolean compatibleForCreate(Participant p);
public abstract boolean isSelfMessage();
private double posYendLevel;
private double posYstartLevel;
public double getPosYstartLevel() {
return posYstartLevel;
}
public void setPosYstartLevel(double posYstartLevel) {
this.posYstartLevel = posYstartLevel;
}
public void setPosYendLevel(double posYendLevel) {
this.posYendLevel = posYendLevel;
}
public double getPosYendLevel() {
return posYendLevel;
}
private String anchor;
private String anchor1;
private String anchor2;
public void setAnchor(String anchor) {
this.anchor = anchor;
if (anchor != null && anchor.startsWith("{"))
throw new IllegalArgumentException(anchor);
}
public void setPart1Anchor(String anchor) {
this.anchor1 = anchor;
}
public void setPart2Anchor(String anchor) {
this.anchor2 = anchor;
}
public String getAnchor() {
return anchor;
}
public String getPart1Anchor() {
return this.anchor1;
}
public String getPart2Anchor() {
return this.anchor2;
}
public abstract Participant getParticipant1();
public abstract Participant getParticipant2();
}