/**************************************************************************** ** ** Copyright (C) 2013 Sandro S. Andrade ** Contact: http://www.qt-project.org/legal ** ** This file is part of the QtUml module of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL$ ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and Digia. For licensing terms and ** conditions see http://qt.digia.com/licensing. For further information ** use the contact form at http://qt.digia.com/contact-us. ** ** GNU Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 2.1 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPL included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 2.1 requirements ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. ** ** In addition, as a special exception, Digia gives you certain additional ** rights. These rights are described in the Digia Qt LGPL Exception ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 3.0 as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL included in the ** packaging of this file. Please review the following information to ** ensure the GNU General Public License version 3.0 requirements will be ** met: http://www.gnu.org/copyleft/gpl.html. ** ** ** $QT_END_LICENSE$ ** ****************************************************************************/ #include "qumlnamedelement.h" #include #include #include #include #include QT_BEGIN_NAMESPACE /*! \class QUmlNamedElement \inmodule QtUml \brief A named element supports using a string expression to specify its name. This allows names of model elements to involve template parameters. The actual name is evaluated from the string expression only when it is sensible to do so (e.g., when a template is bound).A named element is an element in a model that may have a name. \b {QUmlNamedElement is an abstract class.} */ /*! Creates a new QUmlNamedElement. */ QUmlNamedElement::QUmlNamedElement() : _nameExpression(0), _namespace_(0), _visibility(QtUml::VisibilityKindNone) { } /*! Returns a deep-copied clone of the QUmlNamedElement. */ QModelingElement *QUmlNamedElement::clone() const { QUmlNamedElement *c = new QUmlNamedElement; foreach (QUmlComment *element, ownedComments()) c->addOwnedComment(dynamic_cast(element->clone())); foreach (QUmlDependency *element, clientDependencies()) c->addClientDependency(dynamic_cast(element->clone())); c->setName(name()); if (nameExpression()) c->setNameExpression(dynamic_cast(nameExpression()->clone())); c->setVisibility(visibility()); return c; } // OWNED ATTRIBUTES /*! Indicates the dependencies that reference the client. \sa addClientDependency(), removeClientDependency() \b {Subsetted property(ies):} . \b {Opposite property(ies):} QUmlDependency::clients(). */ const QSet QUmlNamedElement::clientDependencies() const { // This is a read-write association end return _clientDependencies; } /*! Adds \a clientDependency to clientDependencies. \sa clientDependencies(), removeClientDependency() */ void QUmlNamedElement::addClientDependency(QUmlDependency *clientDependency) { // This is a read-write association end if (!_clientDependencies.contains(clientDependency)) { _clientDependencies.insert(clientDependency); if (clientDependency && clientDependency->asQModelingObject() && this->asQModelingObject()) QObject::connect(clientDependency->asQModelingObject(), SIGNAL(destroyed(QObject*)), this->asQModelingObject(), SLOT(removeClientDependency(QObject *))); // Adjust opposite properties if (clientDependency) { clientDependency->addClient(this); } } } /*! Removes \a clientDependency from clientDependencies. \sa clientDependencies(), addClientDependency() */ void QUmlNamedElement::removeClientDependency(QUmlDependency *clientDependency) { // This is a read-write association end if (_clientDependencies.contains(clientDependency)) { _clientDependencies.remove(clientDependency); // Adjust opposite properties if (clientDependency) { clientDependency->removeClient(this); } } } /*! The name of the NamedElement. */ QString QUmlNamedElement::name() const { // This is a read-write property return _name; } /*! Adjusts name to \a name. */ void QUmlNamedElement::setName(QString name) { // This is a read-write property if (_name != name) { _name = name; asQModelingObject()->setObjectName(name); } } /*! The string expression used to define the name of this named element. \b {Subsetted property(ies):} QUmlElement::ownedElements(). */ QUmlStringExpression *QUmlNamedElement::nameExpression() const { // This is a read-write association end return _nameExpression; } /*! Adjusts nameExpression to \a nameExpression. */ void QUmlNamedElement::setNameExpression(QUmlStringExpression *nameExpression) { // This is a read-write association end if (_nameExpression != nameExpression) { // Adjust subsetted properties removeOwnedElement(_nameExpression); _nameExpression = nameExpression; if (nameExpression && nameExpression->asQModelingObject() && this->asQModelingObject()) QObject::connect(nameExpression->asQModelingObject(), SIGNAL(destroyed()), this->asQModelingObject(), SLOT(setNameExpression())); nameExpression->asQModelingObject()->setParent(this->asQModelingObject()); // Adjust subsetted properties if (nameExpression) { addOwnedElement(nameExpression); } } } /*! Specifies the namespace that owns the NamedElement. \b {This is a read-only derived union property.} \b {Subsetted property(ies):} QUmlElement::owner(). \b {Opposite property(ies):} QUmlNamespace::ownedMembers(). */ QUmlNamespace *QUmlNamedElement::namespace_() const { // This is a read-only derived union association end return _namespace_; } /*! Adjusts namespace_ to \a namespace_. */ void QUmlNamedElement::setNamespace(QUmlNamespace *namespace_) { // This is a read-only derived union association end if (_namespace_ != namespace_) { // Adjust subsetted properties _namespace_ = namespace_; if (namespace_ && namespace_->asQModelingObject() && this->asQModelingObject()) QObject::connect(namespace_->asQModelingObject(), SIGNAL(destroyed()), this->asQModelingObject(), SLOT(setNamespace())); // Adjust subsetted properties setOwner(namespace_); } } /*! A name which allows the NamedElement to be identified within a hierarchy of nested Namespaces. It is constructed from the names of the containing namespaces starting at the root of the hierarchy and ending with the name of the NamedElement itself. \b {This is a read-only derived property.} */ QString QUmlNamedElement::qualifiedName() const { // This is a read-only derived property if (_name.isEmpty()) return QString(); QString qualifiedName_(_name); QList allNamespaces_ = allNamespaces(); QString separator_ = separator(); foreach (QUmlNamespace *namespace_, allNamespaces_) { if (namespace_->name().isEmpty()) return QString(); qualifiedName_.prepend(separator_).prepend(namespace_->name()); } return qualifiedName_; } /*! Adjusts qualifiedName to \a qualifiedName. */ void QUmlNamedElement::setQualifiedName(QString qualifiedName) { // This is a read-only derived property qWarning("QUmlNamedElement::setQualifiedName(): to be implemented (this is a derived property)"); Q_UNUSED(qualifiedName); if (false /* */) { // } } /*! Determines where the NamedElement appears within different Namespaces within the overall model, and its accessibility. */ QtUml::VisibilityKind QUmlNamedElement::visibility() const { // This is a read-write property return _visibility; } /*! Adjusts visibility to \a visibility. */ void QUmlNamedElement::setVisibility(QtUml::VisibilityKind visibility) { // This is a read-write property if (_visibility != visibility) { _visibility = visibility; } } // OPERATIONS /*! The query allNamespaces() gives the sequence of namespaces in which the NamedElement is nested, working outwards. */ QList QUmlNamedElement::allNamespaces() const { if (!_namespace_) { return QList(); } else { QList allNamespaces_; QUmlNamespace *namespace_ = this->namespace_(); while (namespace_) { allNamespaces_.append(namespace_); namespace_ = namespace_->namespace_(); } return allNamespaces_; } } /*! The query allOwningPackages() returns all the directly or indirectly owning packages. */ QSet QUmlNamedElement::allOwningPackages() const { qWarning("QUmlNamedElement::allOwningPackages(): to be implemented (operation)"); return QSet (); } /*! The query isDistinguishableFrom() determines whether two NamedElements may logically co-exist within a Namespace. By default, two named elements are distinguishable if (a) they have unrelated types or (b) they have related types but different names. */ bool QUmlNamedElement::isDistinguishableFrom(QUmlNamedElement *n, QUmlNamespace *ns) const { qWarning("QUmlNamedElement::isDistinguishableFrom(): to be implemented (operation)"); Q_UNUSED(n); Q_UNUSED(ns); return bool (); } /*! The query separator() gives the string that is used to separate names when constructing a qualified name. */ QString QUmlNamedElement::separator() const { return QStringLiteral("::"); } QT_END_NAMESPACE