22 #ifndef ASTSHIM_CMPMAP_H
23 #define ASTSHIM_CMPMAP_H
29 #include "astshim/base.h"
30 #include "astshim/detail/utils.h"
31 #include "astshim/Mapping.h"
74 :
Mapping(reinterpret_cast<AstMapping *>(astCmpMap(const_cast<AstObject *>(map1.
getRawPtr()),
75 const_cast<AstObject *>(map2.
getRawPtr()),
76 series,
"%s", options.c_str()))) {}
94 std::shared_ptr<Mapping>
operator[](
int i)
const {
return decompose<Mapping>(i,
false); };
102 explicit CmpMap(AstCmpMap *rawptr) :
Mapping(reinterpret_cast<AstMapping *>(rawptr)) {
104 std::ostringstream os;
105 os <<
"this is a " <<
getClassName() <<
", which is not a CmpMap";
106 throw std::invalid_argument(os.str());
virtual std::shared_ptr< Object > copyPolymorphic() const override
Definition: Mapping.h:403
std::shared_ptr< CmpMap > copy() const
Return a deep copy of this object.
Definition: CmpMap.h:86
AstObject const * getRawPtr() const
Definition: Object.h:286
bool getSeries()
Return True if the map is in series.
Definition: CmpMap.h:97
CmpMap(Mapping const &map1, Mapping const &map2, bool series, std::string const &options="")
Definition: CmpMap.h:73
std::string getClassName() const
Definition: Object.h:133
std::shared_ptr< Mapping > operator[](int i) const
Definition: CmpMap.h:94
CmpMap(AstCmpMap *rawptr)
Definition: CmpMap.h:102