]> SALOME platform Git repositories - modules/shaper.git/blobdiff - src/XGUI/XGUI_DocumentDataModel.cpp
Salome HOME
Sources formated according to the codeing standards
[modules/shaper.git] / src / XGUI / XGUI_DocumentDataModel.cpp
index 6082e445bb56df332252a752caa11c14477e13dd..17dfe99b9a58375909ba875c4f7162583c0f4657 100644 (file)
@@ -25,7 +25,8 @@
 #define PASSIVE_COLOR Qt::black
 
 XGUI_DocumentDataModel::XGUI_DocumentDataModel(QObject* theParent)
-  : QAbstractItemModel(theParent), myActivePart(0)
+    : QAbstractItemModel(theParent),
+      myActivePart(0)
 {
   // Register in event loop
   Events_Loop::loop()->registerListener(this, Events_Loop::eventByName(EVENT_OBJECT_CREATED));
@@ -37,20 +38,19 @@ XGUI_DocumentDataModel::XGUI_DocumentDataModel(QObject* theParent)
   myModel->setItemsColor(ACTIVE_COLOR);
 }
 
-
 XGUI_DocumentDataModel::~XGUI_DocumentDataModel()
 {
   clearModelIndexes();
 }
 
-
 void XGUI_DocumentDataModel::processEvent(const Events_Message* theMessage)
 {
   DocumentPtr aRootDoc = ModelAPI_PluginManager::get()->rootDocument();
 
   // Created object event *******************
   if (theMessage->eventID() == Events_Loop::loop()->eventByName(EVENT_OBJECT_CREATED)) {
-    const ModelAPI_ObjectUpdatedMessage* aUpdMsg = dynamic_cast<const ModelAPI_ObjectUpdatedMessage*>(theMessage);
+    const ModelAPI_ObjectUpdatedMessage* aUpdMsg =
+        dynamic_cast<const ModelAPI_ObjectUpdatedMessage*>(theMessage);
     std::set<ObjectPtr> aObjects = aUpdMsg->objects();
 
     std::set<ObjectPtr>::const_iterator aIt;
@@ -62,21 +62,22 @@ void XGUI_DocumentDataModel::processEvent(const Events_Message* theMessage)
 
       DocumentPtr aDoc = aObject->document();
       if (aDoc == aRootDoc) {  // If root objects
-        if (aObject->groupName() == ModelAPI_ResultPart::group()) { // Update only Parts group
-          // Add a new part
+        if (aObject->groupName() == ModelAPI_ResultPart::group()) {  // Update only Parts group
+            // Add a new part
           int aStart = myPartModels.size();
           XGUI_PartDataModel* aModel = new XGUI_PartDataModel(this);
           aModel->setPartId(myPartModels.count());
           myPartModels.append(aModel);
           insertRow(aStart, partFolderNode());
-        } else { // Update top groups (other except parts
+        } else {  // Update top groups (other except parts
           QModelIndex aIndex = myModel->findParent(aObject);
           int aStart = myModel->rowCount(aIndex) - 1;
-          if (aStart < 0) aStart = 0;
-          aIndex = createIndex(aIndex.row(), aIndex.column(), (void*)getModelIndex(aIndex));
+          if (aStart < 0)
+            aStart = 0;
+          aIndex = createIndex(aIndex.row(), aIndex.column(), (void*) getModelIndex(aIndex));
           insertRow(aStart, aIndex);
         }
-      } else { // if sub-objects of first level nodes
+      } else {  // if sub-objects of first level nodes
         XGUI_PartModel* aPartModel = 0;
         QList<XGUI_PartModel*>::const_iterator aIt;
         for (aIt = myPartModels.constBegin(); aIt != myPartModels.constEnd(); ++aIt) {
@@ -87,15 +88,16 @@ void XGUI_DocumentDataModel::processEvent(const Events_Message* theMessage)
         }
         if (aPartModel) {
           QModelIndex aIndex = aPartModel->findParent(aObject);
-          int aStart = aPartModel->rowCount(aIndex); // check this index
-          aIndex = createIndex(aIndex.row(), aIndex.column(), (void*)getModelIndex(aIndex));
+          int aStart = aPartModel->rowCount(aIndex);  // check this index
+          aIndex = createIndex(aIndex.row(), aIndex.column(), (void*) getModelIndex(aIndex));
           insertRow(aStart, aIndex);
         }
       }
     }
-  // Deleted object event ***********************
+    // Deleted object event ***********************
   } else if (theMessage->eventID() == Events_Loop::loop()->eventByName(EVENT_OBJECT_DELETED)) {
-    const ModelAPI_ObjectDeletedMessage* aUpdMsg = dynamic_cast<const ModelAPI_ObjectDeletedMessage*>(theMessage);
+    const ModelAPI_ObjectDeletedMessage* aUpdMsg =
+        dynamic_cast<const ModelAPI_ObjectDeletedMessage*>(theMessage);
     DocumentPtr aDoc = aUpdMsg->document();
     std::set<std::string> aGroups = aUpdMsg->groups();
 
@@ -103,7 +105,7 @@ void XGUI_DocumentDataModel::processEvent(const Events_Message* theMessage)
     for (aIt = aGroups.begin(); aIt != aGroups.end(); ++aIt) {
       std::string aGroup = (*aIt);
       if (aDoc == aRootDoc) {  // If root objects
-        if (aGroup == ModelAPI_ResultPart::group()) { // Update only Parts group
+        if (aGroup == ModelAPI_ResultPart::group()) {  // Update only Parts group
           int aStart = myPartModels.size() - 1;
           removeSubModel(aStart);
           removeRow(aStart, partFolderNode());
@@ -112,10 +114,10 @@ void XGUI_DocumentDataModel::processEvent(const Events_Message* theMessage)
             myActivePartIndex = QModelIndex();
             myModel->setItemsColor(ACTIVE_COLOR);
           }
-        } else { // Update top groups (other except parts
+        } else {  // Update top groups (other except parts
           QModelIndex aIndex = myModel->findGroup(aGroup);
           int aStart = myModel->rowCount(aIndex);
-          aIndex = createIndex(aIndex.row(), aIndex.column(), (void*)getModelIndex(aIndex));
+          aIndex = createIndex(aIndex.row(), aIndex.column(), (void*) getModelIndex(aIndex));
           removeRow(aStart, aIndex);
         }
       } else {
@@ -130,23 +132,23 @@ void XGUI_DocumentDataModel::processEvent(const Events_Message* theMessage)
         if (aPartModel) {
           QModelIndex aIndex = aPartModel->findGroup(aGroup);
           int aStart = aPartModel->rowCount(aIndex);
-          aIndex = createIndex(aIndex.row(), aIndex.column(), (void*)getModelIndex(aIndex));
+          aIndex = createIndex(aIndex.row(), aIndex.column(), (void*) getModelIndex(aIndex));
           removeRow(aStart, aIndex);
         }
       }
     }
-  // Deleted object event ***********************
+    // Deleted object event ***********************
   } else if (theMessage->eventID() == Events_Loop::loop()->eventByName(EVENT_OBJECT_UPDATED)) {
     //const ModelAPI_ObjectUpdatedMessage* aUpdMsg = dynamic_cast<const ModelAPI_ObjectUpdatedMessage*>(theMessage);
     //ObjectPtr aFeature = aUpdMsg->feature();
     //DocumentPtr aDoc = aFeature->document();
-    
+
     // TODO: Identify the necessary index by the modified feature
     QModelIndex aIndex;
     emit dataChanged(aIndex, aIndex);
 
-  // Reset whole tree **************************
-  } else {  
+    // Reset whole tree **************************
+  } else {
     rebuildDataTree();
   }
 }
