LSST Applications 29.1.0,g0fba68d861+6b120c4394,g123d84c11c+8c5ae1fdc5,g1ec0fe41b4+191117f6ec,g1fd858c14a+c8450ae71a,g3533f9d6cb+a04f9ee0ab,g35bb328faa+8c5ae1fdc5,g3f0dcc2b1b+7df08700bd,g4178042926+b4254969db,g44ba364a48+04455b336b,g53246c7159+8c5ae1fdc5,g60b5630c4e+a04f9ee0ab,g663da51e9b+b05e6e1875,g67b6fd64d1+250bf6acd3,g78460c75b0+7e33a9eb6d,g786e29fd12+668abc6043,g8352419a5c+8c5ae1fdc5,g87e3079a85+d3fa38de54,g8852436030+cd899e2626,g89139ef638+250bf6acd3,g93a033419f+31ead11197,g989de1cb63+250bf6acd3,g9f33ca652e+f6053ecf14,ga1e959baac+5fbc491aed,ga2f891cd6c+a04f9ee0ab,gabe3b4be73+8856018cbb,gabf8522325+1f7e6d67b9,gac2eed3f23+250bf6acd3,gb1101e3267+0c331e9486,gb89ab40317+250bf6acd3,gcf25f946ba+cd899e2626,gd107969129+8964d67276,gd6cbbdb0b4+6bbecc8878,gde0f65d7ad+d65f9e019a,ge278dab8ac+eb3bbeb12f,ge410e46f29+250bf6acd3,gf5e32f922b+8c5ae1fdc5,gff02db199a+747430a128,gffe7e49bb4+a04f9ee0ab
LSST Data Management Base Package
Loading...
Searching...
No Matches
base.cc
Go to the documentation of this file.
1#include "astshim/base.h"
2
3#include <sstream>
4#include <stdexcept>
5#include <string>
6#include <vector>
7
8namespace ast {
9namespace {
10
11static std::ostringstream errorMsgStream;
12
13/*
14Write an error message to `errorMsgStream`
15
16Intended to be registered as an error handler to AST by calling `astSetPutErr(reportError)`.
17*/
18void reportError(int errNum, const char *errMsg) { errorMsgStream << errMsg; }
19
20/*
21Instantiate this class to register `reportError` as an AST error handler.
22*/
23class ErrorHandler {
24public:
25 ErrorHandler() { astSetPutErr(reportError); }
26
27 ErrorHandler(ErrorHandler const &) = delete;
28 ErrorHandler(ErrorHandler &&) = delete;
29 ErrorHandler &operator=(ErrorHandler const &) = delete;
30 ErrorHandler &operator=(ErrorHandler &&) = delete;
31
32 static std::string getErrMsg() {
33 auto errMsg = errorMsgStream.str();
34 // clear status bits
35 errorMsgStream.clear();
36 if (errMsg.empty()) {
37 errMsg = "Failed with AST status = " + std::to_string(astStatus);
38 } else {
39 // empty the stream
40 errorMsgStream.str("");
41 }
42 astClearStatus;
43 return errMsg;
44 }
45};
46
47} // namespace
48
49void assertOK(AstObject *rawPtr1, AstObject *rawPtr2) {
50 // Construct ErrorHandler once, the first time this function is called.
51 // This is done to initialize `errorMsgStream` and register `reportError` as the AST error handler.
52 // See https://isocpp.org/wiki/faq/ctors#static-init-order-on-first-use
53 static ErrorHandler *errHandler = new ErrorHandler();
54 if (!astOK) {
55 if (rawPtr1) {
56 astAnnul(rawPtr1);
57 }
58 if (rawPtr2) {
59 astAnnul(rawPtr2);
60 }
61 throw std::runtime_error(errHandler->getErrMsg());
62 }
63}
64
66 return static_cast<ConstArray2D>(arrayFromVector(const_cast<std::vector<double> &>(vec), nAxes));
67}
68
70 int nPoints = vec.size() / nAxes;
71 if (nPoints * nAxes != vec.size()) {
73 os << "vec length = " << vec.size() << " not a multiple of nAxes = " << nAxes;
74 throw std::runtime_error(os.str());
75 }
76 Array2D::Index shape = ndarray::makeVector(nAxes, nPoints);
77 Array2D::Index strides = ndarray::makeVector(nPoints, 1);
78 return external(vec.data(), shape, strides);
79}
80
81} // namespace ast
T clear(T... args)
T data(T... args)
AST wrapper classes and functions.
ndarray::Array< const double, 2, 2 > ConstArray2D
2D array of const double; typically used for lists of const points
Definition base.h:46
ndarray::Array< double, 2, 2 > Array2D
2D array of const double; typically used for lists of const points
Definition base.h:42
void assertOK(AstObject *rawPtr1=nullptr, AstObject *rawPtr2=nullptr)
Throw std::runtime_error if AST's state is bad.
Definition base.cc:49
ConstArray2D arrayFromVector(std::vector< double > const &vec, int nAxes)
Reshape a vector as a 2-dimensional array that shares the same memory.
Definition base.cc:65
T size(T... args)
T str(T... args)
T to_string(T... args)