LogicalPart

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

#include <iostream>
#include <map>
#include <utility>
#include <vector>

#include "DetectorDescription/Core/interface/DDEnums.h"
#include "DetectorDescription/Core/interface/DDMaterial.h"
#include "DetectorDescription/Core/interface/DDSolid.h"
#include "DetectorDescription/Core/interface/DDValue.h"
#include "DetectorDescription/Core/interface/DDsvalues.h"

class DDPartSelection;

namespace DDI {
  class LogicalPart {
  public:
    LogicalPart(const DDMaterial &, const DDSolid &, DDEnums::Category = DDEnums::unspecified);
    const DDMaterial &material() const;
    const DDSolid &solid() const;
    DDEnums::Category category() const;
    std::vector<const DDsvalues_type *> specifics() const;
    void specificsV(std::vector<const DDsvalues_type *> &result) const;
    DDsvalues_type mergedSpecifics() const;
    void mergedSpecificsV(DDsvalues_type &res) const;
    void addSpecifics(const std::pair<const DDPartSelection *, const DDsvalues_type *> &);
    void removeSpecifics(const std::pair<const DDPartSelection *, const DDsvalues_type *> &);
    const std::vector<std::pair<const DDPartSelection *, const DDsvalues_type *> > &attachedSpecifics() const {
      return specifics_;
    }
    bool hasDDValue(const DDValue &) const;
    //const std::vector<DDPartSelection*> & partSelections(const DDValue &) const;
    void stream(std::ostream &);

  private:
    DDMaterial material_;
    DDSolid solid_;
    DDEnums::Category cat_;

    std::map<DDValue, std::vector<DDPartSelection *> > valToParsel_;
    std::vector<std::pair<const DDPartSelection *, const DDsvalues_type *> > specifics_;
    std::vector<bool> hasDDValue_;
  };
}  // namespace DDI
#endif