@@ -159,7 +161,7 @@ void XGUI_DocumentDataModel::rebuildDataTree()
   clearModelIndexes();
 
   int aNbParts = aRootDoc->size(ModelAPI_ResultPart::group());
-  if (myPartModels.size() != aNbParts) { // resize internal models
+  if (myPartModels.size() != aNbParts) {  // resize internal models
     while (myPartModels.size() > aNbParts) {
       delete myPartModels.last();
       myPartModels.removeLast();
@@ -178,52 +180,52 @@ QVariant XGUI_DocumentDataModel::data(const QModelIndex& theIndex, int theRole)
   if (!theIndex.isValid())
     return QVariant();
   switch (theIndex.internalId()) {
-  case PartsFolder:
-    switch (theRole) {
-    case Qt::DisplayRole:
-      return tr("Parts") + QString(" (%1)").arg(rowCount(theIndex));
-    case Qt::DecorationRole:
-      return QIcon(":pictures/constr_folder.png");
-    case Qt::ToolTipRole:
-      return tr("Parts folder");
-    case Qt::ForegroundRole:
-      if (myActivePart)
-        return QBrush(PASSIVE_COLOR);
-      else
-        return QBrush(ACTIVE_COLOR);
-    default:
-      return QVariant();
-    }
-    break;
-  case HistoryNode:
-    {
-      int aOffset = historyOffset();
-      DocumentPtr aRootDoc = ModelAPI_PluginManager::get()->rootDocument();
-      ObjectPtr aObj = aRootDoc->object(ModelAPI_Feature::group(), theIndex.row() - aOffset);
-      FeaturePtr aFeature = boost::dynamic_pointer_cast<ModelAPI_Feature>(aObj);
-      if (!aFeature)
-        return QVariant();
+    case PartsFolder:
       switch (theRole) {
-      case Qt::DisplayRole:
-        if (aFeature)
-          return aFeature->data()->name().c_str();
-        else 
-          return QVariant();
-      case Qt::DecorationRole:
-        return QIcon(XGUI_Workshop::featureIcon(aFeature->getKind()));
-      case Qt::ToolTipRole:
-        return tr("Feature object");
-      case Qt::ForegroundRole:
-        if (myActivePart)
-          return QBrush(PASSIVE_COLOR);
-        else
-          return QBrush(ACTIVE_COLOR);
-      default:
-        return QVariant();
-      }
-    }
-    break;
-  }
+        case Qt::DisplayRole:
+          return tr("Parts") + QString(" (%1)").arg(rowCount(theIndex));
+        case Qt::DecorationRole:
+          return QIcon(":pictures/constr_folder.png");
+        case Qt::ToolTipRole:
+          return tr("Parts folder");
+        case Qt::ForegroundRole:
+          if (myActivePart)
+            return QBrush(PASSIVE_COLOR);
+            else
+            return QBrush(ACTIVE_COLOR);
+            default:
+            return QVariant();
+          }
+          break;
+          case HistoryNode:
+          {
+            int aOffset = historyOffset();
+            DocumentPtr aRootDoc = ModelAPI_PluginManager::get()->rootDocument();
+            ObjectPtr aObj = aRootDoc->object(ModelAPI_Feature::group(), theIndex.row() - aOffset);
+            FeaturePtr aFeature = boost::dynamic_pointer_cast<ModelAPI_Feature>(aObj);
+            if (!aFeature)
+            return QVariant();
+            switch (theRole) {
+              case Qt::DisplayRole:
+              if (aFeature)
+              return aFeature->data()->name().c_str();
+              else
+              return QVariant();
+              case Qt::DecorationRole:
+              return QIcon(XGUI_Workshop::featureIcon(aFeature->getKind()));
+              case Qt::ToolTipRole:
+              return tr("Feature object");
+              case Qt::ForegroundRole:
+              if (myActivePart)
+              return QBrush(PASSIVE_COLOR);
+              else
+              return QBrush(ACTIVE_COLOR);
+              default:
+              return QVariant();
+            }
+          }
+          break;
+        }
   QModelIndex aParent = theIndex.parent();
   if (aParent.isValid() && (aParent.internalId() == PartsFolder)) {
     return myPartModels.at(theIndex.row())->data(QModelIndex(), theRole);
@@ -231,8 +233,8 @@ QVariant XGUI_DocumentDataModel::data(const QModelIndex& theIndex, int theRole)
   return toSourceModelIndex(theIndex)->data(theRole);
 }
 
-
-QVariant XGUI_DocumentDataModel::headerData(int theSection, Qt::Orientation theOrient, int theRole) const
+QVariant XGUI_DocumentDataModel::headerData(int theSection, Qt::Orientation theOrient,
+                                            int theRole) const
 {
   return QVariant();
 }
@@ -256,13 +258,13 @@ int XGUI_DocumentDataModel::rowCount(const QModelIndex& theParent) const
   }
   QModelIndex* aParent = toSourceModelIndex(theParent);
   const QAbstractItemModel* aModel = aParent->model();
