Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115
#include <cstdlib>
#include <exception>
#include <iostream>
#include <string>
#include <utility>
#include <vector>

#include "DetectorDescription/Core/interface/DDBase.h"
#include "DetectorDescription/Core/interface/DDCompactView.h"
#include "DetectorDescription/Core/interface/DDConstant.h"
#include "DetectorDescription/Core/interface/DDVector.h"
#include "DetectorDescription/Parser/interface/DDLParser.h"
#include "DetectorDescription/Parser/interface/FIPConfiguration.h"
#include "DetectorDescription/RegressionTest/interface/DDErrorDetection.h"
#include "FWCore/Utilities/interface/Exception.h"

using namespace std;
namespace DD {}
using namespace DD;

int main(int argc, char* argv[]) {
  std::string const kProgramName = argv[0];
  int rc = 0;

  try {
    // Initialize a DDL Schema aware parser for DDL-documents
    // (DDL ... Detector Description Language)
    cout << "initialize DDL parser" << endl;
    DDCompactView cpv;
    DDLParser myP(cpv);

    /* The configuration file tells the parser what to parse.
       The sequence of files to be parsed does not matter but for one exception:
       XML containing SpecPar-tags must be parsed AFTER all corresponding
       PosPart-tags were parsed. (Simply put all SpecPars-tags into seperate
       files and mention them at end of configuration.xml. Functional SW 
       will not suffer from this restriction).
    */

    cout << "about to start parsing" << endl;
    string configfile("DetectorDescription/RegressionTest/test/configuration.xml");
    if (argc == 2) {
      configfile = argv[1];
    }

    FIPConfiguration fp(cpv);
    fp.readConfig(configfile);
    int parserResult = myP.parse(fp);
    cout << "done parsing" << std::endl;
    cout.flush();
    if (parserResult != 0) {
      cout << " problem encountered during parsing. exiting ... " << endl;
      exit(1);
    }
    cout << "parsing completed" << endl;

    cout << endl << endl << "Start checking!" << endl << endl;

    DDErrorDetection ed(cpv);
    ed.report(cpv, std::cout);

    DDConstant::iterator<DDConstant> cit(DDConstant::begin()), ced(DDConstant::end());
    for (; cit != ced; ++cit) {
      cout << *cit << endl;
    }

    std::vector<std::string> vnames;
    DDVector::iterator<DDVector> vit;
    DDVector::iterator<DDVector> ved(DDVector::end());
    if (vit == ved)
      std::cout << "No DDVectors found." << std::endl;
    for (; vit != ved; ++vit) {
      if (vit->isDefined().second) {
        std::cout << vit->toString() << std::endl;
        {
          DDName vname(vit->name());
          vnames.emplace_back(vname.name());
        }
        const std::vector<double>& tv = *vit;
        std::cout << "size: " << tv.size() << std::endl;
        for (double i : tv) {
          std::cout << i << "\t";
        }
        std::cout << std::endl;
      }
    }

    //This forces the 'vector' to be filled
    cpv.lockdown();
    for (const auto& it : vnames) {
      std::cout << it << std::endl;
      auto v = cpv.vector(it);
      std::cout << "size: " << v.size() << std::endl;
      for (double i : v) {
        std::cout << i << "\t";
      }
      std::cout << std::endl;
    }

    return 0;
  }
  //  Deal with any exceptions that may have been thrown.
  catch (cms::Exception& e) {
    std::cout << "cms::Exception caught in " << kProgramName << "\n" << e.explainSelf();
    rc = 1;
  } catch (std::exception& e) {
    std::cout << "Standard library exception caught in " << kProgramName << "\n" << e.what();
    rc = 1;
  } catch (...) {
    std::cout << "Unknown exception caught in " << kProgramName;
    rc = 2;
  }

  return rc;
}