Specific

Macros

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
#ifndef DDI_Specific_h
#define DDI_Specific_h

#include <iostream>
#include <string>
#include <utility>
#include <vector>

#include "DetectorDescription/Core/interface/DDExpandedView.h"
#include "DetectorDescription/Core/interface/DDLogicalPart.h"
#include "DetectorDescription/Core/interface/DDPartSelection.h"
#include "DetectorDescription/Core/interface/DDsvalues.h"

class DDExpandedView;
class DDLogicalPart;
class DDPartSelection;

namespace DDI {

  class Specific {
  public:
    Specific(const std::vector<std::string> &selections, const DDsvalues_type &specs, bool doRegex = true);

    Specific(const std::vector<DDPartSelection> &selections, const DDsvalues_type &specs);

    const std::vector<DDPartSelection> &selection() const;

    void updateLogicalPart(
        std::vector<std::pair<DDLogicalPart, std::pair<const DDPartSelection *, const DDsvalues_type *> > > &) const;

    void tokenize();

    const DDsvalues_type &specifics() const { return specifics_; }

    //! gives the geometrical history of a fully specified PartSelector
    std::pair<bool, DDExpandedView> node() const;

    void stream(std::ostream &) const;

  protected:
    void createPartSelections(const std::string &selString);
    void addSelectionLevel(std::vector<DDLogicalPart> &lpv,
                           int copyno,
                           ddselection_type st,
                           std::vector<DDPartSelection> &selv);
    DDsvalues_type specifics_;
    std::vector<DDPartSelection> partSelections_;
    bool valid_;
    bool doRegex_;
  };
}  // namespace DDI

#endif  // DDI_Specific_h