]> Creatis software - bbtk.git/commitdiff
*** empty log message ***
authorguigues <guigues>
Thu, 14 Feb 2008 09:32:54 +0000 (09:32 +0000)
committerguigues <guigues>
Thu, 14 Feb 2008 09:32:54 +0000 (09:32 +0000)
kernel/src/bbtkConfigurationFile.cxx
kernel/src/bbtkConfigurationFile.h
kernel/src/bbtkXML.h [new file with mode: 0644]

index e3982866e38f4f0ff592f6ef5b17f050cacb1803..634d5172ea5335a88238dabfba9781535c932ad0 100644 (file)
@@ -3,8 +3,8 @@
   Program:   bbtk
   Module:    $RCSfile: bbtkConfigurationFile.cxx,v $
   Language:  C++
-  Date:      $Date: 2008/02/13 14:08:25 $
-  Version:   $Revision: 1.3 $
+  Date:      $Date: 2008/02/14 09:32:54 $
+  Version:   $Revision: 1.4 $
                                                                                 
   Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
   l'Image). All rights reserved. See doc/license.txt or
@@ -22,8 +22,8 @@
 
 #include "bbtkConfigurationFile.h"
 #include "bbtkMessageManager.h"
-//#include "xmlParser.h"
-#include <sys/stat.h> // for struct stat stFileInfo
+#include "bbtkXML.h"
+#include "bbtkUtilities.h"
 
 #if defined(WIN32)
 #include <direct.h> // for getcwd
 
 namespace bbtk
 {
-/// Constructor
-ConfigurationFile::ConfigurationFile()
-{
-   char *execPath = GetExecutablePath();
-
- #if defined(WIN32)
-   std::string slash("\\");
- #else
-   std::string slash("/");
- #endif
-   // ==> Set system paths
-   mBin_path = execPath;
-   mInstall_path = mBin_path + slash + "..";
-   // The relative path to the doc folder (=BBTK_DOC_REL_PATH)
-   mDoc_rel_path = BBTK_STRINGIFY_SYMBOL(BBTK_DOC_REL_PATH);
-   // The path to the doc folder (=mInstall_path+"/"+mDoc_rel_path)
-   mDoc_path = mInstall_path + slash + mDoc_rel_path;
-   // The relative path to the doc folder (=BBTK_BBS_REL_PATH)
-   mBbs_rel_path = BBTK_STRINGIFY_SYMBOL(BBTK_BBS_REL_PATH);
-   // The path to the bbs folder (=mInstall_path+"/"+mBbs_rel_path)
-   mBbs_path = mInstall_path + slash + mBbs_rel_path;
-   // The relative path to the rsc folder (=BBTK_RSC_REL_PATH)
-   //   mRsc_rel_path = BBTK_STRINGIFY_SYMBOL(BBTK_RSC_REL_PATH);
-   // The path to the rsc folder (=mInstall_path+"/"+mRsc_rel_path)
-   //   mRsc_path = mInstall_path + slash + mRsc_rel_path;
-   // The path to the bbtk data folder 
-   // Initialized to mInstall_path+"/"+BBTK_DATA_REL_PATH
-   // But can be overriden by value read from bbtk_config.xml
-   mData_path = mInstall_path + slash + BBTK_STRINGIFY_SYMBOL(BBTK_DATA_REL_PATH);
-   //  MessageManager::SetMessageLevel("Config",1);
-   bbtkMessage("Config",1," ==> bin    : '"<<mBin_path<<"'"<<std::endl);
-   bbtkMessage("Config",1," ==> prefix : '"<<mInstall_path<<"'"<<std::endl);
-   bbtkMessage("Config",1," ==> doc    : '"<<mDoc_path<<"'"<<std::endl);
-   bbtkMessage("Config",1," ==> bbs    : '"<<mBbs_path<<"'"<<std::endl);
-   //   bbtkMessage("Config",1," ==> rsc    : '"<<mRsc_path<<"'"<<std::endl);
-   bbtkMessage("Config",1," ==> data   : '"<<mData_path<<"'"<<std::endl);
-
-   // ==> First we look for bbtk_config.xml in "."
-   char buf[2048];
-   const char *currentDir = getcwd(buf, 2048);
-     
-   if( !currentDir )
-   {
-      std::cerr << "Path was too long to fit on 2048 bytes ?!?" << std::endl;
-      // \todo : what else?
-      // How abort a constructor and warn the caller function?
-      // LG : throw an exception 
-   }
-
-   std::string configXmlFullPathName = currentDir + slash + "bbtk_config.xml";
-
-   if ( FileExists( configXmlFullPathName ))
-   {
-      bbtkMessage("Config",1, "ConfigurationFile : [" << configXmlFullPathName << 
-            "] found in current directory" << std::endl); 
-      //Read(configXmlFullPathName.c_str());
-      // traiter le fichier local     
-   }
 
-// ==> Then we look for bbtk_config.xml in ".bbtk"
-   else 
-   {
-   #if defined(__GNUC__)
-      std::string str_home(getenv("HOME"));
-   #elif defined(_WIN32)
-      std::string str_home(getenv("USERPROFILE"));
-   #endif
-      configXmlFullPathName = str_home + slash + ".bbtk/bbtk_config.xml";
-      if (!FileExists( configXmlFullPathName ))
-      {         
-         // ==> Nothing found, we create bbtk_config.xml in ".bbtk"
-         InstallPath ();
+  //====================================================================
+  /// Constructor
+  ConfigurationFile::ConfigurationFile()
+  {
+    // file separator
+#if defined(_WIN32)
+    mFile_separator = "\\";
+#else
+    mFile_separator = "/";
+#endif
+    
+    // ==> Set system paths
+    mBin_path = GetExecutablePath();
+    mInstall_path = mBin_path + mFile_separator + "..";
+    // The relative path to the doc folder (=BBTK_DOC_REL_PATH)
+    mDoc_rel_path = BBTK_STRINGIFY_SYMBOL(BBTK_DOC_REL_PATH);
+    // The path to the doc folder (=mInstall_path+"/"+mDoc_rel_path)
+    mDoc_path = mInstall_path + mFile_separator + mDoc_rel_path;
+    // The relative path to the doc folder (=BBTK_BBS_REL_PATH)
+    mBbs_rel_path = BBTK_STRINGIFY_SYMBOL(BBTK_BBS_REL_PATH);
+    // The path to the bbs folder (=mInstall_path+"/"+mBbs_rel_path)
+    mBbs_path = mInstall_path + mFile_separator + mBbs_rel_path;
+    // The relative path to the rsc folder (=BBTK_RSC_REL_PATH)
+    //   mRsc_rel_path = BBTK_STRINGIFY_SYMBOL(BBTK_RSC_REL_PATH);
+    // The path to the rsc folder (=mInstall_path+"/"+mRsc_rel_path)
+    //   mRsc_path = mInstall_path + mFile_separator + mRsc_rel_path;
+    // The path to the bbtk data folder 
+    // Initialized to mInstall_path+"/"+BBTK_DATA_REL_PATH
+    // But can be overriden by value read from bbtk_config.xml
+    mData_path = mInstall_path + mFile_separator + BBTK_STRINGIFY_SYMBOL(BBTK_DATA_REL_PATH);
+    //MessageManager::SetMessageLevel("Config",1);
+    bbtkMessage("Config",1," ==> bin    : '"<<mBin_path<<"'"<<std::endl);
+    bbtkMessage("Config",1," ==> prefix : '"<<mInstall_path<<"'"<<std::endl);
+    bbtkMessage("Config",1," ==> doc    : '"<<mDoc_path<<"'"<<std::endl);
+    bbtkMessage("Config",1," ==> bbs    : '"<<mBbs_path<<"'"<<std::endl);
+    //   bbtkMessage("Config",1," ==> rsc    : '"<<mRsc_path<<"'"<<std::endl);
+    bbtkMessage("Config",1," ==> data   : '"<<mData_path<<"'"<<std::endl);
+    
+    
+    // bbs_paths
+    // always add "." (current working directory) at the begining
+    mBbs_paths.push_back("."); 
+    // add system bbs path 
+    mBbs_paths.push_back(mBbs_path);
+    
+    // always add "." (current working directory) at the begining
+    mPackage_paths.push_back(".");   
+#ifdef UNIX
+    // add system bin path (for build tree)
+    // mPackage_paths.push_back(mBin_path);
+    // add system lib path (for install tree)
+    mPackage_paths.push_back(mInstall_path + mFile_separator + "lib");
+#endif
+#ifdef WIN32
+    // add bin/Debug bin/Release paths (for build/install tree)
+    mPackage_paths.push_back(mBin_path + mFile_separator + "Debug");
+    mPackage_paths.push_back(mBin_path + mFile_separator + "Release");
+#endif
+    
+    
+    // ==> First we look for bbtk_config.xml in "."
+    char buf[2048];
+    const char *currentDir = getcwd(buf, 2048);
+    
+    if( !currentDir )
+      {
+       std::cerr << "Path was too long to fit on 2048 bytes ?!?" << std::endl;
+       // \todo : what else?
+       // How abort a constructor and warn the caller function?
+       // LG : throw an exception 
       }
-   }
+    
+    std::string configXmlFullPathName = currentDir + mFile_separator + "bbtk_config.xml";
+    
+    if ( Utilities::FileExists( configXmlFullPathName ))
+      {
+       bbtkMessage("Config",1, "ConfigurationFile : [" << configXmlFullPathName << 
+                   "] found in current directory" << std::endl); 
+       //Read(configXmlFullPathName.c_str());
+       // traiter le fichier local     
+      }
+    
+    // ==> Then we look for bbtk_config.xml in ".bbtk"
+    else 
+      {
+#if defined(__GNUC__)
+       std::string str_home(getenv("HOME"));
+#elif defined(_WIN32)
+       std::string str_home(getenv("USERPROFILE"));
+#endif
+       configXmlFullPathName = str_home + mFile_separator + ".bbtk/bbtk_config.xml";
+       if (!Utilities::FileExists( configXmlFullPathName ))
+         {         
+           // ==> Nothing found, we create bbtk_config.xml in ".bbtk"
+           InstallPath ();
+         }
+      }
+    
+    // In any case, deal with bbtk_config.xml!
+    Read(configXmlFullPathName.c_str());
+  }
+  //=========================================================================
 
-// In any case, deal with bbtk_config.xml!
-   Read(configXmlFullPathName.c_str());
-}
+  //=========================================================================
+  /// Destructor
+  ConfigurationFile::~ConfigurationFile()
+  {
+  }
+  //=========================================================================
+  
 
-/// Destructor
-ConfigurationFile::~ConfigurationFile()
-{
-}
 
-// See : http://www.techbytes.ca/techbyte103.html for more O.S.
-bool ConfigurationFile::FileExists(std::string strFilename) {
-  struct stat stFileInfo;
-  bool blnReturn;
-  int intStat;
 
-  // Attempt to get the file attributes
-  intStat = stat(strFilename.c_str(),&stFileInfo);
-  if(intStat == 0) {
-    // We were able to get the file attributes
-    // so the file obviously exists.
-    blnReturn = true;
-  } else {
-    // We were not able to get the file attributes.
-    // This may mean that we don't have permission to
-    // access the folder which contains this file. If you
-    // need to do that level of checking, lookup the
-    // return values of stat which will give you
-    // more details on why stat failed.
-    blnReturn = false;
+  //=========================================================================
+  void ConfigurationFile::CreateConfigXML( char *rootDirectory )
+  {
+    FILE *fp;
+    char configXml[250];
+    sprintf (configXml , "%s/bbtk_config.xml", rootDirectory);
+    bbtkMessage("Config",1, "in CreateConfigXML[" << configXml << "]" << std::endl);
+    fp = fopen (configXml, "w");
+    fprintf(fp, "<?xml version=\"1.0\" encoding=\"iso-8859-1\"?>\n");
+    //  fprintf(fp, "<!DOCTYPE config SYSTEM \"/mnt/windows/bbtk/bbtk_config.xml>\n");
+    fprintf(fp, "<config>\n");
+    fprintf(fp, "   <description>  </description>\n");
+    //   fprintf(fp, "   <url>  http://www.creatis.insa-lyon.fr/software/bbtk  </url>\n");
+    //  fprintf(fp, "   <install_path> </install_path>\n");
+    fprintf(fp, "   <bbs_path>     </bbs_path>\n");
+    // fprintf(fp, "   <ext_dll_path> </ext_dll_path>\n");
+    fprintf(fp, "   <package_path> </package_path>\n");
+    fprintf(fp, "   <data_path> </data_path>\n");//, BBTK_DATA_PATH);
+    /// \todo find a decent default value !
+      ///fprintf(fp, "   <default_temp_dir>  %s </default_temp_dir>\n", " ");
+      // when $ will be found, default_temp_dir value will be replaced
+      fprintf(fp, "   <default_temp_dir>$</default_temp_dir>\n");
+      fprintf(fp, "</config>\n");
+      fclose(fp);
   }
-
-  return(blnReturn);
-}
+  //=========================================================================  
 
 
-void ConfigurationFile::CreateConfigXML( char *rootDirectory )
-{
-   FILE *fp;
-   char configXml[250];
-   sprintf (configXml , "%s/bbtk_config.xml", rootDirectory);
-   bbtkMessage("Config",1, "in CreateConfigXML[" << configXml << "]" << std::endl);
-   fp = fopen (configXml, "w");
-   fprintf(fp, "<?xml version=\"1.0\" encoding=\"iso-8859-1\"?>\n");
-   //  fprintf(fp, "<!DOCTYPE config SYSTEM \"/mnt/windows/bbtk/bbtk_config.xml>\n");
-   fprintf(fp, "<config>\n");
-   fprintf(fp, "   <description>  </description>\n");
-   //   fprintf(fp, "   <url>  http://www.creatis.insa-lyon.fr/software/bbtk  </url>\n");
-   //  fprintf(fp, "   <install_path> </install_path>\n");
-   fprintf(fp, "   <bbs_path>     </bbs_path>\n");
-  // fprintf(fp, "   <ext_dll_path> </ext_dll_path>\n");
-   fprintf(fp, "   <package_path> </package_path>\n");
-   fprintf(fp, "   <data_path> </data_path>\n");//, BBTK_DATA_PATH);
-   /// \todo find a decent default value !
-   ///fprintf(fp, "   <default_temp_dir>  %s </default_temp_dir>\n", " ");
-   // when $ will be found, default_temp_dir value will be replaced
-   fprintf(fp, "   <default_temp_dir>$</default_temp_dir>\n");
-   fprintf(fp, "</config>\n");
-   fclose(fp);
-}
-
-char *ConfigurationFile::GetExecutablePath()
-{
+  //=========================================================================
+  std::string ConfigurationFile::GetExecutablePath()
+  {
     /// \todo : Think to delete it!
     char *buf = (char *)malloc(512);
     char *slash;
-
+    
 #if defined(WIN32)
     GetModuleFileName(NULL, buf, 511);
     slash = strrchr(buf, '\\');
     if (slash)
-    {
+      {
         *slash = 0;
-    }
+      }
 #elif defined(__GNUC__)
     int res;
     res = readlink("/proc/self/exe", buf, 512);
     if (res == -1)
-        return "";
+      return "";
     buf[res] = 0;
     slash = strrchr(buf, '/');
     if (slash)
-    {
+      {
         *slash = 0;
-    }
+      }
 #else
     return "";
 #endif
+    std::string ret(buf);
+    free(buf);
+    return ret;
+  }
+  //=========================================================================
 
-    return buf;
-}
-
-
-
-void ConfigurationFile::InstallPath ()
-{
-
-/*--------------------------------------------------
-New policy for bbtk_config.xml :
-
-if bbtk_config.xml found in current directory (user is an aware user!)
-   use it!
-   
-else if bbtk_config.xml found in HOME/.bbtk (user already worked with it)
-   use it!
-   
-else if bbtk_config.xml.tmp found in /usr/local/bin or c:\\Program Files\\BBTK\\bin
-   copy it as .bbtk/bbtk_config.xml
-   
-else (nothing installed)
-   create a minimum version in HOME/.bbtk
-----------------------------------------------------*/
-
-
-// -----------------------------------------------------------------
-#if defined(__GNUC__)
-
-// ------------------ create some usefull strings ----------------
-// installed bbtk_path
-  char bbtk_path[100];
-  strcpy(bbtk_path, "/usr/local/bin");
-       
-// rootDirectory
-  char rootDirectory[200];
-  sprintf( rootDirectory,  "%s/.bbtk", getenv("HOME"));
-      
-// configPath
-  char configPath[200];
-  sprintf(configPath, "%s/bbtk_config.xml",rootDirectory);
-  
-// makeDir
-  char makeDir[250];
-  sprintf( makeDir, "mkdir \"%s\" ", rootDirectory);
-
-// configXmlTmp
-  char configXmlTmp[250]; 
-  sprintf(configXmlTmp, "%s/bbtk_config.xml.tmp", bbtk_path);
-
-// copyFile
-  char copyFile[250];
-
-  if (!FileExists(configXmlTmp)) // bbtk_config.xml.tmp not found (not installed)
-  {  
-     if (!FileExists(rootDirectory)) // .bbtk not found
-     {
-       system(makeDir);  // create .bbtk
-     }
 
-     // if "bbtk_path/bbtk_config.xml.tmp" doesn't exist, hard-create a minimum version in .bbtk
-     CreateConfigXML( rootDirectory );// create .bbtk
-  }
-  else
+  //=========================================================================
+  void ConfigurationFile::InstallPath ()
   {
-     sprintf(copyFile,"cp %s  %s/bbtk_config.xml ",configXmlTmp,rootDirectory );
-     if (!FileExists(rootDirectory))
-     {
-       //std::cout << "makeDir[" << makeDir << "]" << std::endl;
-       system(makeDir);
-     }
-
-     if (!FileExists(configPath))
-     {
-       system(copyFile);
-     }
-  }
-  return;
-   
-// ------------------------------------------------------------------
+    
+    /*--------------------------------------------------
+      New policy for bbtk_config.xml :
+      
+      if bbtk_config.xml found in current directory (user is an aware user!)
+      use it!
+      
+      else if bbtk_config.xml found in HOME/.bbtk (user already worked with it)
+      use it!
+      
+      else if bbtk_config.xml.tmp found in /usr/local/bin or c:\\Program Files\\BBTK\\bin
+      copy it as .bbtk/bbtk_config.xml
+      
+      else (nothing installed)
+      create a minimum version in HOME/.bbtk
+      ----------------------------------------------------*/
+    
+    
+    // -----------------------------------------------------------------
+#if defined(__GNUC__)
+    
+    // ------------------ create some usefull strings ----------------
+    // installed bbtk_path
+    char bbtk_path[100];
+    strcpy(bbtk_path, "/usr/local/bin");
+    
+    // rootDirectory
+    char rootDirectory[200];
+    sprintf( rootDirectory,  "%s/.bbtk", getenv("HOME"));
+    
+    // configPath
+    char configPath[200];
+    sprintf(configPath, "%s/bbtk_config.xml",rootDirectory);
+    
+    // makeDir
+    char makeDir[250];
+    sprintf( makeDir, "mkdir \"%s\" ", rootDirectory);
+    
+    // configXmlTmp
+    char configXmlTmp[250]; 
+    sprintf(configXmlTmp, "%s/bbtk_config.xml.tmp", bbtk_path);
+    
+    // copyFile
+    char copyFile[250];
+    
+    if (!Utilities::FileExists(configXmlTmp)) // bbtk_config.xml.tmp not found (not installed)
+      {  
+       if (!Utilities::FileExists(rootDirectory)) // .bbtk not found
+         {
+           system(makeDir);  // create .bbtk
+         }
+       
+       // if "bbtk_path/bbtk_config.xml.tmp" doesn't exist, hard-create a minimum version in .bbtk
+       CreateConfigXML( rootDirectory );// create .bbtk
+      }
+    else
+      {
+       sprintf(copyFile,"cp %s  %s/bbtk_config.xml ",configXmlTmp,rootDirectory );
+       if (!Utilities::FileExists(rootDirectory))
+         {
+           //std::cout << "makeDir[" << makeDir << "]" << std::endl;
+           system(makeDir);
+         }
+       
+       if (!Utilities::FileExists(configPath))
+         {
+           system(copyFile);
+         }
+      }
+    return;
+    
+    // ------------------------------------------------------------------
 #elif defined(WIN32)
-
-
-// installed bbtk_path
-  char bbtk_path[100];
-  strcpy(bbtk_path, "\"c:\\Program Files\\BBTK\\bin\"");
-  char bbtk_path2[100];
-  strcpy(bbtk_path2, "c:\\Program Files\\BBTK\\bin");
-
-// rootDirectory
-  char rootDirectory[200];  
-  sprintf(rootDirectory, "%s\\.bbtk",getenv("USERPROFILE"));
-  //  std::cout << "[" << rootDirectory << "]" << std::endl;
-    
-// configPath
-  char configPath[200];
-  sprintf(configPath, "%s\\bbtk_config.xml",rootDirectory);
-    
-// makeDir
-  char makeDir[250];
-  sprintf( makeDir, "mkdir \"%s\" ", rootDirectory);
-
-// configXmlTmp
-  char configXmlTmp[250]; 
-  sprintf(configXmlTmp, "%s\\bbtk_config.xml.tmp", bbtk_path2);
     
-// copyFile
-  char copyFile[250];
-  
-  if (!FileExists(configXmlTmp)) // bbtk_config.xml.tmp not found
-  {
-     if (!FileExists(rootDirectory)) // .bbtk not found
-     {
-       system(makeDir);  // create .bbtk
-     }
-     
-     // if "bbtk_path/bbtk_config.xml.tmp" doesn't exist, hard-create a minimum version in .bbtk
-     CreateConfigXML( rootDirectory );// create .bbtk
-     return;
-  }  
-  
-  sprintf(copyFile,"copy %s\\bbtk_config.xml.tmp \"%s\"\\bbtk_config.xml ",bbtk_path,rootDirectory );
-    
-  int attribs = GetFileAttributes (rootDirectory);
-  bbtkMessage("Config",1,std::hex << attribs << " " << FILE_ATTRIBUTE_DIRECTORY << std::endl);
-  if ( attribs != 0xFFFFFFFF){
-    if ((attribs & FILE_ATTRIBUTE_DIRECTORY) == FILE_ATTRIBUTE_DIRECTORY ) /// \TODO : check !
-    {
-      if ( GetFileAttributes( configPath ) == 0xFFFFFFFF)
+    
+    // installed bbtk_path
+    char bbtk_path[100];
+    strcpy(bbtk_path, "\"c:\\Program Files\\BBTK\\bin\"");
+    char bbtk_path2[100];
+    strcpy(bbtk_path2, "c:\\Program Files\\BBTK\\bin");
+    
+    // rootDirectory
+    char rootDirectory[200];  
+    sprintf(rootDirectory, "%s\\.bbtk",getenv("USERPROFILE"));
+    //  std::cout << "[" << rootDirectory << "]" << std::endl;
+    
+    // configPath
+    char configPath[200];
+    sprintf(configPath, "%s\\bbtk_config.xml",rootDirectory);
+    
+    // makeDir
+    char makeDir[250];
+    sprintf( makeDir, "mkdir \"%s\" ", rootDirectory);
+    
+    // configXmlTmp
+    char configXmlTmp[250]; 
+    sprintf(configXmlTmp, "%s\\bbtk_config.xml.tmp", bbtk_path2);
+    
+    // copyFile
+    char copyFile[250];
+    
+    if (!Utilities::FileExists(configXmlTmp)) // bbtk_config.xml.tmp not found
       {
-         system(copyFile);  
+       if (!Utilities::FileExists(rootDirectory)) // .bbtk not found
+         {
+           system(makeDir);  // create .bbtk
+         }
+       
+       // if "bbtk_path/bbtk_config.xml.tmp" doesn't exist, hard-create a minimum version in .bbtk
+       CreateConfigXML( rootDirectory );// create .bbtk
+       return;
+      }  
+    
+    sprintf(copyFile,"copy %s\\bbtk_config.xml.tmp \"%s\"\\bbtk_config.xml ",bbtk_path,rootDirectory );
+    
+    int attribs = GetFileAttributes (rootDirectory);
+    bbtkMessage("Config",1,std::hex << attribs << " " << FILE_ATTRIBUTE_DIRECTORY << std::endl);
+    if ( attribs != 0xFFFFFFFF)
+      {
+       if ((attribs & FILE_ATTRIBUTE_DIRECTORY) == FILE_ATTRIBUTE_DIRECTORY ) /// \TODO : check !
+         {
+           if ( GetFileAttributes( configPath ) == 0xFFFFFFFF)
+             {
+               system(copyFile);  
+             } 
+         }
       } 
-    }
-  } else {
-    system(makeDir);
-    system(copyFile); 
-  }    
-  return;  
-// ------------------------------------------------------------------    
+    else 
+      {
+       system(makeDir);
+       system(copyFile); 
+      }    
+    return;  
+    // ------------------------------------------------------------------    
 #else
 /// \todo  ConfigurationFile::InstallPath() : exit when for not WIN32 and not__GNUC__
 
@@ -340,110 +352,87 @@ else (nothing installed)
 #endif
 
 }
-
-void ConfigurationFile::GetTextOrClear(const XMLNode& node, std::string& var)
-{
-  if (node.nText()>0) 
-    {
-      var = node.getText();
-    }
-  else if (node.nClear()>0) 
-    {
-      var = node.getClear().lpszValue;
-    }
-  else 
-    {
-      std::string mess("Error : element <");
-      mess += node.getName();
-      mess += "> : no text nor <PRE></PRE> clear tag found";
-    }
-}
+  //=========================================================================
 
 
-// Gets the list of directories holding bb scripts, packages, dll, ... from the xml file
-//      bbtk_config.xml
-
-void ConfigurationFile::Read(const std::string& filename)
-{
 
-  //std::cout << "=======================in  ConfigurationFile::Read filename [" <<filename << "]" << std::endl;
+  //=========================================================================
+  // Gets the list of directories holding bb scripts, packages, dll, ... from the xml file
+  //      bbtk_config.xml
   
-  mConfig_xml_full_path = filename;
-  XMLResults* res = new XMLResults;
-  XMLNode BB = XMLNode::parseFile((XMLCSTR)filename.c_str(),(XMLCSTR)"config",res);
-
-  if ( res->error != eXMLErrorNone ) 
-    {
-      std::ostringstream str;
-      str << XMLNode::getError(res->error);
-      str << " [line " << res->nLine << ", col "<<res->nColumn<<"] ";
-      str << " file "<<filename; 
-      delete res;
-      bbtkError(str.str());
-//      throw ConfigurationException(str.str());
-    }
-  delete res;
-
-  int i,j;
-
-  // Description
-  for (i=0,j=0; i<BB.nChildNode((XMLCSTR)"description"); i++) 
-    {
-      std::string val;
-      GetTextOrClear(BB.getChildNode((XMLCSTR)"description",&j),val);
-      mDescription += val;
-    }    
-
-  // Url
-  if( BB.nChildNode((XMLCSTR)"url") ) 
-     GetTextOrClear(BB.getChildNode((XMLCSTR)"url"),mUrl);
-
-  // Data_Path
-  if( BB.nChildNode((XMLCSTR)"data_path") ) 
-     GetTextOrClear(BB.getChildNode((XMLCSTR)"data_path"),mData_path);
-
-  // install_path
-  //  if( BB.nChildNode((XMLCSTR)"install_path") )
-  //   GetTextOrClear(BB.getChildNode((XMLCSTR)"install_path"),mInstall_path);
-
-  // always add "." (current working directory) at the begining
-  // bbs_paths
-  mBbs_paths.push_back("."); 
-  // add system bbs path 
-  mBbs_paths.push_back(mBbs_path);
-
-  for (i=0,j=0; i<BB.nChildNode((XMLCSTR)"bbs_path"); i++) 
-    {
-      std::string val;
-      GetTextOrClear(BB.getChildNode((XMLCSTR)"bbs_path",&j),val);
-      mBbs_paths.push_back(val);
-    }
-
-  // package_paths
-  mPackage_paths.push_back(".");   
-  for (i=0,j=0; i<BB.nChildNode((XMLCSTR)"package_path"); i++) 
-    {
-      std::string val;
-      GetTextOrClear(BB.getChildNode((XMLCSTR)"package_path",&j),val);
-      mPackage_paths.push_back(val);
-    }
-
-  // default_temp_dir
-  if( BB.nChildNode((XMLCSTR)"default_temp_dir") ) 
-     GetTextOrClear(BB.getChildNode((XMLCSTR)"default_temp_dir"),mDefault_temp_dir);
-
-  if ( mDefault_temp_dir == "$") // no value found in config_xml
+  void ConfigurationFile::Read(const std::string& filename)
   {
-     size_t pos = mConfig_xml_full_path.find("bbtk_config.xml");
-     mDefault_temp_dir = mConfig_xml_full_path.substr (0,pos); 
-  }    
-  // file separator
-  #if defined(_WIN32)
-     mFile_separator = "\\";
-  #else
-     mFile_separator = "/";
-  #endif
-}
-
+    
+    //std::cout << "=======================in  ConfigurationFile::Read filename [" <<filename << "]" << std::endl;
+    
+    mConfig_xml_full_path = filename;
+    XMLResults* res = new XMLResults;
+    XMLNode BB = XMLNode::parseFile((XMLCSTR)filename.c_str(),(XMLCSTR)"config",res);
+    
+    if ( res->error != eXMLErrorNone ) 
+      {
+       std::ostringstream str;
+       str << XMLNode::getError(res->error);
+       str << " [line " << res->nLine << ", col "<<res->nColumn<<"] ";
+       str << " file "<<filename; 
+       delete res;
+       bbtkError(str.str());
+       //      throw ConfigurationException(str.str());
+      }
+    delete res;
+    
+    
+    int i,j;
+    
+    // Description
+    for (i=0,j=0; i<BB.nChildNode((XMLCSTR)"description"); i++) 
+      {
+       std::string val;
+       GetTextOrClear(BB.getChildNode((XMLCSTR)"description",&j),val);
+       mDescription += val;
+      }    
+    
+    // Url
+    if( BB.nChildNode((XMLCSTR)"url") ) 
+      GetTextOrClear(BB.getChildNode((XMLCSTR)"url"),mUrl);
+    
+    // Data_Path
+    if( BB.nChildNode((XMLCSTR)"data_path") ) 
+      GetTextOrClear(BB.getChildNode((XMLCSTR)"data_path"),mData_path);
+    
+    // install_path
+    //  if( BB.nChildNode((XMLCSTR)"install_path") )
+    //   GetTextOrClear(BB.getChildNode((XMLCSTR)"install_path"),mInstall_path);
+    
+    // add user bbs paths
+    for (i=0,j=0; i<BB.nChildNode((XMLCSTR)"bbs_path"); i++) 
+      {
+       std::string val;
+       GetTextOrClear(BB.getChildNode((XMLCSTR)"bbs_path",&j),val);
+       mBbs_paths.push_back(val);
+      }
+    
+    // package_paths
+    
+    // add user package path
+    for (i=0,j=0; i<BB.nChildNode((XMLCSTR)"package_path"); i++) 
+      {
+       std::string val;
+       GetTextOrClear(BB.getChildNode((XMLCSTR)"package_path",&j),val);
+       mPackage_paths.push_back(val);
+      }
+    
+    // default_temp_dir
+    if( BB.nChildNode((XMLCSTR)"default_temp_dir") ) 
+      GetTextOrClear(BB.getChildNode((XMLCSTR)"default_temp_dir"),mDefault_temp_dir);
+    
+    if ( mDefault_temp_dir == "$") // no value found in config_xml
+      {
+       size_t pos = mConfig_xml_full_path.find("bbtk_config.xml");
+       mDefault_temp_dir = mConfig_xml_full_path.substr (0,pos); 
+      }    
+    
+  }
+  //=========================================================================
 
 } // namespace bbtk
index c9b7caba716077b65bedcc9160054267b01463ff..c871f14b81fe68f7b53febb8e70f4aea830cae93 100644 (file)
@@ -3,8 +3,8 @@
   Program:   bbtk
   Module:    $RCSfile: bbtkConfigurationFile.h,v $
   Language:  C++
-  Date:      $Date: 2008/02/13 14:08:25 $
-  Version:   $Revision: 1.3 $
+  Date:      $Date: 2008/02/14 09:32:54 $
+  Version:   $Revision: 1.4 $
                                                                                 
   Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
   l'Image). All rights reserved. See doc/license.txt or
@@ -37,7 +37,6 @@
 #endif
 
 #include <stdio.h>
-#include "xmlParser.h"
 #include <iostream>
 #include <fstream>
 #include <sstream>
 
 namespace bbtk
 {
-//==========================================================================
-class BBTK_EXPORT  ConfigurationException
-{
-public:
-  ConfigurationException(const std::string& message) : mMessage(message) {}
-
-  std::string mMessage;
-};
-
-
-//==========================================================================
-class BBTK_EXPORT ConfigurationFile
-{
-public:
-
-  static ConfigurationFile const &GetInstance()
+  //==========================================================================
+  class BBTK_EXPORT  ConfigurationException
   {
-    static ConfigurationFile f;
-    return f;
-  }
-
-  ~ConfigurationFile();
-
-private:
-  ConfigurationFile();
-  void InstallPath ();
-
-public:
-  inline const std::string& Get_description() const
-     { return mDescription;}
-  inline const std::string& Get_url() const
-     { return mUrl;}
-  inline const std::string& Get_data_path() const
-     { return mData_path;}  
-  inline const std::string& Get_file_separator() const
-     { return mFile_separator;}
-
-  inline const std::string& Get_bin_path() const
-     { return mBin_path;}
-  inline const std::string& Get_install_path() const
-     { return mInstall_path;}
-  inline const std::string& Get_doc_path() const
-     { return mDoc_path;}
-  inline const std::string& Get_rsc_path() const
-     { return mRsc_path;}
-
-  inline const std::vector<std::string>& Get_bbs_paths() const
-     { return mBbs_paths;}
-  inline const std::vector<std::string>& Get_package_paths() const
-     { return mPackage_paths;}
-  inline const std::string& Get_config_xml_full_path() const
-     { return mConfig_xml_full_path;}
-  inline const std::string& Get_default_temp_dir() const
-     { return mDefault_temp_dir;}
-           
+  public:
+    ConfigurationException(const std::string& message) : mMessage(message) {}
+    
+    std::string mMessage;
+  };
+  //==========================================================================
+  
+  //==========================================================================
+  class BBTK_EXPORT ConfigurationFile
+  {
+  public:
+    
+    static ConfigurationFile const &GetInstance()
+    {
+      static ConfigurationFile f;
+      return f;
+    }
+    
+    ~ConfigurationFile();
+    
+  private:
+    ConfigurationFile();
+    void InstallPath ();
+    
+  public:
+    inline const std::string& Get_description() const
+    { return mDescription;}
+    inline const std::string& Get_url() const
+    { return mUrl;}
+    inline const std::string& Get_data_path() const
+    { return mData_path;}  
+    inline const std::string& Get_file_separator() const
+    { return mFile_separator;}
+    
+    inline const std::string& Get_bin_path() const
+    { return mBin_path;}
+    inline const std::string& Get_install_path() const
+    { return mInstall_path;}
+    inline const std::string& Get_doc_path() const
+    { return mDoc_path;}
+    inline const std::string& Get_rsc_path() const
+    { return mRsc_path;}
+    
+    inline const std::vector<std::string>& Get_bbs_paths() const
+    { return mBbs_paths;}
+    inline const std::vector<std::string>& Get_package_paths() const
+    { return mPackage_paths;}
+    inline const std::string& Get_config_xml_full_path() const
+    { return mConfig_xml_full_path;}
+    inline const std::string& Get_default_temp_dir() const
+    { return mDefault_temp_dir;}
+    
   private:
-  void Read(const std::string& fileName);
-  void GetTextOrClear(const XMLNode& node, std::string& var); 
-  char *GetExecutablePath();
-  bool FileExists(std::string strFilename);
-  void CreateConfigXML( char *rootDirectory );
+    void Read(const std::string& fileName);
+     std::string GetExecutablePath();
+     void CreateConfigXML( char *rootDirectory );
     
-// Attributes :
+    // Attributes :
   private :
-  std::string mDescription; 
-  /// Where is the file bbtk_config.xml
-  std::string mConfig_xml_full_path;  
-
-  /// Set automatically :
-  /// The path to the executable (usually bbi)
-  std::string mBin_path;
-  /// The path to the install prefix (=mBinPath+"/..")
-  std::string mInstall_path;
-  /// The relative path to the doc folder (=BBTK_DOC_REL_PATH)
-  std::string mDoc_rel_path;
-  /// The path to the doc folder (=mInstall_path+"/"+mDoc_rel_path)
-  std::string mDoc_path;
-  /// The relative path to the doc folder (=BBTK_BBS_REL_PATH)
-  std::string mBbs_rel_path;
-  /// The path to the bbs folder (=mInstall_path+"/"+mBbs_rel_path)
-  std::string mBbs_path;
-  /// The relative path to the rsc folder (=BBTK_RSC_REL_PATH)
-  std::string mRsc_rel_path;
-  /// The path to the rsc folder (=mInstall_path+"/"+mRsc_rel_path)
-  std::string mRsc_path;
-  /// The path to the bbtk data folder 
-  /// Initialized to mInstall_path+"/"+BBTK_DATA_REL_PATH
-  /// But can be overriden by value read from bbtk_config.xml
-  std::string mData_path;
-
-  /// / or \, depending on the OS
-  std::string mFile_separator;
-
-  /// Read from bbtk_config.xml file
-  /// Where the doc is
-  std::string mUrl;
-  /// Scripts  
-  std::vector<std::string> mBbs_paths; 
-  /// Package dlls    
-  std::vector<std::string> mPackage_paths;
-  /// If Packages link against extern dlls
-  std::vector<std::string> mExt_dll_paths;
-  /// Default directory for generating Graph
-  std::string mDefault_temp_dir;       
+    std::string mDescription; 
+    /// Where is the file bbtk_config.xml
+    std::string mConfig_xml_full_path;  
+    
+    /// Set automatically :
+    /// The path to the executable (usually bbi)
+    std::string mBin_path;
+    /// The path to the install prefix (=mBinPath+"/..")
+    std::string mInstall_path;
+    /// The relative path to the doc folder (=BBTK_DOC_REL_PATH)
+    std::string mDoc_rel_path;
+    /// The path to the doc folder (=mInstall_path+"/"+mDoc_rel_path)
+    std::string mDoc_path;
+    /// The relative path to the doc folder (=BBTK_BBS_REL_PATH)
+    std::string mBbs_rel_path;
+    /// The path to the bbs folder (=mInstall_path+"/"+mBbs_rel_path)
+    std::string mBbs_path;
+    /// The relative path to the rsc folder (=BBTK_RSC_REL_PATH)
+    std::string mRsc_rel_path;
+    /// The path to the rsc folder (=mInstall_path+"/"+mRsc_rel_path)
+    std::string mRsc_path;
+    /// The path to the bbtk data folder 
+    /// Initialized to mInstall_path+"/"+BBTK_DATA_REL_PATH
+    /// But can be overriden by value read from bbtk_config.xml
+    std::string mData_path;
+    
+    /// / or \, depending on the OS
+    std::string mFile_separator;
+    
+    /// Read from bbtk_config.xml file
+    /// Where the doc is
+    std::string mUrl;
+    /// Scripts  
+    std::vector<std::string> mBbs_paths; 
+    /// Package dlls    
+    std::vector<std::string> mPackage_paths;
+    /// If Packages link against extern dlls
+    std::vector<std::string> mExt_dll_paths;
+    /// Temp directory for generated data
+    std::string mDefault_temp_dir;       
   };
-
-
+  
+  
 }// namespace bbtk
 
 
diff --git a/kernel/src/bbtkXML.h b/kernel/src/bbtkXML.h
new file mode 100644 (file)
index 0000000..ed46960
--- /dev/null
@@ -0,0 +1,30 @@
+#ifndef __bbtkXML_h_INCLUDED__
+#define __bbtkXML_h_INCLUDED__
+
+#include "xmlParser.h"
+
+
+namespace bbtk
+{
+  //====================================================================
+  inline bool GetTextOrClear(const XMLNode& node, std::string& var)
+  {
+    if (node.nText()>0) 
+      {
+       var = node.getText();
+       return true;
+      }
+    else if (node.nClear()>0) 
+      {
+       var = node.getClear().lpszValue;
+       return true;
+      }
+    else 
+      {
+       return false;
+      }
+  }
+  //====================================================================
+};
+
+#endif