LSST Applications 24.1.6,g063fba187b+56b85ce14a,g0f08755f38+df8a265115,g12f32b3c4e+891a09f10d,g1524ad2192+7a5d7b3fbd,g1653933729+a8ce1bb630,g168dd56ebc+a8ce1bb630,g28da252d5a+07cb1400be,g2bbee38e9b+ae03bbfc84,g2bc492864f+ae03bbfc84,g3156d2b45e+6e55a43351,g347aa1857d+ae03bbfc84,g35bb328faa+a8ce1bb630,g3a166c0a6a+ae03bbfc84,g3e281a1b8c+c5dd892a6c,g414038480c+6b9177ef31,g41af890bb2+8f257c4c0b,g781aacb6e4+a8ce1bb630,g7af13505b9+7137b3b17d,g80478fca09+6df6903293,g82479be7b0+091ce1d07f,g858d7b2824+df8a265115,g89c8672015+f4add4ffd5,g9125e01d80+a8ce1bb630,g9726552aa6+414189b318,ga5288a1d22+4a2bca08d7,gacef1a1666+c9a8ff65f4,gb58c049af0+d64f4d3760,gbcfae0f0a0+de1d42d831,gc28159a63d+ae03bbfc84,gcf0d15dbbd+72117bf34e,gda6a2b7d83+72117bf34e,gdaeeff99f8+1711a396fd,ge500cccec5+c8c9c9af63,ge79ae78c31+ae03bbfc84,gf0baf85859+c1f95f4921,gfa517265be+df8a265115,gfa999e8aa5+17cd334064,gfb92a5be7c+df8a265115
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
std::ostream * os
Definition Schema.cc:557
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)