]> Creatis software - bbtk.git/commitdiff
.
authorEduardo Davila <Eduardo.Davila@creatis.insa-lyon.fr>
Thu, 28 May 2009 08:26:59 +0000 (08:26 +0000)
committerEduardo Davila <Eduardo.Davila@creatis.insa-lyon.fr>
Thu, 28 May 2009 08:26:59 +0000 (08:26 +0000)
kernel/src/bbtkPackage.cxx
kernel/src/bbtkPackage.h

index ead823cad9cc81a2faa5946613a6a3f0c168ab61..59abd496fe2361ecb38c274c49eb5f8024b1a465 100644 (file)
@@ -3,8 +3,8 @@
   Program:   bbtk
   Module:    $RCSfile: bbtkPackage.cxx,v $
   Language:  C++
-  Date:      $Date: 2009/05/28 08:12:06 $
-  Version:   $Revision: 1.26 $
+  Date:      $Date: 2009/05/28 08:26:59 $
+  Version:   $Revision: 1.27 $
 =========================================================================*/
 
 /* ---------------------------------------------------------------------
@@ -117,52 +117,49 @@ namespace bbtk
 
 
   //==========================================================================
-  void PackageReleaseBlackBoxDescriptorInternal(Package::WeakPointer pack,
-                                               const std::string& descname)
-  {
-    // Try to release descriptor
-    std::string packname = pack.lock()->GetName();
-
-    bbtkDebugMessage("package",5,"--- Releasing descriptor '"
-                    <<packname<<"::"<<descname<<"'"<<bbtkendl);
-
-
-    Package::BlackBoxMapType::iterator desc = 
-      pack.lock()->GetBlackBoxMap().find(descname);
-    if (desc ==  pack.lock()->GetBlackBoxMap().end())
-      {
-       bbtkDebugMessage("package",5,
-                        "    Descriptor has already been released"
-                        <<bbtkendl);
-       return;
-      }
-    //    bbtkDebugMessage("package",3,
-    //              "    Trying unreferencing it ... "<<std::endl);
-    BlackBoxDescriptor::WeakPointer pdesc = desc->second;
-    desc->second.reset();
-    // if it is dead : remove it 
-    if (pdesc.expired()) 
-      {
-       bbtkDebugMessage("package",2," ==> '"<<packname<<"::"<<descname<<"' Descriptor expired"<<bbtkendl);
-       if (pack.expired()) 
+         void PackageReleaseBlackBoxDescriptorInternal(Package::WeakPointer pack,
+                                                       const std::string& descname)
          {
-           bbtkDebugMessage("package",2,
-                            "     ... and caused its package death"
-                            <<bbtkendl);
-           return;
+               // Try to release descriptor
+               std::string packname = pack.lock()->GetName();
+
+               bbtkDebugMessage("package",5,"--- Releasing descriptor '"
+                                <<packname<<"::"<<descname<<"'"<<bbtkendl);
+
+
+               Package::BlackBoxMapType::iterator desc = 
+                 pack.lock()->GetBlackBoxMap().find(descname);
+               if (desc ==  pack.lock()->GetBlackBoxMap().end())
+                 {
+               bbtkDebugMessage("package",5,
+                                "    Descriptor has already been released"
+                                <<bbtkendl);
+               return;
+                 }
+               //    bbtkDebugMessage("package",3,
+               //                   "    Trying unreferencing it ... "<<std::endl);
+               BlackBoxDescriptor::WeakPointer pdesc = desc->second;
+               desc->second.reset();
+               // if it is dead : remove it 
+               if (pdesc.expired()) 
+               {
+                 bbtkDebugMessage("package",2," ==> '"<<packname<<"::"<<descname<<"' Descriptor expired"<<bbtkendl);
+                 if (pack.expired()) 
+                 {
+                       bbtkDebugMessage("package",2,
+                                        "     ... and caused its package death"
+                                        <<bbtkendl);
+                       return;
+                 } // pack.expired
+                 desc = pack.lock()->GetBlackBoxMap().find(descname);
+                 if (desc !=  pack.lock()->GetBlackBoxMap().end())       pack.lock()->GetBlackBoxMap().erase(desc);
+               }   else    {  //pdesc.expired
+                    bbtkDebugMessage("package",5,"    ... Descriptor still alive ("
+                                <<pdesc.use_count()<<" refs)"
+                                <<bbtkendl);
+                    pack.lock()->GetBlackBoxMap()[descname] = pdesc.lock();
+               } // pdesc.expired
          }
-       desc = pack.lock()->GetBlackBoxMap().find(descname);
-       if (desc !=  pack.lock()->GetBlackBoxMap().end())
-         pack.lock()->GetBlackBoxMap().erase(desc);
-      }
-    else 
-      {
-       bbtkDebugMessage("package",5,"    ... Descriptor still alive ("
-                        <<pdesc.use_count()<<" refs)"
-                        <<bbtkendl);
-       pack.lock()->GetBlackBoxMap()[descname] = pdesc.lock();
-      }
-  }
   //==========================================================================
 
 
@@ -230,8 +227,12 @@ namespace bbtk
                break;
              }
            
-           PackageReleaseBlackBoxDescriptorInternal(pack,*descname);
-           
+#if defined(MACOSX)
+                 if (dyn==0)  PackageReleaseBlackBoxDescriptorInternal(pack,*descname);
+#else
+                 PackageReleaseBlackBoxDescriptorInternal(pack,*descname);
+#endif
+
          }
 
        //
@@ -301,7 +302,13 @@ namespace bbtk
     //  and descallocated (reset) by PACKAGENAMEDeletePackage())
     if (nrefs == ndesc + dyn) 
       {
-       PackageReleaseBlackBoxDescriptorInternal(pack,dname);
+#if defined(MACOSX)
+                 //
+                 if (dyn==0)
+                         PackageReleaseBlackBoxDescriptorInternal(pack,dname);
+#else
+                 PackageReleaseBlackBoxDescriptorInternal(pack,dname);
+#endif 
       }
     
     // If the package is released and dynamically loaded 
@@ -352,8 +359,9 @@ namespace bbtk
 
     // Open shared lib
     void *handler;
-    handler = dlopen(libname.c_str(),
-                    BBTK_RTLD_TIME | BBTK_RTLD_SCOPE );
+    handler = dlopen(libname.c_str(), BBTK_RTLD_TIME | BBTK_RTLD_SCOPE );
+//EED     handler = dlopen(libname.c_str(), RTLD_LAZY | RTLD_LOCAL );
+         
     if (!handler)
       {
        bbtkMessage("package",2,
@@ -653,7 +661,13 @@ namespace bbtk
     
     // closes the dl handler
 #if defined(__GNUC__)  
-    dlclose(h);  
+         if (dlclose(h)!=0)
+         {
+                 printf("EED Package::UnLoad ERROR %s\n", packname.c_str() );
+                 bbtkWarning("Failed to close dynamic library for package '"<<packname
+                                         <<"'"<<std::endl);
+         }  
+         
 #elif defined(_WIN32)
     FreeLibrary(h);
 #endif
index f2876752077a213a472bfd495b8b7c5b48c78d24..4b8d649f19ec5b1ddae40bc8a6402c05108946c9 100644 (file)
@@ -2,8 +2,8 @@
   Program:   bbtk
   Module:    $RCSfile: bbtkPackage.h,v $
   Language:  C++
-  Date:      $Date: 2009/05/19 10:19:23 $
-  Version:   $Revision: 1.13 $
+  Date:      $Date: 2009/05/28 08:26:59 $
+  Version:   $Revision: 1.14 $
 =========================================================================*/
 
 /* ---------------------------------------------------------------------
@@ -341,14 +341,15 @@ namespace bbtk
     bbtk::Package::Pointer                                             \
     BBTK_CDECL NAME ## GetPackage()            \
     {                                                                  \
-      if (!NAME ## GetPackagePointer())                                        \
-       NAME ## GetPackagePointer() =                                   \
-         bbtk::Package::New(#NAME,                                     \
+        if (!NAME ## GetPackagePointer())              {                       \
+                 NAME ## GetPackagePointer() =                                 \
+             bbtk::Package::New(#NAME,                                 \
                             AUTHOR,                                    \
                             DESCRIPTION,                               \
                             VERSION    \
                             );                                         \
-      bbtk::Object::InsertInPackageList( NAME ## GetPackagePointer() ); \
+           bbtk::Object::InsertInPackageList( NAME ## GetPackagePointer() );  \
+         }                                              \
       return NAME ## GetPackagePointer();                              \
     }                                                                  \
     BBTK_PACKAGE_EXPORT const std::string&                             \