]> Creatis software - bbtk.git/blobdiff - kernel/src/bbtkWxGUIScriptingInterface.cxx
Feature #1774
[bbtk.git] / kernel / src / bbtkWxGUIScriptingInterface.cxx
index fd43191ca23f7d87f002f54782ba81876788450f..9e8e57dbe5732772b25494f9ad15dfa167bccf49 100644 (file)
@@ -1,32 +1,39 @@
-/*=========================================================================                                                                               
+/*
+ # ---------------------------------------------------------------------
+ #
+ # Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image
+ #                        pour la SantÈ)
+ # Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton
+ # Previous Authors : Laurent Guigues, Jean-Pierre Roux
+ # CreaTools website : www.creatis.insa-lyon.fr/site/fr/creatools_accueil
+ #
+ #  This software is governed by the CeCILL-B license under French law and
+ #  abiding by the rules of distribution of free software. You can  use,
+ #  modify and/ or redistribute the software under the terms of the CeCILL-B
+ #  license as circulated by CEA, CNRS and INRIA at the following URL
+ #  http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
+ #  or in the file LICENSE.txt.
+ #
+ #  As a counterpart to the access to the source code and  rights to copy,
+ #  modify and redistribute granted by the license, users are provided only
+ #  with a limited warranty  and the software's author,  the holder of the
+ #  economic rights,  and the successive licensors  have only  limited
+ #  liability.
+ #
+ #  The fact that you are presently reading this means that you have had
+ #  knowledge of the CeCILL-B license and that you accept its terms.
+ # ------------------------------------------------------------------------ */
+
+
+/*=========================================================================
   Program:   bbtk
   Module:    $RCSfile: bbtkWxGUIScriptingInterface.cxx,v $
   Language:  C++
-  Date:      $Date: 2010/03/19 08:18:41 $
-  Version:   $Revision: 1.42 $
+  Date:      $Date: 2012/11/16 08:49:01 $
+  Version:   $Revision: 1.49 $
 =========================================================================*/
 