-  if (!isSubModel(aModel)) 
+  if (!isSubModel(aModel))
     return 0;
 
   /*if (isPartSubModel(aModel)) {
-    if (aModel != myActivePart)
-      return 0;
-  }*/
+   if (aModel != myActivePart)
+   return 0;
+   }*/
   return aModel->rowCount(*aParent);
 }
 
@@ -271,33 +273,34 @@ int XGUI_DocumentDataModel::columnCount(const QModelIndex& theParent) const
   return 1;
 }
 
-QModelIndex XGUI_DocumentDataModel::index(int theRow, int theColumn, const QModelIndex& theParent) const
+QModelIndex XGUI_DocumentDataModel::index(int theRow, int theColumn,
+                                          const QModelIndex& theParent) const
 {
   QModelIndex aIndex;
   if (!theParent.isValid()) {
     int aOffs = myModel->rowCount();
     if (theRow < aOffs) {
       aIndex = myModel->index(theRow, theColumn, theParent);
-      aIndex = createIndex(theRow, theColumn, (void*)getModelIndex(aIndex));
+      aIndex = createIndex(theRow, theColumn, (void*) getModelIndex(aIndex));
     } else {
       if (theRow == aOffs)  // Create Parts node
         aIndex = partFolderNode();
-      else // create history node
+      else
+        // create history node
         aIndex = createIndex(theRow, theColumn, HistoryNode);
     }
   } else {
     if (theParent.internalId() == PartsFolder) {
       aIndex = myPartModels.at(theRow)->index(0, theColumn, QModelIndex());
     } else {
-      QModelIndex* aParent = (QModelIndex*)theParent.internalPointer();
+      QModelIndex* aParent = (QModelIndex*) theParent.internalPointer();
       aIndex = aParent->model()->index(theRow, theColumn, (*aParent));
     }
-    aIndex = createIndex(theRow, theColumn, (void*)getModelIndex(aIndex));
+    aIndex = createIndex(theRow, theColumn, (void*) getModelIndex(aIndex));
   }
   return aIndex;
 }
 
