]> Creatis software - bbtk.git/blob - src/bbstdExecBbiCommand.cxx
#3202 BBTK Feature New Normal - fast algorithm for ImageBoundaries box
[bbtk.git] / src / bbstdExecBbiCommand.cxx
1 /*
2  # ---------------------------------------------------------------------
3  #
4  # Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image
5  #                        pour la SantÈ)
6  # Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton
7  # Previous Authors : Laurent Guigues, Jean-Pierre Roux
8  # CreaTools website : www.creatis.insa-lyon.fr/site/fr/creatools_accueil
9  #
10  #  This software is governed by the CeCILL-B license under French law and
11  #  abiding by the rules of distribution of free software. You can  use,
12  #  modify and/ or redistribute the software under the terms of the CeCILL-B
13  #  license as circulated by CEA, CNRS and INRIA at the following URL
14  #  http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
15  #  or in the file LICENSE.txt.
16  #
17  #  As a counterpart to the access to the source code and  rights to copy,
18  #  modify and redistribute granted by the license, users are provided only
19  #  with a limited warranty  and the software's author,  the holder of the
20  #  economic rights,  and the successive licensors  have only  limited
21  #  liability.
22  #
23  #  The fact that you are presently reading this means that you have had
24  #  knowledge of the CeCILL-B license and that you accept its terms.
25  # ------------------------------------------------------------------------ */
26
27
28 /*=========================================================================
29   Program:   bbtk
30   Module:    $RCSfile: bbstdExecBbiCommand.cxx,v $
31   Language:  C++
32   Date:      $Date: 2012/11/16 08:51:32 $
33   Version:   $Revision: 1.12 $
34 =========================================================================*/
35
36
37
38 #include "bbstdExecBbiCommand.h"
39 #include "bbstdPackage.h"
40 #include "bbtkInterpreter.h"
41 #include "bbtkExecuter.h"
42
43 namespace bbstd
44 {
45
46   BBTK_ADD_BLACK_BOX_TO_PACKAGE(std,ExecBbiCommand);
47   BBTK_BLACK_BOX_IMPLEMENTATION(ExecBbiCommand,bbtk::AtomicBlackBox);
48
49   void ExecBbiCommand::bbUserSetDefaultValues() 
50   { 
51     bbSetInputIn("help");
52   }
53   void ExecBbiCommand::bbUserInitializeProcessing() 
54   { 
55   }
56   void ExecBbiCommand::bbUserFinalizeProcessing() 
57   {
58   }
59   
60   void ExecBbiCommand::DoProcess()
61     {
62
63       // Look for the interpreter
64       bbtk::Interpreter::Pointer I;
65           bool delete_inter = false;
66           if (bbGetParent() != 0)
67           {
68           bbtk::Factory::Pointer f
69                 = ((bbtk::ComplexBlackBoxDescriptor*)bbGetParent()
70                   ->bbGetDescriptor().get())->GetFactory();
71           if ((f != 0)&&
72               (f->GetExecuter()))
73             {
74               I = f->GetExecuter()->GetInterpreter();
75             }
76           }
77       if (I==0)
78           {
79           //      bbtkError("ExecBbiCommand::DoProcess() : could not find interpreter");
80           I = bbtk::Interpreter::New();
81           delete_inter = true;
82           }
83
84       unsigned int i;
85
86       bool ok=true;
87       int pos1=0,pos2;
88       pos2 = bbGetInputIn().find(";",pos1);
89       std::string ccommand;
90       while (ok==true)
91             {
92           if (pos2==-1) 
93            {
94             ok=false;
95             ccommand=bbGetInputIn().substr(pos1,bbGetInputIn().length()-pos1 );
96            } else {
97             ccommand=bbGetInputIn().substr(pos1,pos2-pos1);
98           }
99           for ( i=0 ; i < ccommand.length() ; i++)
100           {
101             if (ccommand[i]==39)
102             {
103                   ccommand[i]=34;
104         }
105      }
106
107           I->InterpretLine( ccommand );
108           pos1=pos2+1;
109           pos2 = bbGetInputIn().find(";",pos2+1);
110
111         }
112       
113 //      if (delete_inter) delete I;
114
115    /*  Grrr  not works in windows
116         char * pch;
117         pch = strtok (bbGetInputIn(),";");
118         while (pch != NULL)
119         {
120                 std::string ccommand(pch);
121                 printf("EED  ExecBbiCommand::DoProcess 1.1  %s\n",ccommand.c_str());
122                 for ( i=0 ; i < ccommand.length() ; i++)
123                 {
124                         if (ccommand[i]==39)
125                         {
126                                 ccommand[i]=34;
127                         }
128                 }
129
130                 printf("EED  ExecBbiCommand::DoProcess 2  %s\n",ccommand.c_str());
131                 bbtk::Interpreter::mGlobalInterpreter->InterpretLine( ccommand );
132         pch = strtok (NULL, ";");
133         }
134   */
135   }
136 } // EO namespace bbstd
137
138