[2220] | 1 |
|
---|
| 2 | // main genere automatiquement par xsl
|
---|
| 3 | // ne pas modifier
|
---|
| 4 | // derniere mise a jour : VF le 22/10/2002
|
---|
| 5 |
|
---|
| 6 | // inclusions expat
|
---|
| 7 | #include <stdio.h>
|
---|
| 8 | #include "expat.h"
|
---|
| 9 |
|
---|
| 10 | // inclusions c++
|
---|
| 11 | #include <string>
|
---|
| 12 | #include "config.h"
|
---|
| 13 | #include <map>
|
---|
| 14 | using namespace std;
|
---|
| 15 | #include <iostream.h>
|
---|
| 16 | #include "toi.h"
|
---|
| 17 | #include "toiprocessor.h"
|
---|
| 18 | #include "toimanager.h"
|
---|
| 19 | #include "toisegment.h"
|
---|
| 20 | #include "sophyainit.h"
|
---|
| 21 | #include <stdexcept>
|
---|
| 22 |
|
---|
| 23 | #ifndef MAXINT
|
---|
| 24 | #define MAXINT 2147483647
|
---|
| 25 | #endif
|
---|
| 26 |
|
---|
| 27 | #include "smoothtoi.h"
|
---|
| 28 | #include "demopipe.h"
|
---|
| 29 | #include "fitstoirdr.h"
|
---|
| 30 | #include "fitstoiwtr.h"
|
---|
| 31 |
|
---|
| 32 | // classe de gestion des balises en design patern object call-back
|
---|
| 33 | class ToiPipe
|
---|
| 34 | {
|
---|
| 35 | public:
|
---|
| 36 | ToiPipe(void);
|
---|
| 37 | virtual ~ToiPipe();
|
---|
| 38 | static void startElement(void *userData, const char *name, const char **atts);
|
---|
| 39 | static void endElement(void *userData, const char *name);
|
---|
| 40 | private:
|
---|
| 41 | // pour concordances instances - nom
|
---|
| 42 | map<string,TOIProcessor*> toiProc;
|
---|
| 43 | string id;
|
---|
| 44 | // gestionnaire de TOI
|
---|
| 45 | TOIManager* mgr;
|
---|
| 46 | void startElementC(const char *name, const char **atts);
|
---|
| 47 | void endElementC(const char *name);
|
---|
| 48 | };
|
---|
| 49 |
|
---|
| 50 |
|
---|
| 51 |
|
---|
| 52 | ToiPipe::ToiPipe()
|
---|
| 53 | {
|
---|
| 54 | // Ouverture du gestionnaire de TOI.
|
---|
| 55 | mgr = TOIManager::getManager();
|
---|
| 56 | // initialisation du processeur courant
|
---|
| 57 | id="";
|
---|
| 58 |
|
---|
| 59 | }
|
---|
| 60 |
|
---|
| 61 | ToiPipe::~ToiPipe()
|
---|
| 62 | {
|
---|
| 63 |
|
---|
| 64 | }
|
---|
| 65 |
|
---|
| 66 | void ToiPipe::startElement(void *userData, const char *name, const char **atts)
|
---|
| 67 | {
|
---|
| 68 | ToiPipe *toiPipe = (ToiPipe*) userData;
|
---|
| 69 | toiPipe->startElementC(name, atts);
|
---|
| 70 | }
|
---|
| 71 |
|
---|
| 72 | void ToiPipe::endElement(void *userData, const char *name)
|
---|
| 73 | {
|
---|
| 74 | ToiPipe* toiPipe = (ToiPipe*) userData;
|
---|
| 75 | toiPipe->endElementC(name);
|
---|
| 76 | }
|
---|
| 77 |
|
---|
| 78 |
|
---|
| 79 | void ToiPipe::startElementC(const char *name, const char **atts)
|
---|
| 80 | {
|
---|
| 81 | int i;
|
---|
| 82 | //puts(name);
|
---|
| 83 |
|
---|
| 84 | // filtrage des balises
|
---|
| 85 | if ((string)name == "connect") {
|
---|
| 86 | // mise en ordre des arguments
|
---|
| 87 | string nom;
|
---|
| 88 | TOIProcessor* procin=NULL;
|
---|
| 89 | TOIProcessor* procout=NULL;
|
---|
| 90 | string input;
|
---|
| 91 | string output;
|
---|
| 92 | int taille = 1024;
|
---|
| 93 | bool writeflag = false;
|
---|
| 94 | for (i=0; atts[i]; i+=2) {
|
---|
| 95 | if ((string)atts[i] == "name") {
|
---|
| 96 | nom=atts[i+1];
|
---|
| 97 | }
|
---|
| 98 | if ((string)atts[i] == "procin") {
|
---|
| 99 | map<string,TOIProcessor*>::iterator j=toiProc.find(atts[i+1]);
|
---|
| 100 | if (j != toiProc.end()) {
|
---|
| 101 | procin = (*j).second;
|
---|
| 102 | } else {
|
---|
| 103 | throw ParmError("Connect error: processor in not found");
|
---|
| 104 | }
|
---|
| 105 | }
|
---|
| 106 | if ((string)atts[i] == "procout") {
|
---|
| 107 | map<string,TOIProcessor*>::iterator j=toiProc.find(atts[i+1]);
|
---|
| 108 | if (j != toiProc.end()) {
|
---|
| 109 | procout = (*j).second;
|
---|
| 110 | } else {
|
---|
| 111 | throw ParmError("Connect error: processor out not found");
|
---|
| 112 | }
|
---|
| 113 | }
|
---|
| 114 | if ((string)atts[i] == "input") {
|
---|
| 115 | input = atts[i+1];
|
---|
| 116 | }
|
---|
| 117 | if ((string)atts[i] == "output") {
|
---|
| 118 | output = atts[i+1];
|
---|
| 119 | }
|
---|
| 120 | }
|
---|
| 121 | // connection automatique des toiprocesseurs
|
---|
| 122 | if (procin != NULL && procout != NULL ) {
|
---|
| 123 | cout << "connect " << output << " " << input << endl;
|
---|
| 124 | mgr->connect(*procout, output, *procin, input, nom, taille, writeflag);
|
---|
| 125 | cout << "connect done" << endl;
|
---|
| 126 | }
|
---|
| 127 |
|
---|
| 128 | } else if ((string)name == "constraint") { // si balise de contrainte
|
---|
| 129 | TOIProcessor* proc=NULL;
|
---|
| 130 | int min=0;
|
---|
| 131 | int max=MAXINT;
|
---|
| 132 | for (i=0; atts[i]; i+=2) {
|
---|
| 133 | if ((string)atts[i] =="proc") {
|
---|
| 134 | map<string,TOIProcessor*>::iterator j=toiProc.find(atts[i+1]);
|
---|
| 135 | if (j != toiProc.end()) {
|
---|
| 136 | proc = (*j).second;
|
---|
| 137 | } else {
|
---|
| 138 | throw ParmError("Constraint error: processor not found");
|
---|
| 139 | }
|
---|
| 140 | }
|
---|
| 141 | if ((string)atts[i] == "min") {
|
---|
| 142 | min = atoi(atts[i+1]);
|
---|
| 143 | }
|
---|
| 144 | if ((string)atts[i] == "max") {
|
---|
| 145 | max = atoi(atts[i+1]);
|
---|
| 146 | }
|
---|
| 147 | }
|
---|
| 148 | cout << "setting " << proc << " " << min << " " << max << endl;
|
---|
| 149 | proc->setRequestedSample(min, max);
|
---|
| 150 | cout << "constraint done" << endl;
|
---|
| 151 |
|
---|
| 152 | } else if ((string)name == "start") { // si balise de demarrage
|
---|
| 153 | cout << "***** Starting execution *****" << endl;
|
---|
| 154 | mgr->startAll();
|
---|
| 155 | // Gestion de la re-connection des threads
|
---|
| 156 | cout<<"***** Joining threads *****"<<endl;
|
---|
| 157 | mgr->joinAll();
|
---|
| 158 | cout<<"***** End threads *****"<<endl;
|
---|
| 159 | // destruction du toimanager et des processeurs a implementer dans toimanager pour l'utilisation de plusieurs start
|
---|
| 160 | //TOIManager::~toimanager();
|
---|
| 161 | //toiProc.clear();
|
---|
| 162 |
|
---|
| 163 | } else if (id == "") { // si nouveau processeur
|
---|
| 164 |
|
---|
| 165 | if ((string)name == "smooth") {
|
---|
| 166 | uint_4 lsm;
|
---|
| 167 | uint_4 deg;
|
---|
| 168 |
|
---|
| 169 |
|
---|
| 170 | // gestion des arguments du constructeur
|
---|
| 171 | for (i=0; atts[i]; i+=2) {
|
---|
| 172 | // var pour instanciation
|
---|
| 173 | if ((string)atts[i] == "id") {
|
---|
| 174 | id=atts[i+1];
|
---|
| 175 | }
|
---|
| 176 |
|
---|
| 177 | //initialisation des arguments par defaut si existants
|
---|
| 178 |
|
---|
| 179 |
|
---|
| 180 | // mise a jour des arguments
|
---|
| 181 |
|
---|
| 182 | if ((string)atts[i] == "lsm") {
|
---|
| 183 | lsm = atoi(atts[i+1]);
|
---|
| 184 |
|
---|
| 185 | }
|
---|
| 186 |
|
---|
| 187 | if ((string)atts[i] == "deg") {
|
---|
| 188 | deg = atoi(atts[i+1]);
|
---|
| 189 |
|
---|
| 190 | }
|
---|
| 191 |
|
---|
| 192 | }
|
---|
| 193 |
|
---|
| 194 | // creation du toiprocesseur
|
---|
| 195 | toiProc[id] = new DataSmooth (lsm, deg);
|
---|
| 196 | }
|
---|
| 197 |
|
---|
| 198 | if ((string)name == "demopipe") {
|
---|
| 199 |
|
---|
| 200 |
|
---|
| 201 | // gestion des arguments du constructeur
|
---|
| 202 | for (i=0; atts[i]; i+=2) {
|
---|
| 203 | // var pour instanciation
|
---|
| 204 | if ((string)atts[i] == "id") {
|
---|
| 205 | id=atts[i+1];
|
---|
| 206 | }
|
---|
| 207 |
|
---|
| 208 | //initialisation des arguments par defaut si existants
|
---|
| 209 |
|
---|
| 210 |
|
---|
| 211 | // mise a jour des arguments
|
---|
| 212 |
|
---|
| 213 | }
|
---|
| 214 |
|
---|
| 215 | // creation du toiprocesseur
|
---|
| 216 | toiProc[id] = new DemoPipe ();
|
---|
| 217 | }
|
---|
| 218 |
|
---|
| 219 | if ((string)name == "fitsreader") {
|
---|
| 220 | string fn;
|
---|
| 221 |
|
---|
| 222 |
|
---|
| 223 | // gestion des arguments du constructeur
|
---|
| 224 | for (i=0; atts[i]; i+=2) {
|
---|
| 225 | // var pour instanciation
|
---|
| 226 | if ((string)atts[i] == "id") {
|
---|
| 227 | id=atts[i+1];
|
---|
| 228 | }
|
---|
| 229 |
|
---|
| 230 | //initialisation des arguments par defaut si existants
|
---|
| 231 | fn = "test.fits";
|
---|
| 232 |
|
---|
| 233 |
|
---|
| 234 | // mise a jour des arguments
|
---|
| 235 |
|
---|
| 236 | if ((string)atts[i] == "fn") {
|
---|
| 237 | fn = atts[i+1];
|
---|
| 238 |
|
---|
| 239 | }
|
---|
| 240 |
|
---|
| 241 | }
|
---|
| 242 |
|
---|
| 243 | // creation du toiprocesseur
|
---|
| 244 | toiProc[id] = new FITSTOIReader (fn);
|
---|
| 245 | }
|
---|
| 246 |
|
---|
| 247 | if ((string)name == "fitswriter") {
|
---|
| 248 | string fn;
|
---|
| 249 |
|
---|
| 250 |
|
---|
| 251 | // gestion des arguments du constructeur
|
---|
| 252 | for (i=0; atts[i]; i+=2) {
|
---|
| 253 | // var pour instanciation
|
---|
| 254 | if ((string)atts[i] == "id") {
|
---|
| 255 | id=atts[i+1];
|
---|
| 256 | }
|
---|
| 257 |
|
---|
| 258 | //initialisation des arguments par defaut si existants
|
---|
| 259 |
|
---|
| 260 |
|
---|
| 261 | // mise a jour des arguments
|
---|
| 262 |
|
---|
| 263 | if ((string)atts[i] == "fn") {
|
---|
| 264 | fn = atts[i+1];
|
---|
| 265 |
|
---|
| 266 | }
|
---|
| 267 |
|
---|
| 268 | }
|
---|
| 269 |
|
---|
| 270 | // creation du toiprocesseur
|
---|
| 271 | toiProc[id] = new FITSTOIWriter (fn);
|
---|
| 272 | }
|
---|
| 273 |
|
---|
| 274 |
|
---|
| 275 | } else { // sinon c une methode
|
---|
| 276 | // gestion des methodes
|
---|
| 277 |
|
---|
| 278 | if (id == "smooth") {
|
---|
| 279 |
|
---|
| 280 | if ((string)name == "DoNotLookAt") {
|
---|
| 281 | uint_8 flag;
|
---|
| 282 |
|
---|
| 283 |
|
---|
| 284 | // gestion des arguments de la methode
|
---|
| 285 | for (i=0; atts[i]; i+=2) {
|
---|
| 286 | //initialisation des arguments par defaut si existants
|
---|
| 287 | flag = FlgToiAll;
|
---|
| 288 |
|
---|
| 289 |
|
---|
| 290 | // mise a jour des arguments
|
---|
| 291 |
|
---|
| 292 | if ((string)atts[i] == "flag") {
|
---|
| 293 | flag = atoi(atts[i+1]);
|
---|
| 294 |
|
---|
| 295 | }
|
---|
| 296 |
|
---|
| 297 | }
|
---|
| 298 |
|
---|
| 299 | // appelle de la methode du processeur concerne
|
---|
| 300 | ((DataSmooth*)toiProc[id])->DoNotLookAt (flag);
|
---|
| 301 | }
|
---|
| 302 |
|
---|
| 303 | if ((string)name == "SetFlagFailed") {
|
---|
| 304 | uint_8 flag;
|
---|
| 305 |
|
---|
| 306 |
|
---|
| 307 | // gestion des arguments de la methode
|
---|
| 308 | for (i=0; atts[i]; i+=2) {
|
---|
| 309 | //initialisation des arguments par defaut si existants
|
---|
| 310 | flag = FlgToiInterp;
|
---|
| 311 |
|
---|
| 312 |
|
---|
| 313 | // mise a jour des arguments
|
---|
| 314 |
|
---|
| 315 | if ((string)atts[i] == "flag") {
|
---|
| 316 | flag = atoi(atts[i+1]);
|
---|
| 317 |
|
---|
| 318 | }
|
---|
| 319 |
|
---|
| 320 | }
|
---|
| 321 |
|
---|
| 322 | // appelle de la methode du processeur concerne
|
---|
| 323 | ((DataSmooth*)toiProc[id])->SetFlagFailed (flag);
|
---|
| 324 | }
|
---|
| 325 |
|
---|
| 326 | if ((string)name == "SetBuff") {
|
---|
| 327 | uint_4 bupd;
|
---|
| 328 |
|
---|
| 329 |
|
---|
| 330 | // gestion des arguments de la methode
|
---|
| 331 | for (i=0; atts[i]; i+=2) {
|
---|
| 332 | //initialisation des arguments par defaut si existants
|
---|
| 333 | bupd = 100;
|
---|
| 334 |
|
---|
| 335 |
|
---|
| 336 | // mise a jour des arguments
|
---|
| 337 |
|
---|
| 338 | if ((string)atts[i] == "bupd") {
|
---|
| 339 | bupd = atoi(atts[i+1]);
|
---|
| 340 |
|
---|
| 341 | }
|
---|
| 342 |
|
---|
| 343 | }
|
---|
| 344 |
|
---|
| 345 | // appelle de la methode du processeur concerne
|
---|
| 346 | ((DataSmooth*)toiProc[id])->SetBuffUpd (bupd);
|
---|
| 347 | }
|
---|
| 348 |
|
---|
| 349 | if ((string)name == "MinSmoothLength") {
|
---|
| 350 | uint_4 lsmin;
|
---|
| 351 |
|
---|
| 352 |
|
---|
| 353 | // gestion des arguments de la methode
|
---|
| 354 | for (i=0; atts[i]; i+=2) {
|
---|
| 355 | //initialisation des arguments par defaut si existants
|
---|
| 356 | lsmin = 0;
|
---|
| 357 |
|
---|
| 358 |
|
---|
| 359 | // mise a jour des arguments
|
---|
| 360 |
|
---|
| 361 | if ((string)atts[i] == "lsmin") {
|
---|
| 362 | lsmin = atoi(atts[i+1]);
|
---|
| 363 |
|
---|
| 364 | }
|
---|
| 365 |
|
---|
| 366 | }
|
---|
| 367 |
|
---|
| 368 | // appelle de la methode du processeur concerne
|
---|
| 369 | ((DataSmooth*)toiProc[id])->MinSmoothLength (lsmin);
|
---|
| 370 | }
|
---|
| 371 |
|
---|
| 372 | }
|
---|
| 373 |
|
---|
| 374 | if (id == "demopipe") {
|
---|
| 375 |
|
---|
| 376 | }
|
---|
| 377 |
|
---|
| 378 | if (id == "fitsreader") {
|
---|
| 379 |
|
---|
| 380 | }
|
---|
| 381 |
|
---|
| 382 | if (id == "fitswriter") {
|
---|
| 383 |
|
---|
| 384 | }
|
---|
| 385 |
|
---|
| 386 |
|
---|
| 387 | }
|
---|
| 388 |
|
---|
| 389 | }
|
---|
| 390 |
|
---|
| 391 |
|
---|
| 392 | void ToiPipe::endElementC(const char *name)
|
---|
| 393 | {
|
---|
| 394 | // verification si une balise processeur est fermee pour la gestion des methodes d'initialisation
|
---|
| 395 |
|
---|
| 396 | if ((string)name == "smooth") {
|
---|
| 397 | id="";
|
---|
| 398 | }
|
---|
| 399 |
|
---|
| 400 | if ((string)name == "demopipe") {
|
---|
| 401 | id="";
|
---|
| 402 | }
|
---|
| 403 |
|
---|
| 404 | if ((string)name == "fitsreader") {
|
---|
| 405 | id="";
|
---|
| 406 | }
|
---|
| 407 |
|
---|
| 408 | if ((string)name == "fitswriter") {
|
---|
| 409 | id="";
|
---|
| 410 | }
|
---|
| 411 |
|
---|
| 412 |
|
---|
| 413 | // execution du pipeline
|
---|
| 414 | if ((string)name == "toipipe") {
|
---|
| 415 | cout << "***** Starting execution *****" << endl;
|
---|
| 416 | mgr->startAll();
|
---|
| 417 | // Gestion de la re-connection des threads
|
---|
| 418 | cout<<"***** Joining threads *****"<<endl;
|
---|
| 419 | mgr->joinAll();
|
---|
| 420 | cout<<"***** End threads *****"<<endl;
|
---|
| 421 | }
|
---|
| 422 | }
|
---|
| 423 |
|
---|
| 424 |
|
---|
| 425 | int main(int argc, char *argv[])
|
---|
| 426 | {
|
---|
| 427 | char buf[BUFSIZ];
|
---|
| 428 | XML_Parser parser = XML_ParserCreate(NULL);
|
---|
| 429 | int done;
|
---|
| 430 | FILE* fich=fopen(argv[1],"r");
|
---|
| 431 |
|
---|
| 432 | ToiPipe* toiPipe = new ToiPipe();
|
---|
| 433 |
|
---|
| 434 | // Initialisation de Sophya
|
---|
| 435 | SophyaInit();
|
---|
| 436 | cout << "-- Application start --" << endl;
|
---|
| 437 | XML_SetUserData(parser, toiPipe);
|
---|
| 438 | XML_SetElementHandler(parser, ToiPipe::startElement, ToiPipe::endElement);
|
---|
| 439 | if (fich != NULL) {
|
---|
| 440 | cout << "-- Reading file --" << endl;
|
---|
| 441 | // traitement des balises
|
---|
| 442 | do {
|
---|
| 443 | try {
|
---|
| 444 | size_t len = fread(buf, 1, sizeof(buf), fich);
|
---|
| 445 | done = len < sizeof(buf);
|
---|
| 446 | if (!XML_Parse(parser, buf, len, done)) {
|
---|
| 447 | fprintf(stderr,
|
---|
| 448 | "%s at line %d\n",
|
---|
| 449 | XML_ErrorString(XML_GetErrorCode(parser)),
|
---|
| 450 | XML_GetCurrentLineNumber(parser));
|
---|
| 451 | return 1;
|
---|
| 452 | }
|
---|
| 453 | } catch (PThrowable & exc) { // Sophya exceptions
|
---|
| 454 | cout << "\ntstdemopipe: Catched Exception \n" << (string)typeid(exc).name()
|
---|
| 455 | << " - Msg= " << exc.Msg() << endl;
|
---|
| 456 | } catch (const std::exception & sex) { // Standard exceptions
|
---|
| 457 | cout << "\ntstdemopipe: Catched std::exception \n"
|
---|
| 458 | << (string)typeid(sex).name() << endl;
|
---|
| 459 | } catch (...) { // Other exceptions
|
---|
| 460 | cout << "\ntstdemopipe: some other exception was caught ! " << endl;
|
---|
| 461 | }
|
---|
| 462 | } while (!done);
|
---|
| 463 | XML_ParserFree(parser);
|
---|
| 464 | fclose(fich);
|
---|
| 465 | } else {
|
---|
| 466 | fprintf(stderr,"file not found");
|
---|
| 467 | return 1;
|
---|
| 468 | }
|
---|
| 469 | return(0);
|
---|
| 470 | }
|
---|
| 471 |
|
---|