-
 QModelIndex XGUI_DocumentDataModel::parent(const QModelIndex& theIndex) const
 {
   if ((theIndex.internalId() == PartsFolder) || (theIndex.internalId() == HistoryNode))
@@ -305,7 +308,7 @@ QModelIndex XGUI_DocumentDataModel::parent(const QModelIndex& theIndex) const
 
   QModelIndex* aIndex = toSourceModelIndex(theIndex);
   const QAbstractItemModel* aModel = aIndex->model();
-  if (!isSubModel(aModel)) 
+  if (!isSubModel(aModel))
     return QModelIndex();
 
   if (isPartSubModel(aModel)) {
@@ -316,11 +319,10 @@ QModelIndex XGUI_DocumentDataModel::parent(const QModelIndex& theIndex) const
 
   QModelIndex aIndex1 = aModel->parent(*aIndex);
   if (aIndex1.isValid())
-    return createIndex(aIndex1.row(), aIndex1.column(), (void*)getModelIndex(aIndex1));
+    return createIndex(aIndex1.row(), aIndex1.column(), (void*) getModelIndex(aIndex1));
   return aIndex1;
 }
 
-
 bool XGUI_DocumentDataModel::hasChildren(const QModelIndex& theParent) const
 {
   if (!theParent.isValid())
@@ -328,14 +330,12 @@ bool XGUI_DocumentDataModel::hasChildren(const QModelIndex& theParent) const
   return rowCount(theParent) > 0;
 }
 
-
 QModelIndex* XGUI_DocumentDataModel::toSourceModelIndex(const QModelIndex& theProxy) const
 {
   QModelIndex* aIndexPtr = static_cast<QModelIndex*>(theProxy.internalPointer());
   return aIndexPtr;
 }
 
-
 QModelIndex* XGUI_DocumentDataModel::findModelIndex(const QModelIndex& theIndex) const
 {
   QList<QModelIndex*>::const_iterator aIt;
@@ -361,7 +361,7 @@ QModelIndex* XGUI_DocumentDataModel::getModelIndex(const QModelIndex& theIndex)
 void XGUI_DocumentDataModel::clearModelIndexes()
 {
   QList<QModelIndex*>::const_iterator aIt;
-  for (aIt = myIndexes.constBegin(); aIt != myIndexes.constEnd(); ++aIt) 
+  for (aIt = myIndexes.constBegin(); aIt != myIndexes.constEnd(); ++aIt)
     delete (*aIt);
   myIndexes.clear();
 }
@@ -376,7 +376,7 @@ ObjectPtr XGUI_DocumentDataModel::object(const QModelIndex& theIndex) const
     return aRootDoc->object(ModelAPI_Feature::group(), theIndex.row() - aOffset);
   }
   QModelIndex* aIndex = toSourceModelIndex(theIndex);
-  if (!isSubModel(aIndex->model())) 
+  if (!isSubModel(aIndex->model()))
     return ObjectPtr();
 
   const XGUI_FeaturesModel* aModel = dynamic_cast<const XGUI_FeaturesModel*>(aIndex->model());
@@ -404,7 +404,6 @@ bool XGUI_DocumentDataModel::removeRows(int theRow, int theCount, const QModelIn
   return true;
 }
 
-
 void XGUI_DocumentDataModel::removeSubModel(int theModelId)
 {
   XGUI_PartModel* aModel = myPartModels.at(theModelId);
@@ -414,7 +413,7 @@ void XGUI_DocumentDataModel::removeSubModel(int theModelId)
       aToRemove.append(i);
   }
   int aId;
-  while(aToRemove.size() > 0) {
+  while (aToRemove.size() > 0) {
     aId = aToRemove.last();
     delete myIndexes.at(aId);
     myIndexes.removeAt(aId);
@@ -433,7 +432,7 @@ bool XGUI_DocumentDataModel::isSubModel(const QAbstractItemModel* theModel) cons
 
 bool XGUI_DocumentDataModel::isPartSubModel(const QAbstractItemModel* theModel) const
 {
-  return myPartModels.contains((XGUI_PartModel*)theModel);
+  return myPartModels.contains((XGUI_PartModel*) theModel);
 }
 
 QModelIndex XGUI_DocumentDataModel::partFolderNode() const
@@ -462,43 +461,44 @@ bool XGUI_DocumentDataModel::activatedIndex(const QModelIndex& theIndex)
   if (isPartSubModel(aModel)) {
     // if this is root node (Part item index)
     if (!aIndex->parent().isValid()) {
-      if (myActivePart) myActivePart->setItemsColor(PASSIVE_COLOR);
+      if (myActivePart)
+        myActivePart->setItemsColor(PASSIVE_COLOR);
+
+        if (myActivePart == aModel) {
+          myActivePart = 0;
+          myActivePartIndex = QModelIndex();
+        } else {
+          myActivePart = (XGUI_PartModel*)aModel;
+          myActivePartIndex = theIndex;
+        }
 
-      if (myActivePart == aModel) {
-        myActivePart = 0;
-        myActivePartIndex = QModelIndex();
-      } else {
-        myActivePart = (XGUI_PartModel*)aModel;
-        myActivePartIndex = theIndex;
+        if (myActivePart) {
+          myActivePart->setItemsColor(ACTIVE_COLOR);
+          myModel->setItemsColor(PASSIVE_COLOR);
+        } else
+        myModel->setItemsColor(ACTIVE_COLOR);
+        return true;
       }
-
-      if (myActivePart) {
-        myActivePart->setItemsColor(ACTIVE_COLOR);
-        myModel->setItemsColor(PASSIVE_COLOR);
-      } else 
-         myModel->setItemsColor(ACTIVE_COLOR);
-     return true;
     }
-  }
   return false;
 }
 
 ResultPartPtr XGUI_DocumentDataModel::activePart() const
 {
-  if (myActivePart) 
+  if (myActivePart)
     return myActivePart->part();
   return ResultPartPtr();
 }
 
-void XGUI_DocumentDataModel::deactivatePart() 
-{ 
-  if (myActivePart) 
+void XGUI_DocumentDataModel::deactivatePart()
+{
+  if (myActivePart)
     myActivePart->setItemsColor(PASSIVE_COLOR);
-  myActivePart = 0;
-  myActivePartIndex = QModelIndex();
-  myModel->setItemsColor(ACTIVE_COLOR);
-}
+    myActivePart = 0;
+    myActivePartIndex = QModelIndex();
+    myModel->setItemsColor(ACTIVE_COLOR);
+  }
+
 Qt::ItemFlags XGUI_DocumentDataModel::flags(const QModelIndex& theIndex) const
 {
   Qt::ItemFlags aFlags = QAbstractItemModel::flags(theIndex);
@@ -508,11 +508,12 @@ Qt::ItemFlags XGUI_DocumentDataModel::flags(const QModelIndex& theIndex) const
   return aFlags;
 }
 
-QModelIndex XGUI_DocumentDataModel::partIndex(const ResultPartPtr& theObject) const 
+QModelIndex XGUI_DocumentDataModel::partIndex(const ResultPartPtr& theObject) const
 {
   int aRow = -1;
   XGUI_PartModel* aModel = 0;
-  foreach (XGUI_PartModel* aPartModel, myPartModels) {
+  foreach (XGUI_PartModel* aPartModel, myPartModels)
+  {
     aRow++;
     if (aPartModel->part() == theObject) {
       aModel = aPartModel;
@@ -520,7 +521,7 @@ QModelIndex XGUI_DocumentDataModel::partIndex(const ResultPartPtr& theObject) co
     }
   }
   if (aModel) {
-    return createIndex(aRow, 0, (void*)getModelIndex(aModel->index(0, 0, QModelIndex())));
+    return createIndex(aRow, 0, (void*) getModelIndex(aModel->index(0, 0, QModelIndex())));
   }
   return QModelIndex();
 }
@@ -544,13 +545,15 @@ QModelIndex XGUI_DocumentDataModel::objectIndex(const ObjectPtr theObject) const
         return index(aId + historyOffset(), 0, QModelIndex());
     } else {
       QModelIndex aIndex = myModel->objectIndex(theObject);
-      return aIndex.isValid()? 
-        createIndex(aIndex.row(), aIndex.column(), (void*)getModelIndex(aIndex)) :
-        QModelIndex();
+      return
+          aIndex.isValid() ?
+              createIndex(aIndex.row(), aIndex.column(), (void*) getModelIndex(aIndex)) :
+              QModelIndex();
     }
   } else {
     XGUI_PartModel* aPartModel = 0;
-    foreach(XGUI_PartModel* aModel, myPartModels) {
+    foreach(XGUI_PartModel* aModel, myPartModels)
+    {
       if (aModel->hasDocument(aDoc)) {
         aPartModel = aModel;
         break;
@@ -558,9 +561,10 @@ QModelIndex XGUI_DocumentDataModel::objectIndex(const ObjectPtr theObject) const
     }
     if (aPartModel) {
       QModelIndex aIndex = aPartModel->objectIndex(theObject);
-      return aIndex.isValid()? 
-        createIndex(aIndex.row(), aIndex.column(), (void*)getModelIndex(aIndex)) :
-        QModelIndex();
+      return
+          aIndex.isValid() ?
+              createIndex(aIndex.row(), aIndex.column(), (void*) getModelIndex(aIndex)) :
+              QModelIndex();
     }
   }
   return QModelIndex();