diff options
Diffstat (limited to 'src/uml/qumlduration.cpp')
-rw-r--r-- | src/uml/qumlduration.cpp | 18 |
1 files changed, 8 insertions, 10 deletions
diff --git a/src/uml/qumlduration.cpp b/src/uml/qumlduration.cpp index f44e7386..bcaa563b 100644 --- a/src/uml/qumlduration.cpp +++ b/src/uml/qumlduration.cpp @@ -75,6 +75,14 @@ QUmlDuration::QUmlDuration(bool createQModelingObject) : } /*! + Destroys the QUmlDuration. + */ +QUmlDuration::~QUmlDuration() +{ + QModelingElement::deleteQModelingObject(); +} + +/*! Returns a deep-copied clone of the QUmlDuration. */ QModelingElement *QUmlDuration::clone() const @@ -82,22 +90,12 @@ QModelingElement *QUmlDuration::clone() const QUmlDuration *c = new QUmlDuration; foreach (QUmlComment *element, ownedComments()) c->addOwnedComment(dynamic_cast<QUmlComment *>(element->clone())); - foreach (QUmlDependency *element, clientDependencies()) - c->addClientDependency(dynamic_cast<QUmlDependency *>(element->clone())); c->setName(name()); if (nameExpression()) c->setNameExpression(dynamic_cast<QUmlStringExpression *>(nameExpression()->clone())); - if (type()) - c->setType(dynamic_cast<QUmlType *>(type()->clone())); - if (owningTemplateParameter()) - c->setOwningTemplateParameter(dynamic_cast<QUmlTemplateParameter *>(owningTemplateParameter()->clone())); - if (templateParameter()) - c->setTemplateParameter(dynamic_cast<QUmlTemplateParameter *>(templateParameter()->clone())); c->setVisibility(visibility()); if (expr()) c->setExpr(dynamic_cast<QUmlValueSpecification *>(expr()->clone())); - foreach (QUmlObservation *element, observations()) - c->addObservation(dynamic_cast<QUmlObservation *>(element->clone())); return c; } |