Version: 8.3.0
debugger.cxx File Reference
#include "RuntimeSALOME.hxx"
#include "Proc.hxx"
#include "Exception.hxx"
#include "Executor.hxx"
#include "parsers.hxx"
#include "Thread.hxx"
#include <iostream>
#include <fstream>
#include "YacsTrace.hxx"
Include dependency graph for debugger.cxx:

Go to the source code of this file.

Functions

void * executorFunc (void *arg)
 
int main (int argc, char *argv[])
 

Function Documentation

void* executorFunc ( void *  arg)

Definition at line 40 of file debugger.cxx.

References YACS::ENGINE::Executor::RunB().

Referenced by main().

41 {
42  void **argT=(void **)arg;
43  Executor *myExec = (Executor *)argT[0];
44  Proc *myProc = (Proc *)argT[1];
45  myExec->RunB(myProc, 2);
46  return 0;
47 }
int main ( int  argc,
char *  argv[] 
)

Definition at line 50 of file debugger.cxx.

References DEBTRACE, YACS::ENGINE::Executor::displayDot(), executorFunc(), gui.CONNECTOR::f(), YACS::ENGINE::Executor::getExecutorState(), YACS::ENGINE::Executor::isNotFinished(), YACS::YACSLoader::load(), loader, p, YACS::ENGINE::Executor::resumeCurrentBreakPoint(), YACS::ENGINE::Executor::setExecMode(), YACS::STEPBYSTEP, YACS::Exception::what(), and YACS::ENGINE::Proc::writeDot().

51 {
52  if (argc != 2)
53  {
54  cerr << "usage: " << argv[0] << " schema.xml" << endl;
55  return 1;
56  }
57 
58  RuntimeSALOME::setRuntime();
59 
61  Executor *executor = new Executor();
62 
63  try
64  {
65  Proc* p=loader.load(argv[1]);
66  std::ofstream f("toto");
67  p->writeDot(f);
68  f.close();
69 
70  executor->setExecMode(YACS::STEPBYSTEP);
71  void **args=new void *[2];
72  args[0]=(void *)executor;
73  args[1]=(void *)p;
74  Thread* execThread = new Thread(executorFunc,args);
75  char com;
76  cerr << "enter a char to start" << endl;
77  cin >> com;
78  //executor->wakeUp();
79  while (executor->isNotFinished())
80  {
81  YACS::ExecutorState executorState = executor->getExecutorState();
82  cerr << "executorState: " << executorState << endl;
83  cerr << "command display=d step=s : ";
84  cin >> com;
85  switch (com)
86  {
87  case 's':
88  {
89  executor->setExecMode(YACS::STEPBYSTEP);
90  bool res = executor->resumeCurrentBreakPoint();
91  cerr << "resumeCurrentBreakPoint(): " << res << endl;
92  break;
93  }
94  case 'd':
95  {
96  executor->displayDot(p);
97  break;
98  }
99  default:
100  {
101  cerr << "commande inconnue" << endl;
102  }
103  }
104  }
105  execThread->join();
106  std::ofstream g("titi");
107  p->writeDot(g);
108  g.close();
109  delete executor;
110  return 0;
111  }
112  catch (YACS::Exception& e)
113  {
114  DEBTRACE("exception YACS levee " << e.what());
115  return 1;
116  }
117  catch (const std::ios_base::failure&)
118  {
119  DEBTRACE("io failure");
120  return 1;
121  }
122  catch(CORBA::SystemException& ex)
123  {
124  DEBTRACE("...");
125  CORBA::Any tmp;
126  tmp <<= ex;
127  CORBA::TypeCode_var tc = tmp.type();
128  const char *p = tc->name();
129  if ( *p != '\0' )
130  {
131  DEBTRACE("Caught a CORBA::SystemException. " <<p);
132  }
133  else
134  {
135  DEBTRACE("Caught a CORBA::SystemException. " << tc->id());
136  }
137  return 1;
138  }
139  catch(omniORB::fatalException& fe)
140  {
141  DEBTRACE("Caught omniORB::fatalException: file: "<<fe.file()<<" line: "<<fe.line()<<" msg: "<<fe.errmsg());
142  return 1;
143  }
144  catch(...)
145  {
146  DEBTRACE("Caught unknown exception.");
147  return 1;
148  }
149 }