-/* ---------------------------------------------------------------------
-
-* Copyright (c) CREATIS-LRMN (Centre de Recherche en Imagerie Medicale)
-* Authors : Eduardo Davila, Laurent Guigues, Jean-Pierre Roux
-*
-*  This software is governed by the CeCILL-B license under French law and 
-*  abiding by the rules of distribution of free software. You can  use, 
-*  modify and/ or redistribute the software under the terms of the CeCILL-B 
-*  license as circulated by CEA, CNRS and INRIA at the following URL 
-*  http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html 
-*  or in the file LICENSE.txt.
-*
-*  As a counterpart to the access to the source code and  rights to copy,
-*  modify and redistribute granted by the license, users are provided only
-*  with a limited warranty  and the software's author,  the holder of the
-*  economic rights,  and the successive licensors  have only  limited
-*  liability. 
-*
-*  The fact that you are presently reading this means that you have had
-*  knowledge of the CeCILL-B license and that you accept its terms.
-* ------------------------------------------------------------------------ */                                                                         
+
    
 
 /**
@@ -54,6 +61,8 @@
 #include "bbtkWxStreamRedirector.h"
 #include "bbtkUtilities.h"
 
+#include "creaWx.h"
+
 #include <wx/tipwin.h>
 #include <wx/splash.h>
 
@@ -110,13 +119,13 @@ namespace bbtk
     menuAbout->Append( ID_Menu_About, _T("&About...") );
 
     wxMenu *menuTools = new wxMenu;
-    menuTools->Append( ID_Menu_CreatePackage, _T("Create &package") );
+    menuTools->Append( ID_Menu_CreatePackage,  _T("Create &package") );
     menuTools->Append( ID_Menu_CreateBlackBox, _T("Create &black box") );
-    menuTools->Append( ID_Menu_PlugPackage, _T("&Plug package") );
+    menuTools->Append( ID_Menu_PlugPackage,    _T("&Plug package") );
     menuTools->AppendSeparator();
     menuTools->Append( ID_Menu_RegeneratePackageDoc,_T("Regenerate package &doc") );
     menuTools->Append( ID_Menu_RegenerateBoxesLists,_T("Regenerate boxes &lists") );
-    menuTools->Append( ID_Menu_RegenerateAll,_T("Regenerate &all") );
+    menuTools->Append( ID_Menu_RegenerateAll,       _T("Regenerate &all") );
     menuTools->AppendSeparator();
     menuTools->Append( ID_Menu_ShowImageGraph, _T("&Show last graph") );
 
@@ -281,8 +290,7 @@ namespace bbtk
                           style,
                           1000, 0, -1, wxDefaultPosition, wxDefaultSize,
                           wxSIMPLE_BORDER|wxSTAY_ON_TOP);
-       
-    
+
     if (ConfigurationFile::GetInstance().DotBbtkIsNew())
       {
 
@@ -441,14 +449,24 @@ namespace bbtk
          std::string filename = dir + separator + "tmp_bbtk.bbs";
          mWxGUITextEditor->GetCurrentPage()->SaveFile(filename);
        
-               std::string command = "\"\"";
+       std::string command = "\"";
+
+#ifdef WIN32
+       command += "\"";
+#endif
+
          command += ConfigurationFile::GetInstance().Get_bin_path();
 #ifdef MACOSX
          command += separator + "bbi.app/Contents/MacOS/bbi\" ";
 #else 
-         command += separator + "bbi.exe\" ";
+         command += separator + "bbi\" ";
+#endif
+         command += "\""+filename + "\"";
+
+#ifdef WIN32
+       command += "\"";
 #endif
-         command += "\""+filename + "\"\"";
+
          command += " & ";
          
          printf ("EED WxGUIScriptingInterface::WxGUITextEditorRunBBI %s \n" , command.c_str() );
@@ -496,7 +514,7 @@ namespace bbtk
   {
     m_mgr.Update();
     Refresh();
-    wxMessageBox(_T("  bbStudio\nThe Black Box Toolkit Development Studio\n(c) CREATIS-LRMN 2008\n\n http://www.creatis.insa-lyon.fr/creatools"),
+    wxMessageBox(_T("  bbStudio\nThe Black Box Toolkit Development Studio\n(c) CREATIS 2008\n\n http://www.creatis.insa-lyon.fr/site/en/CreaTools_home"),
                  _T("About ..."), wxOK | wxICON_INFORMATION,
                  this);
   }
@@ -563,7 +581,6 @@ namespace bbtk
     command = "include toolsbbtk/appli/GUICreatePackage";
     bbtkMessage("Debug",1,"Executing : '"<<command<<"'"<<std::endl);
        mWxGUICommand->SendCommand(command);
-
   }
   //================================================================
 
@@ -596,8 +613,7 @@ namespace bbtk
       doc_path += bbtk::ConfigurationFile::GetInstance().Get_file_separator();
          
          std::string pack_name("User");
-         std::string pack_path = doc_path + pack_name;
-         
+         std::string pack_path = doc_path + pack_name;   
          
 #if defined(WIN32)
     std::string strappli="start ";
@@ -607,8 +623,7 @@ namespace bbtk
   #else
       std::string strappli="gnome-open ";        
   #endif
-#endif
-         
+#endif   
          std::string strcommand = strappli +pack_path+"/workspace_workspacePrototype.png";
     // std::cout << "system: " << strcommand << std::endl;
     system ( strcommand.c_str() );
@@ -659,9 +674,6 @@ namespace bbtk
        err +=  bbtk::std2wx(command) + _T("'");
        wxMessageBox(err,_T("Regenerate package doc"),wxOK | wxICON_ERROR);      
       }
-
-
-
   }
 
 
@@ -698,6 +710,7 @@ namespace bbtk
        command += " -q";
        bbtkMessage("debug",1,"Executing system command '"<<command<<"'"<<std::endl);
 
+std::cout << "==========================================================================================================" << command.c_str() << std::endl;
     if ( ! system ( command.c_str() ) )
       {
        SetStatusText( _T("Done !"));
@@ -735,39 +748,62 @@ namespace bbtk
 
  
   //================================================================
+  /**
+   * Event Handler for the plug package menu.
+   * This method prompts the user for the directory where the bbtkPackage file is
+   * located and associates the related package with the configuration file.
+   * @param event event not used.
+   */
+
+  //DFGO - 8/10/2012
   void WxGUIScriptingInterface::OnMenuPlugPackage(wxCommandEvent& WXUNUSED(event))
   {
     long style = wxDD_DEFAULT_STYLE | wxDD_DIR_MUST_EXIST;
-    wxDirDialog* FD = 
-      new wxDirDialog( 0, 
+    wxDirDialog* FD =
+      new wxDirDialog( 0,
                       _T("Select package directory"),
                       _T(""),
                       style);
-    
-    if (FD->ShowModal()==wxID_OK)
-      {
-       std::string path = wx2std (FD->GetPath()) ;
-       std::string fname = path + "/bbtkPackage"; 
-       if ( ! Utilities::FileExists( fname ) )
-         {
-           wxString err(_T("The directory does not contain a 'bbtkPackage' file"));
-           wxMessageBox(err,_T("Plug package"),wxOK | wxICON_ERROR);      
-           return;
-         }
-       
-       std::ifstream f;
-       f.open(fname.c_str());
-       std::string pname;
-       f >> pname;
-       f.close();
-       
-       
-       bbtk::ConfigurationFile::GetInstance().AddPackagePathsAndWrite( path );
-       
-       DoRegeneratePackageDoc(pname);
-       DoRegenerateBoxesLists();
+    long userResponse;
+    do
+    {
+       userResponse = FD->ShowModal();
+       if(userResponse==wxID_OK)
+       {
+                       std::string path = wx2std (FD->GetPath()) ;
+                       std::string fname = path + "/bbtkPackage";
+                       std::cout << "Path chosen = \"" << FD->GetPath() << "\"" << std::endl;
+                       if ( Utilities::FileExists( fname ) )
+                       {
+                               std::ifstream f;
+                               f.open(fname.c_str());
+                               std::string pname;
+                               f >> pname;
+                               f.close();
+
+                               bbtk::ConfigurationFile::GetInstance().AddPackagePathsAndWrite( path );
 
-         }     
+                               DoRegeneratePackageDoc(pname);
+                               DoRegenerateBoxesLists();
+
+                               wxMessageBox(_T("Package successfully plugged"),_T("Plug package"),wxOK | wxICON_INFORMATION);
+
+                               userResponse = wxID_CANCEL;
+                       }
+                       else
+                       {
+                               std::string err = "The directory \"" + path + "\" does not contain a 'bbtkPackage' file.";
+                               #ifndef WIN32
+                                       #ifndef MACOSX
+                                               err += "\nNote: If you are on Linux please select the folder and click \"Open\", don't enter in it.";
+                                       #endif
+                               #endif
+
+
+                               wxMessageBox(crea::std2wx(err),_T("Plug package"),wxOK | wxICON_ERROR);
+                       }
+       }
+    }while(userResponse != wxID_CANCEL);
   }
   //================================================================
 
@@ -803,9 +839,9 @@ namespace bbtk
   {
     size_t s = target.length();
     if ((s>3) && (target[s-1]=='s')
-               && (target[s-2]=='b')
-               && (target[s-3]=='b')
-               && (target[s-4]=='.'))
+              && (target[s-2]=='b')
+              && (target[s-3]=='b')
+              && (target[s-4]=='.'))
        {
                        mWxGUITextEditor->Open(target);
                        #if NOTEBOOK
@@ -816,9 +852,9 @@ namespace bbtk
        }
 
        if ((s>3) && (target[s-1]=='f')
-               && (target[s-2]=='d')
-               && (target[s-3]=='p')
-               && (target[s-4]=='.'))
+                 && (target[s-2]=='d')
+                 && (target[s-3]=='p')
+                 && (target[s-4]=='.'))
        {
 
                // Open pdf in linux
@@ -863,7 +899,6 @@ namespace bbtk
       }
   }
 
-
   //================================================================  
   void WxGUIScriptingInterface::OnMenuWindowsFiles(wxCommandEvent& event)
   {