]> AND Private Git Repository - blast.git/blobdiff - GroupInterface.cpp
Logo AND Algorithmique Numérique Distribuée

Private GIT Repository
started clkconvert output gen
[blast.git] / GroupInterface.cpp
index 5f292b6aad1a94488dd809206f78b7802059a5a0..bfeb1ff2373a4fe113854772826892dd9f0187d3 100644 (file)
@@ -122,13 +122,39 @@ bool GroupInterface::canConnectFrom(AbstractInterface *iface) {
     if ((direction == Input) && (iface->getDirection() == Input) && (purpose == iface->getPurpose())) return true;
     if ((direction == InOut) && (iface->getDirection() == InOut) && (purpose == iface->getPurpose())) return true;
   }
-  else if ((getOwner()->isTopGroupBlock()) && (iface->getOwner()->isSourceBlock())) {
+  else if ((getOwner()->isTopGroupBlock()) && (iface->getOwner()->isStimuliBlock())) {
     if ((direction == Input) && (iface->getDirection() == Output) && (purpose == iface->getPurpose())) return true;
   }
 
   return false;
 }
 
+int GroupInterface::getClockDomain() throw(Exception) {
+
+  int idClock = -1;
+
+  GroupInterface* iface = NULL;
+  if (clkIfaceType == ClockName) {
+    iface = AI_TO_GRP(getClockIface());
+  }
+  else if ((direction == Input) && (purpose == Clock)) {
+    iface = this;
+  }
+
+  if ( iface != NULL) {
+
+    QString name = iface->getName();
+    name.remove(0,8);
+    bool ok;
+    idClock = name.toInt(&ok);
+    if (!ok) throw(Exception(IFACE_INVALID_CLKFREQ,this));
+
+  }
+
+  return idClock;
+}
+
+
 void GroupInterface::connectionsValidation(QStack<AbstractInterface*> *interfacetoValidate, QList<AbstractInterface*> *validatedInterfaces) throw(Exception) {
     cout << "group interface connection validation" << endl;
 }