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
#include <cstdlib>
#include <iostream>
#include <string>

#include "DetectorDescription/Core/interface/DDCompactView.h"
#include "DetectorDescription/Parser/interface/DDLParser.h"
#include "DetectorDescription/Parser/interface/DDLSAX2FileHandler.h"
#include "DetectorDescription/Parser/interface/FIPConfiguration.h"
#include "DetectorDescription/RegressionTest/interface/DDErrorDetection.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"
#include "FWCore/PluginManager/interface/PluginManager.h"
#include "FWCore/PluginManager/interface/standard.h"
#include "FWCore/Utilities/interface/Exception.h"
#include <boost/program_options.hpp>
#include <boost/exception/diagnostic_information.hpp>

int main(int argc, char* argv[]) {
  try {
    edmplugin::PluginManager::configure(edmplugin::standard::config());
  } catch (cms::Exception& e) {
    edm::LogInfo("DDErrorReport") << "Attempting to configure the plugin manager. Exception message: " << e.what();
    return 1;
  }

  // Process the command line arguments
  std::string descString("DDErrorReport");
  descString += " [options] configurationFileName\n";
  descString += "Allowed options";
  boost::program_options::options_description desc(descString);
  desc.add_options()("help,h", "Print this help message")(
      "file,f",
      boost::program_options::value<std::string>(),
      "XML configuration file name. "
      "Default is DetectorDescription/RegressionTest/test/configuration.xml")("path,p",
                                                                              "Specifies filename is a full path and "
                                                                              "not to use FileInPath to find file. "
                                                                              " This option is ignored if a filename "
                                                                              "is not specified");

  boost::program_options::positional_options_description p;
  p.add("file", -1);

  boost::program_options::variables_map vm;
  try {
    store(boost::program_options::command_line_parser(argc, argv).options(desc).positional(p).run(), vm);
    notify(vm);
  } catch (boost::program_options::error const& iException) {
    std::cerr << "Exception from command line processing: " << iException.what() << "\n";
    std::cerr << desc << std::endl;
    return 1;
  }

  if (vm.count("help")) {
    std::cout << desc << std::endl;
    return 0;
  }

  bool fullPath = false;
  std::string configfile("DetectorDescription/RegressionTest/test/configuration.xml");
  try {
    if (vm.count("file")) {
      configfile = vm["file"].as<std::string>();
      if (vm.count("path")) {
        fullPath = true;
      }
    }
  } catch (boost::exception& e) {
    edm::LogInfo("DDErrorReport") << "Attempting to parse the options. Exception message: "
                                  << boost::diagnostic_information(e);
    return 1;
  }

  DDCompactView cpv;
  DDLParser myP(cpv);
  myP.getDDLSAX2FileHandler()->setUserNS(false);

  /* 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).
    */

  // Use the File-In-Path configuration document provider.
  FIPConfiguration fp(cpv);
  try {
    fp.readConfig(configfile, fullPath);
  } catch (cms::Exception& e) {
    edm::LogInfo("DDErrorReport") << "Attempting to read config. Exception message: " << e.what();
    return 1;
  }

  int parserResult = myP.parse(fp);
  if (parserResult != 0) {
    std::cout << " problem encountered during parsing. exiting ... " << std::endl;
    exit(1);
  }
  std::cout << "Parsing completed. Start checking for errors." << std::endl;

  DDErrorDetection ed(cpv);

  bool noErrors = ed.noErrorsInTheReport(cpv);
  if (noErrors && fullPath) {
    std::cout << "DDErrorReport did not find any errors and is finished." << std::endl;
  } else {
    ed.report(cpv, std::cout);
    if (!noErrors) {
      return 1;
    }
  }
  return 0;
}